@charset "UTF-8";
:root {
  background-color: var(--color-white);
  color: var(--color-black);
}

html {
  font-size: clamp(1rem, 0.766rem + 1vw, 1.125rem);
  height: 100%;
  line-break: strict;
}

body {
  font-family: "Zen Kaku Gothic New", "Hiragino Kaku Gothic Pro", "Hiragino Sans", "游ゴシック体", YuGothic, "游ゴシック", Meiryo, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  height: 100%;
}

h1, h2, h3, h4, h5, ul, dl {
  font-weight: normal;
  margin: 0;
  padding: 0;
}

ul, ol {
  padding: 0;
  margin: 0;
  list-style-type: none;
  overflow: hidden;
}

a {
  outline: 0;
  text-decoration: none;
}

p, dt, dd, li {
  line-height: 1.75;
  margin: 0;
  padding: 0;
}
p a, p span, dt a, dt span, dd a, dd span, li a, li span {
  color: inherit;
  font-size: inherit;
}

table {
  border-collapse: collapse;
  width: 100%;
}
table th, table td {
  padding: 0.5em 1em;
}
table th dt, table th dd, table th li, table th a, table th span, table td dt, table td dd, table td li, table td a, table td span {
  font-size: inherit;
}

figure {
  margin: 0;
}

.for-large {
  display: none;
}

.for-small {
  display: block;
}

.hover-fade {
  transition-property: opacity;
  transition-duration: var(--animate-duration);
  transition-timing-function: var(--animate-easing);
  transition-delay: 0s;
}
.hover-fade:hover {
  opacity: var(--animate-opacity);
}

.img-fit {
  height: auto;
  width: 100%;
}

.layout-max,
.layout-primary,
.layout-secondary {
  margin-right: var(--margin-side-small);
  margin-left: var(--margin-side-small);
  width: auto;
}

.ol-lower,
.ol-number,
.ol-upper {
  overflow: visible;
  padding-left: 2rem;
}

.ol-lower {
  list-style-type: lower-alpha;
}

.ol-number {
  list-style-type: decimal;
}

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

.text-nowrap {
  display: inline-block;
  white-space: nowrap;
}

.ul-disc,
.ul-halfnote,
.ul-hyphen,
.ul-note {
  overflow: hidden;
}
.ul-disc li,
.ul-halfnote li,
.ul-hyphen li,
.ul-note li {
  padding-left: 1em;
}
.ul-disc li:before,
.ul-halfnote li:before,
.ul-hyphen li:before,
.ul-note li:before {
  margin-left: -1rem;
  width: 1rem;
}

.ul-disc li:before {
  content: "・";
}

.ul-halfnote li:before {
  content: "*";
}

.ul-hyphen li:before {
  content: "-";
}

.ul-note li:before {
  content: "※";
}

.js-fadein {
  transition-property: opacity, filter, transform;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.61, 1, 0.88, 1);
  transition-delay: 0s;
  opacity: 0;
  transform: translateY(1.5rem);
}
.js-fadein.-show {
  opacity: 1;
  transform: translateY(0);
}

.site-article > .header {
  margin-bottom: 2.5rem;
}
.site-article > .header > .date {
  color: #b3b3b3;
  display: block;
  margin-bottom: 1rem;
}
.site-article > .content {
  margin-bottom: 3rem;
}

.site-block {
  padding: 4rem 0;
  position: relative;
}
.site-block.-intro {
  margin-bottom: -5px;
  padding-top: 5rem;
  padding-bottom: calc(30.875vw + 1rem);
}
.site-block.-intro::before {
  background: url(../images/home/divide_ornament01.svg) center bottom no-repeat;
  background-size: cover;
  content: "";
  height: 30.875vw;
  position: absolute;
  inset: auto auto 0 0;
  width: 100%;
}
.site-block.-blue {
  background-color: var(--color-project-blue);
  color: var(--color-white);
  padding-top: 3rem;
  padding-bottom: 6.5rem;
}
.site-block.-blue::before {
  aspect-ratio: 59/77;
  background: url(../images/home/divide_ornament02.svg) center center no-repeat;
  background-size: contain;
  content: "";
  height: 4.813rem;
  margin: auto;
  position: absolute;
  inset: auto 0 0 0;
  width: 3.688rem;
  z-index: 3;
}
.site-block.-strength {
  margin-bottom: -31.8680555556vw;
  padding-top: 22.2222222222vw;
  padding-bottom: calc(31.8680555556vw + 4rem);
}
.site-block.-strength::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament03.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 18.9583333333vw;
  position: absolute;
  inset: -0.625rem auto auto 0;
  width: 100%;
}
.site-block.-strength.-show::before {
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 100% 100%, 100% 100%, 0 100%);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 100% 100%, 100% 100%, 0 100%);
}
.site-block.-line {
  padding-top: calc(31.8680555556vw - 1.5rem);
  padding-bottom: 2rem;
}
.site-block.-line::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament04.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 31.8680555556vw;
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
}
.site-block.-line > .ornament {
  position: static;
}
.site-block.-line > .ornament::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/image_line_ornament01.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 4.75rem;
  position: absolute;
  inset: 0.5555555556vw auto auto 3.0555555556vw;
  width: 5.813rem;
}
.site-block.-line > .ornament::after {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/image_line_ornament02.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 6.25rem;
  position: absolute;
  inset: auto -1.5rem 0 auto;
  width: 8.188rem;
}
.site-block.-announce {
  margin-top: 0;
  padding-top: calc(31.8680555556vw + 4rem);
  padding-bottom: 21.9375vw;
}
.site-block.-announce::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament05.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 31.8680555556vw;
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
}
.site-block.-announce > .ornament {
  position: static;
}
.site-block.-announce > .ornament::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/image_announce_ornament01.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 6.188rem;
  position: absolute;
  inset: 4rem auto auto -1.5rem;
  width: 7.438rem;
}
.site-block.-announce > .ornament::after {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/image_announce_ornament02.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 5.25rem;
  position: absolute;
  inset: auto -2rem 5rem auto;
  width: 6.563rem;
}
.site-block.-step {
  padding-top: 4rem;
}
.site-block.-step::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament06.png) center top no-repeat;
  background-size: cover;
  content: "";
  height: 21.9375vw;
  position: absolute;
  inset: -10.1388888889vw auto auto 0;
  width: 105.6944444444vw;
}
.site-block.-note {
  padding-top: 21.9375vw;
  padding-bottom: 4rem;
}
.site-block.-note::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament07.png) center top no-repeat;
  background-size: cover;
  content: "";
  height: 21.9375vw;
  position: absolute;
  inset: -7.9166666667vw auto auto 0;
  width: 105.6944444444vw;
}
.site-block.-faq {
  padding-top: 4rem;
  padding-bottom: 3rem;
}
.site-block.-faq::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament08.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 6.1388888889vw;
  position: absolute;
  inset: -2.3611111111vw auto auto 0;
  width: 100%;
}
.site-block.-closer {
  padding-top: 5rem;
  padding-bottom: 6rem;
}
.site-block.-closer::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament09.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 6.1388888889vw;
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
}
.site-block.-contact {
  padding-top: 2.5rem;
}
.site-block.-contact::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/home/divide_ornament10.svg) center top no-repeat;
  background-size: cover;
  content: "";
  height: 18.6875vw;
  position: absolute;
  inset: -13.2638888889vw auto auto 0;
  width: 100%;
}
.site-block.-beige {
  background-color: var(--color-project-beige);
}
.site-block.-dark-beige {
  background-color: var(--color-project-dark-beige);
}
.site-block::after {
  background: url(../images/common/background_noise.png) top center repeat;
  background-size: 100px 100px;
  content: "";
  height: 100%;
  mix-blend-mode: multiply;
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  z-index: 1;
}
.site-block > * {
  position: relative;
  z-index: 2;
}

.site-button-primary {
  transition-property: opacity;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  color: var(--color-white);
  background-color: var(--color-brand-line);
  border-radius: 100vw;
  box-shadow: 0 4px 0 #008509;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  line-height: 1.2;
  padding: 0.5rem 1.5rem 0.5rem 1rem;
  text-decoration: none;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.site-button-primary::before {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  aspect-ratio: 1/1;
  background: url(../images/common/icon_line.png) center center no-repeat;
  background-size: contain;
  content: "";
  display: block;
  width: 3rem;
}
.site-button-primary > .text {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}
.site-button-primary > .text > .main {
  font-size: 1rem;
}
.site-button-primary > .text > .sub {
  font-size: 0.813rem;
}
.site-button-primary.-center {
  margin-right: auto;
  margin-left: auto;
}
.site-button-primary:hover {
  opacity: 0.5;
}

.site-button-text {
  transition-property: background-size;
  transition-duration: 0.6s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 0%);
  background-position: left bottom;
  background-repeat: no-repeat;
  background-size: 100% 1px;
  color: #000;
  text-decoration: none;
}
.site-button-text::after {
  background-color: currentColor;
  content: "";
  display: inline;
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
}
.site-button-text:hover {
  background-position: right bottom;
  background-size: 0 1px;
}

.site-cms-pager {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  font-size: 1rem;
  margin-top: var(--spacing-two);
  text-align: center;
}
.site-cms-pager .page-numbers {
  transition-property: background-color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: var(--color-light-grey);
  border: none;
  font-size: inherit;
  margin: 0 1px;
  padding: 8px 10px;
  position: relative;
  text-decoration: none;
}
.site-cms-pager .page-numbers:hover, .site-cms-pager .page-numbers.current {
  background-color: var(--color-primary);
  color: var(--color-white);
}
.site-cms-pager .page-numbers.dots {
  padding: 0;
}
.site-cms-pager .page-numbers.dots:hover {
  color: var(--color-black);
}
.site-cms-pager .page-numbers.dots:after {
  content: none;
}
.site-cms-pager .page-numbers.prev {
  display: none;
}
.site-cms-pager .page-numbers.prev:before {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_left-secondary.svg);
  mask-image: url(../images/icon/arrow_left-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
  line-height: 1;
}
.site-cms-pager .page-numbers.next {
  display: none;
}
.site-cms-pager .page-numbers.next:after {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
  line-height: 1;
}

.site-cms-pager-select {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  font-size: 1rem;
  margin-top: var(--spacing-two);
  text-align: center;
}
.site-cms-pager-select > a {
  transition-property: background-color, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  border: 1px solid var(--color-border);
  display: block;
  font-size: inherit;
  margin: 0 0.5em;
  padding: 0.5em;
  position: relative;
  text-decoration: none;
}
.site-cms-pager-select > a:before {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  line-height: 1;
  width: 0.875rem;
}
.site-cms-pager-select > a:hover {
  background-color: var(--color-light-grey);
  color: var(--color-grey);
}
.site-cms-pager-select > a:first-child {
  margin-right: 0.5rem;
}
.site-cms-pager-select > a:first-child:before {
  -webkit-mask-image: url(../images/icon/arrow_left-secondary.svg);
  mask-image: url(../images/icon/arrow_left-secondary.svg);
}
.site-cms-pager-select > a:last-child {
  margin-left: 0.5rem;
}
.site-cms-pager-select > a:last-child:before {
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
}
.site-cms-pager-select > .select {
  position: relative;
}
.site-cms-pager-select > .select > .current {
  transition-property: background-color, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  border: 1px solid var(--color-border);
  cursor: pointer;
  display: block;
  height: 100%;
  padding: 0.5em 2em 0.5em 0.5em;
  position: relative;
  width: 10rem;
}
.site-cms-pager-select > .select > .current::after {
  border-left: 1px solid var(--color-border);
  background-color: currentColor;
  content: "";
  display: block;
  -webkit-mask-image: url(../images/icon/select.svg);
  mask-image: url(../images/icon/select.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 1rem;
  margin-left: 0.5em;
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  width: 1rem;
}
.site-cms-pager-select > .select > select {
  cursor: pointer;
  font-size: 16px;
  height: 100%;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
.site-cms-pager-select > .select > select:hover + .current {
  background-color: var(--color-light-grey);
  color: var(--color-grey);
}

.site-footer {
  background-color: var(--color-project-brown);
  display: grid;
  align-items: start;
  grid-template-areas: "title" "description" "link" "copyright";
  grid-template-columns: 1fr;
  gap: 1.5rem;
  padding: 3rem var(--margin-side-small);
}
.site-footer > .title {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.625rem;
  grid-area: title;
}
.site-footer > .description {
  grid-area: description;
  line-break: strict;
  overflow-wrap: anywhere;
  text-align: center;
  word-break: keep-all;
}
.site-footer > .link {
  background-color: var(--color-white);
  border-radius: 10px;
  display: flex;
  align-items: center;
  gap: 2rem;
  grid-area: link;
  margin-right: auto;
  margin-left: auto;
  padding: 1rem 2.5rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.site-footer > .link > li {
  line-height: 1;
}
.site-footer > .link > li > .item {
  display: block;
}
.site-footer > .copyright {
  grid-area: copyright;
  margin-top: auto;
  text-align: center;
}

.site-form-content input,
.site-form-content select,
.site-form-content textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  box-shadow: none;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.5;
  outline: 0;
}
.site-form-content input[type=text],
.site-form-content input[type=email],
.site-form-content input[type=tel],
.site-form-content textarea {
  border-radius: 3px;
  padding: 0.55em 0.8em;
}
.site-form-content input[type=email] {
  transition-property: font-size;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
}
.site-form-content input[type=email]:focus {
  font-size: 1.563rem;
}
.site-form-content input[type=radio],
.site-form-content input[type=checkbox] {
  box-shadow: inset 0 0 0 3px var(--color-white);
  height: 16px;
  margin-right: 10px;
  vertical-align: middle;
  width: 16px;
}
.site-form-content input[type=radio] {
  border-radius: 10px;
}
.site-form-content input[type=radio]:checked {
  background-color: var(--color-black);
}
.site-form-content input[type=checkbox]:checked {
  background: url(../images/common/icon-check.svg) center center no-repeat;
  background-size: 90% 90%;
}
.site-form-content select {
  background: url(../images/common/icon-arrow-under.png) 95% center no-repeat #fff;
  border-radius: 3px;
  padding: 0.55em 3.5em 0.55em 0.8em;
}
.site-form-content textarea {
  height: 200px;
}
.site-form-content fieldset {
  border: 0;
  margin: 0;
  padding: 0;
}
.site-form-content label.heading,
.site-form-content legend.heading {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: var(--spacing-break);
}
.site-form-content label.subheading,
.site-form-content legend.subheading {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin-bottom: var(--spacing-break);
}
.site-form-content label.wrap {
  display: inline-block;
  font-size: 1rem;
  letter-spacing: 0.05em;
  margin-right: 2em;
  vertical-align: middle;
}
.site-form-content .group {
  margin-bottom: var(--spacing-one);
}
.site-form-content .full {
  width: 100%;
}
.site-form-content .half {
  width: 100%;
}
.site-form-content .short {
  width: 25%;
}
.site-form-content .separate {
  display: flex;
  flex-wrap: wrap;
}
.site-form-content .separate > .block {
  margin-bottom: var(--spacing-one);
  width: 100%;
}
.site-form-content .separate > .block:last-child {
  margin-bottom: 0;
}
.site-form-content .spacer {
  margin-top: var(--spacing-break);
}
.site-form-content .required {
  background-color: var(--color-primary);
  color: var(--color-white);
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1;
  margin-right: 1em;
  padding: 0.3em;
}
.site-form-content .note {
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
  margin-top: var(--spacing-break);
}
.site-form-content .example {
  color: #999999;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
  margin-top: var(--spacing-break);
}
.site-form-content .privacy {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: var(--spacing-two);
}
.site-form-content .privacy input[type=checkbox] {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  cursor: pointer;
  height: 20px;
  width: 20px;
}
.site-form-content .privacy > label {
  display: flex;
}
.site-form-content .privacy > label > .text {
  font-size: 1.15rem;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
.site-form-content .privacy > label > .text > .icon-popup-a {
  transition-property: color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  border-bottom: 1px solid var(--color-primary);
  color: var(--color-black);
  cursor: pointer;
}
.site-form-content .privacy > label > .text > .icon-popup-a:hover {
  color: var(--color-primary);
}
.site-form-content .privacy > label > .text > .icon-popup-a::after {
  color: var(--color-primary);
}
.site-form-content .error {
  background-color: var(--color-orange);
  border-radius: 6px;
  color: var(--color-white) !important;
  display: block;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: var(--spacing-break-small);
  padding: var(--spacing-break-small);
}
.site-form-content .mwform-radio-field {
  display: block;
}
.site-form-content .mwform-radio-field.horizontal-item {
  display: inline-block;
  margin-top: 0;
}

.site-heading-simple {
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.site-heading-simple.-factor-1 {
  font-size: 1.125rem;
}
.site-heading-simple.-factor-2 {
  font-size: 1.375rem;
}
.site-heading-simple.-factor-3 {
  font-size: 1.625rem;
}
.site-heading-simple.-factor-4 {
  font-size: 1.625rem;
}
.site-heading-simple.-factor-5 {
  font-size: 1.625rem;
}
.site-heading-simple.-center-all {
  text-align: center;
}
.site-heading-simple > .accent {
  color: var(--color-project-yellow);
  display: inline-block;
  font-style: normal;
  position: relative;
  -webkit-text-stroke: 2px var(--color-black);
  -webkit-text-fill-color: var(--color-project-yellow);
}
.site-heading-simple > .accent::after {
  content: attr(data-text);
  position: absolute;
  top: 0;
  left: 0;
  -webkit-text-stroke: 0;
}
.site-heading-simple > .line {
  color: var(--color-brand-line);
  display: inline-block;
  font-style: normal;
  margin-right: 0.25em;
  padding: 0 0.25em;
  position: relative;
}
.site-heading-simple > .line > .text {
  font-weight: 900;
  position: relative;
  z-index: 2;
}
.site-heading-simple > .line::after {
  background-color: var(--color-white);
  border: 2px solid var(--color-black);
  box-shadow: 2px 3px 0 var(--color-black);
  content: "";
  height: 90%;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
}
.site-heading-simple > .line.-brand > .text {
  font-weight: 700;
}
.site-heading-simple > .line.-brand::after {
  border-color: var(--color-brand-line);
  box-shadow: 2px 3px 0 var(--color-brand-line);
}
.site-heading-simple > .point {
  line-height: 1.8;
  position: relative;
}
.site-heading-simple > .point::after {
  aspect-ratio: 1/1;
  background: var(--color-project-orange);
  border-radius: 50%;
  content: "";
  margin: 0 auto;
  position: absolute;
  top: -0.188rem;
  right: 0;
  left: 0;
  width: 0.375rem;
}
.site-heading-simple.-light {
  color: var(--color-white);
}
.site-heading-simple.-light > .accent {
  -webkit-text-stroke: 0;
}
.site-heading-simple.-light > .accent::after {
  content: none;
}
.site-heading-simple.-line > .accent {
  color: var(--color-brand-line);
  -webkit-text-stroke: 0;
  -webkit-text-fill-color: var(--color-brand-line);
}
.site-heading-simple.-line > .accent::after {
  content: none;
}

.site-heading-ornament {
  background-color: var(--color-project-yellow);
  border: 1px solid var(--color-black);
  border-radius: 100vw;
  display: inline-block;
  font-feature-settings: "palt" 1;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.6;
  margin: 0 auto;
  padding: 0.25rem 1.5rem;
  position: relative;
  text-align: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.site-heading-ornament::after {
  aspect-ratio: 1/1;
  background-color: var(--color-project-yellow);
  border: 1px solid var(--color-black);
  border-radius: 50%;
  -webkit-clip-path: polygon(0 14px, 25px 14px, 25px 25px, 0 25px);
  clip-path: polygon(0 14px, 25px 14px, 25px 25px, 0 25px);
  content: "";
  position: absolute;
  inset: auto auto -10px 42px;
  width: 25px;
}

.site-layout-side {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--margin-gutter-small);
}

.site-normalize-content.-block p {
  font-size: 1rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
}
.site-normalize-content.-block strong {
  font-weight: bold;
}
.site-normalize-content.-block em {
  font-style: italic;
}
.site-normalize-content.-block a {
  transition-property: border, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  color: var(--color-brand-line);
  text-decoration: underline;
}
.site-normalize-content.-block a:hover {
  text-decoration: none;
}
.site-normalize-content.-block h2 {
  font-feature-settings: "palt" 1;
  font-size: 1.375rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.site-normalize-content.-block h3 {
  font-feature-settings: "palt" 1;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.site-normalize-content.-block h4, .site-normalize-content.-block h5, .site-normalize-content.-block h6 {
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.site-normalize-content.-block ul, .site-normalize-content.-block ol {
  list-style-position: outside;
}
.site-normalize-content.-block li {
  font-size: 1rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
}
.site-normalize-content.-block ul {
  overflow: hidden;
}
.site-normalize-content.-block ul li {
  padding-left: 1em;
}
.site-normalize-content.-block ul li:last-child {
  margin-bottom: 0;
}
.site-normalize-content.-block ul li:before {
  content: "・";
  margin-left: -1rem;
  width: 1rem;
}
.site-normalize-content.-block ol {
  list-style-type: decimal;
  overflow: visible;
  padding-left: 2rem;
}
.site-normalize-content.-block ol li:last-child {
  margin-bottom: 0;
}
.site-normalize-content.-block .wp-block-table thead th {
  background-color: var(--color-primary);
  color: var(--color-white);
}
.site-normalize-content.-block .wp-block-table th,
.site-normalize-content.-block .wp-block-table td {
  border: 1px solid #c0c0c0;
  text-align: left;
  padding: 1rem 1.5rem;
  font-size: 1rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
}
.site-normalize-content.-block .wp-block-table figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .wp-block-table .has-fixed-layout {
  table-layout: fixed;
}
.site-normalize-content.-block img {
  display: block;
  height: auto;
  max-height: 38.125rem;
  max-width: 100%;
  width: auto;
}
.site-normalize-content.-block .wp-block-image figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .wp-block-image a {
  transition-property: opacity;
  transition-duration: var(--animate-duration);
  transition-timing-function: var(--animate-easing);
  transition-delay: 0s;
  border-bottom: 0;
  display: block;
}
.site-normalize-content.-block .wp-block-image a:after {
  content: none;
}
.site-normalize-content.-block .wp-block-image a:hover {
  opacity: var(--animate-opacity);
}
.site-normalize-content.-block .wp-block-image a[target=_blank]::after {
  content: none;
}
.site-normalize-content.-block .wp-block-image.is-style-rounded {
  border-radius: 50%;
}
.site-normalize-content.-block .wp-block-separator {
  background-color: #c0c0c0;
  border: 0;
  height: 1px;
  width: 100%;
}
.site-normalize-content.-block .wp-block-media-text {
  gap: 1.25rem;
}
.site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__media, .site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__content {
  padding: 0;
}
.site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__content {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
}
.site-normalize-content.-block .wp-block-media-text.has-media-on-the-right {
  flex-direction: row-reverse;
}
.site-normalize-content.-block .wp-block-media-text.is-stacked-on-mobile {
  flex-wrap: wrap;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-top {
  align-items: start;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-center {
  align-items: center;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-bottom {
  align-items: end;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill {
  align-items: stretch;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill > .wp-block-media-text__media {
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill > .wp-block-media-text__media img {
  visibility: hidden;
}
.site-normalize-content.-block .wp-block-columns {
  gap: 1.25rem;
}
.site-normalize-content.-block .wp-block-columns .wp-block-column:empty {
  display: none;
}
.site-normalize-content.-block .wp-block-embed-youtube .wp-block-embed__wrapper {
  aspect-ratio: 16/9;
  height: auto;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.site-normalize-content.-block .wp-block-embed-youtube .wp-block-embed__wrapper iframe {
  height: 100%;
  width: 100%;
}
.site-normalize-content.-block .wp-block-embed-youtube figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .has-text-align-left {
  text-align: left;
}
.site-normalize-content.-block .has-text-align-center {
  text-align: center;
}
.site-normalize-content.-block .has-text-align-right {
  text-align: right;
}
.site-normalize-content.-block .aligncenter {
  text-align: center;
}
.site-normalize-content.-block .aligncenter img,
.site-normalize-content.-block .aligncenter .wp-block-file__button {
  margin-right: auto;
  margin-left: auto;
}
.site-normalize-content.-block .alignleft {
  text-align: left;
}
.site-normalize-content.-block .alignleft img,
.site-normalize-content.-block .alignleft .wp-block-file__button {
  margin-right: auto;
  margin-left: 0;
}
.site-normalize-content.-block .alignleft .wp-block-file__button {
  text-align: center;
}
.site-normalize-content.-block .alignright {
  text-align: right;
}
.site-normalize-content.-block .alignright img,
.site-normalize-content.-block .alignright .wp-block-file__button {
  margin-right: 0;
  margin-left: auto;
}
.site-normalize-content.-block {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}
.site-normalize-content.-block h2 {
  margin-top: 1.6rem;
}
.site-normalize-content.-block figcaption {
  margin-top: var(--spacing-break);
}
.site-normalize-content.-block *:first-child {
  margin-top: 0;
}
.site-normalize-content.-block *:last-child {
  margin-bottom: 0;
}

.site-post > .inner {
  background-color: var(--color-white);
  border: 1px solid var(--color-black);
  border-radius: 20px;
  margin: auto;
  padding: 2rem var(--margin-side-small);
}
.site-post > .inner > .post {
  margin: auto;
}
.site-post > .inner > .post > .header {
  margin-bottom: 2rem;
}
.site-post > .inner > .post > .header > .title {
  border-bottom: 1px solid var(--color-black);
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.4;
  padding-bottom: 0.875rem;
}
.site-post > .footer {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  margin: 3rem auto 0;
}
.site-post > .footer > .button > .item {
  background-color: var(--color-white);
  border: 1px solid var(--color-black);
  border-radius: 100vw;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.5rem 1rem;
  text-align: center;
  text-decoration: none;
  width: 100%;
}
.site-post > .footer > .button > .item::before, .site-post > .footer > .button > .item::after {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  aspect-ratio: 1/1;
  content: "";
  display: block;
  width: 1.875rem;
}
.site-post > .footer > .button.-prev > .item::before {
  background-color: var(--color-project-dark-brown);
  -webkit-mask-image: url(../images/icon/arrow_left.svg);
  mask-image: url(../images/icon/arrow_left.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
}
.site-post > .footer > .button.-next > .item::after {
  background-color: var(--color-project-dark-brown);
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
}
.site-post > .footer > .home {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  order: -1;
}
.site-post > .footer > .home > .link {
  display: flex;
  align-items: center;
  justify-content: center;
}

.site-post-card {
  background-color: #fafafa;
  color: var(--color-black);
  display: flex;
  align-content: flex-start;
  flex-direction: row-reverse;
  padding: var(--margin-gutter-small);
  height: 100%;
}
.site-post-card > .image {
  background-color: var(--color-light-grey);
  height: 0;
  overflow: hidden;
  padding-top: 100px;
  position: relative;
  width: 100px;
}
.site-post-card > .image > img {
  height: auto;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
}
.site-post-card > .image.-landscape > img {
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: auto;
}
.site-post-card > .text {
  flex: 1;
  padding-right: calc(var(--margin-gutter-small) * 0.5);
}
.site-post-card > .text > .info {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 0.5em;
}
.site-post-card > .text > .info > .date {
  font-size: 1em;
  margin-right: 0.5em;
  margin-bottom: 0.5em;
}
.site-post-card > .text > .info > .category {
  display: flex;
  flex-wrap: wrap;
  margin: -0.25em 0;
}
.site-post-card > .text > .info > .category > .item {
  margin: 0.25em 0;
}
.site-post-card > .text > .info > .category > .item::after {
  content: "/";
  margin: 0 0.5em;
}
.site-post-card > .text > .info > .category > .item:last-child::after {
  content: none;
}
.site-post-card > .text > .title {
  display: block;
  font-size: 1.25rem;
  margin-bottom: 1rem;
  width: 100%;
}

.site-post-card-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-one) var(--margin-gutter-small);
}

.site-post-simple {
  color: var(--color-black);
  display: block;
}
.site-post-simple > .info {
  display: flex;
  margin-bottom: 0.5rem;
}
.site-post-simple > .info > .date {
  border-right: 1px solid var(--color-border);
  font-size: 1rem;
  flex: 0;
  margin-right: 1em;
  padding-right: 1em;
}
.site-post-simple > .info > .category {
  display: flex;
  flex-wrap: wrap;
  flex: 1;
  margin: -0.5rem 0;
}
.site-post-simple > .info > .category > .item {
  margin: 0.5em 0;
}
.site-post-simple > .info > .category > .item::after {
  content: "/";
  margin: 0 0.5em;
}
.site-post-simple > .info > .category > .item:last-child::after {
  content: none;
}
.site-post-simple > .title {
  font-size: 1.25rem;
}

.site-post-simple-list > .article {
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 1rem;
  padding-bottom: 1rem;
}

.site-sitemap > .list {
  border-bottom: 1px solid var(--color-border);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--margin-gutter);
  margin-bottom: var(--spacing-one);
  padding-bottom: var(--spacing-one);
}
.site-sitemap > .list:last-child {
  border-bottom: 0;
  margin-bottom: 0;
  padding-bottom: 0;
}
.site-sitemap-nest {
  display: flex;
}
.site-sitemap-nest > .list {
  padding-right: 1em;
  width: 50%;
}

.site-table-standard th,
.site-table-standard td {
  display: block;
  font-size: 1rem;
  line-height: 1.5;
  padding: 1.25em 0.5em 1.25em 0.5em;
  text-align: left;
}
.site-table-standard th {
  padding-bottom: 0;
}
.site-table-standard td {
  border-bottom: 1px solid var(--color-border);
  padding-top: 0.25em;
}

.site-text-standard {
  font-size: 1rem;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
}
.site-text-standard.-center-all {
  text-align: center;
}
.site-text-standard.-small {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.4;
}
.site-text-standard + .site-text-standard {
  margin-top: 1.6em;
}