@charset "UTF-8";
/*//////////////////////////////////////////////////////////

Copyright (C) apricot-design All Rights Reserved.
------------------------------------------------------------
CSS information
 file name  :  reset.css
 style info :  リセットファイル
 admin info :  apricot-design

//////////////////////////////////////////////////////////*/
article, aside, details, figcaption, figure, footer, header, hgroup, nav, section {
  display: block;
}

audio[controls], canvas, video {
  display: inline-block;
  *display: inline;
  zoom: 1;
}

html {
  overflow-y: scroll;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

body, div, dl, dt, dd, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td, ul {
  margin: 0;
  padding: 0;
}

body, button, input, select, textarea {
  font-family: inherit;
  font-size: 100%;
}

abbr[title] {
  border-bottom: 1px dotted;
}

b, strong {
  font-weight: bold;
}

blockquote {
  margin: 1em 40px;
}

dfn {
  font-style: italic;
}

mark {
  background: #ff0;
  color: #000;
}

pre, code, kbd, samp {
  font-family: monospace, monospace;
  _font-family: "courier new", monospace;
  font-size: 1em;
}

pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word;
}

q {
  quotes: none;
}
q:before, q:after {
  content: "";
  content: none;
}

small {
  font-size: inherit;
}

sub {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

ul, ol {
  margin: 0;
  padding: 0;
}

dd {
  margin: 0px;
}

nav ul, nav ol {
  list-style: none;
}

img {
  border: 0;
  -ms-interpolation-mode: bicubic;
}

svg:not(:root) {
  overflow: hidden;
}

figure, form {
  margin: 0;
}

fieldset {
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  border: 0;
  *margin-left: -7px;
}

button, input, select, textarea {
  font-size: 100%;
  margin: 0;
  vertical-align: baseline;
  *vertical-align: middle;
}

button, input {
  line-height: normal;
  *overflow: visible;
}

button {
  cursor: pointer;
  -webkit-appearance: button;
  padding: 0;
  border: none;
  background-color: transparent;
}

input[type=button], input[type=reset], input[type=submit] {
  cursor: pointer;
  -webkit-appearance: button;
}
input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
}
input[type=search] {
  -webkit-appearance: textfield;
  box-sizing: content-box;
}
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

textarea {
  overflow: auto;
  vertical-align: top;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  font-size: 100%;
}

img, abbr, acronym, fieldset {
  border: 0;
}

li {
  list-style: none;
}

/*画像を縦に並べた時に余白が出ないように*/
img {
  vertical-align: top;
  font-size: 0;
  line-height: 0;
}

/*box-sizingを全ブラウザに対応*/
* {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}
*:before, *:after {
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
}

.ie6_error, .no_script {
  background: #F66;
  padding: 100px;
  text-align: center;
  font-size: 150%;
  color: #333;
}

.mincho {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
}

.gothic {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
}

.en {
  font-family: "Josefin Sans", sans-serif;
}

.c_white {
  color: #fff;
}

.c_maincolor {
  color: #156743;
}

:root {
  --extend: min(calc(( 50vw - 50% ) * -1), 0px);
  --sideW: min(5.856vw, 80px);
  --headerHeight: 110px;
  --contentsWideS: 1000px;
  --contentsWideM: 1060px;
  --contentsWideL: 1206px;
  --contentsWide1100: 1100px;
}

@media screen and (max-width: 820px) {
  :root {
    --sideW: 6.4vw;
    --headerHeight: 82px;
    --sectionWrap: 3.75em;
  }
}
html {
  width: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: var(--headerHeight);
}

body {
  font: 400 16px/1.8 "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  letter-spacing: 0;
  color: #003D25;
  text-align: left;
  counter-reset: number 0;
}

.l_container_wrap {
  position: relative;
}

.l_container {
  position: relative;
}

.single-post .l_container,
.error404 .l_container {
  padding-top: 10.5em;
}
@media screen and (max-width: 820px) {
  .single-post .l_container,
  .error404 .l_container {
    padding-top: 7.5em;
  }
}

.single-case-study .l_container,
.single-column .l_container {
  padding-top: 9.5em;
}
@media screen and (max-width: 820px) {
  .single-case-study .l_container,
  .single-column .l_container {
    padding-top: 7.5em;
  }
}

.section_wrap {
  padding: 0 0 10em;
}
@media screen and (max-width: 820px) {
  .section_wrap {
    padding: 0 0 6.25em;
  }
}

.inner, .inner_1100, .inner_l, .inner_m, .inner_s {
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--sideW);
}

.inner_s {
  max-width: calc(var(--contentsWideS) + var(--sideW) * 2);
}

.inner_m {
  max-width: calc(var(--contentsWideM) + var(--sideW) * 2);
}

.inner_l {
  max-width: calc(var(--contentsWideL) + var(--sideW) * 2);
}

.inner_1100 {
  max-width: calc(var(--contentsWide1100) + var(--sideW) * 2);
}

section {
  margin: 0 0 6em;
}
@media screen and (max-width: 820px) {
  section {
    margin-bottom: 5em;
  }
}

.post_content h2 {
  font-size: 1.25em;
  font-weight: 600;
  background-color: #E8F7EF;
  padding: 9px 16px;
  margin-top: 70px;
}
@media screen and (max-width: 820px) {
  .post_content h2 {
    margin-top: 56px;
  }
}
.post_content strong {
  font-weight: 600;
}
.post_content ul {
  margin-top: 1.8em;
}

.column_174_style_01 {
  display: flex;
  gap: 3.48%;
}
.column_174_style_01 li {
  width: 100%;
}
.column_174_style_01 li dl {
  padding: 44px 5% 36px;
  height: 100%;
  display: grid;
  place-content: center;
  text-align: center;
  border-radius: 32px;
  border: 1px dashed #00AE68;
}
.column_174_style_01 li dt {
  color: #00AE68;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 820px) {
  .column_174_style_01 li dt {
    font-size: 1.2em;
  }
}
.column_174_style_01 li dd {
  font-size: 0.875em;
  font-weight: 600;
}

.column_174_style_02 {
  display: flex;
  gap: 4.92%;
}
@media screen and (max-width: 820px) {
  .column_174_style_02 {
    flex-direction: column;
    align-items: center;
    gap: 1.5em;
  }
}
.column_174_style_02 > li {
  width: 100%;
}
@media screen and (max-width: 820px) {
  .column_174_style_02 > li {
    width: 80%;
  }
}
.column_174_style_02 dl {
  height: 100%;
  border: 1px dashed #00AE68;
  color: #00AE68;
  font-weight: 600;
  text-align: center;
  padding: 22px 0 18px;
}
.column_174_style_02 dt {
  font-size: 2.25em;
  line-height: 1.3;
  margin-bottom: 10px;
}
@media screen and (max-width: 820px) {
  .column_174_style_02 dt {
    font-size: 1.8em;
  }
}
.column_174_style_02 dt span {
  display: block;
  font-size: 0.66em;
}
.column_174_style_02 dd {
  font-size: 0.875em;
  line-height: 1.6;
}
.column_174_style_02 dd .small {
  font-size: 0.715em;
}

a {
  text-decoration: none;
  color: inherit;
  transition: 0.3s;
}
a:link, a:active, a:visited {
  text-decoration: none;
}

h1, h2, h3, h4, h5, h6 {
  color: inherit;
  font-weight: inherit;
  line-height: 1.5;
}

label {
  cursor: pointer;
}

button {
  padding: 0;
  border: none;
  color: inherit;
}

picture {
  display: contents;
}
picture img {
  display: block;
}

img {
  max-width: 100%;
  height: auto;
}
img[src$=".svg"] {
  max-width: 100%;
  width: auto;
}

.opacity, .about_sec_03 .dlist_network dd a, .about_sec_03--table ul li a, .footer_address ul li .btn_googlemap, .wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label a {
  transition: 0.5s;
}
@media (hover: hover) {
  .opacity:hover, .about_sec_03 .dlist_network dd a:hover, .about_sec_03--table ul li a:hover, .footer_address ul li .btn_googlemap:hover, .wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label a:hover {
    opacity: 0.5;
  }
}

@media screen and (max-width: 820px) {
  .pc {
    display: none !important;
  }
}

@media screen and (min-width: 821px) {
  .sp {
    display: none !important;
  }
}

.img_only {
  display: block;
}
.img_only img {
  display: block;
  width: 100%;
}

.text_link {
  text-decoration: underline !important;
}

.fw_600 {
  font-weight: 600;
}

.marker_subcolor {
  background: linear-gradient(0deg, #00ae68 0%, #00ae68 60%, rgba(0, 174, 104, 0) 60%, rgba(0, 174, 104, 0) 100%);
}

input[type=text],
input[type=email],
input[type=tel],
textarea {
  width: 100%;
  padding: 0.5em;
  border-radius: 0;
  border: 1px solid #003D25;
  background: #F1F4F3;
  color: inherit;
  font-family: inherit;
  line-height: inherit;
  font-size: 16px !important;
  border-radius: 8px;
}

select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: 0.5em 28px 0.5em 0.5em;
  border-radius: 0;
  border: 1px solid rgba(0, 61, 37, 0.5);
  background: url(../images/icon_tri_select.svg) no-repeat center right 10px/10px 8px #fff;
  color: inherit;
  font-family: inherit;
  line-height: inherit;
  font-size: 16px !important;
}

textarea {
  height: 15em;
  min-width: 100%;
  max-width: 100%;
}

input[type=checkbox] {
  accent-color: #156743;
  inline-size: 1.5em;
  block-size: 1.5em;
  flex-shrink: 0;
}

input[type=radio] {
  accent-color: #156743;
  inline-size: 1.5em;
  block-size: 1.5em;
  flex-shrink: 0;
}

.dlist_form {
  display: flex;
  flex-wrap: wrap;
  gap: 2em 12px;
}
.dlist_form .group {
  width: 100%;
}
.dlist_form .group.name {
  width: calc((100% - 12px) / 2);
}
.dlist_form .group dt {
  font-size: 0.875em;
  font-weight: 600;
}
.dlist_form .group dt.require:after {
  content: "(必須)";
  color: #AE2800;
  margin-left: 0.5em;
}
.dlist_form .group dd {
  margin-top: 0px;
}
.dlist_form .group dd:not(:has(.list_kome)) {
  margin-top: 4px;
}
.dlist_form .list_kome {
  font-size: 0.75em;
  /* font-weight: 300; */
  margin-bottom: 10px;
}

.wpcf7-form-control-wrap[data-name=your-agreement] {
  display: block;
  margin-top: 32px;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox {
  display: block;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item {
  margin: 0;
  display: block;
  background-color: #F1F4F3;
  padding: 8px 5.6%;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label input {
  flex-shrink: 0;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label {
  font-size: 0.75em;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label a {
  text-decoration: underline;
}
.wpcf7-form-control-wrap[data-name=your-agreement] .wpcf7-checkbox .wpcf7-list-item label .wpcf7-list-item-label .ast {
  color: #AE2800;
}

.wpcf7-not-valid-tip {
  font-size: 0.875em !important;
  color: #AE2800 !important;
}

.wpcf7-submit {
  margin: 4em auto 0;
  background-color: #156743;
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 15px;
  width: 100%;
  max-width: 412px;
  height: 85px;
  border-radius: 100px;
  font-size: 1.25em;
  font-weight: 600;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 820px) {
  .wpcf7-submit {
    font-size: 1em;
    height: 72px;
  }
}
.wpcf7-submit:after {
  flex-shrink: 0;
  content: "";
  display: block;
  width: 32px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_right_01_maincolor.svg) no-repeat center/50%;
}
.wpcf7-submit:hover {
  background-color: #00AE68;
}
.wpcf7-submit:hover:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/50%;
}

.wpcf7-response-output,
.wpcf7-spinner {
  display: none !important;
}

.your-type .wpcf7-list-item,
.your-detail .wpcf7-list-item,
.your-timing .wpcf7-list-item {
  margin: 0 0 8px;
  background: #F1F4F3;
  border-radius: 8px;
  display: block;
  width: 100%;
  padding: 12px 16px;
}
.your-type .wpcf7-list-item:hover,
.your-detail .wpcf7-list-item:hover,
.your-timing .wpcf7-list-item:hover {
  font-weight: 700;
}
.your-type .wpcf7-list-item label,
.your-detail .wpcf7-list-item label,
.your-timing .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 8px;
}
.your-type .wpcf7-list-item label input:checked + .wpcf7-list-item-label,
.your-detail .wpcf7-list-item label input:checked + .wpcf7-list-item-label,
.your-timing .wpcf7-list-item label input:checked + .wpcf7-list-item-label {
  font-weight: 700;
}
.grecaptcha-badge {
  visibility: hidden;
}

@keyframes fade_in {
  80% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 1;
  }
}
[class^=fade_anim] {
  opacity: 0;
}
[class^=fade_anim].js-active {
  animation: fade_in 1s ease-out forwards;
}

.fade_anim.js-active {
  animation: fade_in 1s ease-in forwards;
}

.fade_anim_bottom {
  transform: translate(0, 60px);
}

.fade_anim_left {
  transform: translate(-40px, 0);
}

.fade_anim_right {
  transform: translate(60px, 0);
}

.bg_gradation_01 {
  background: linear-gradient(180deg, rgba(241, 244, 243, 0) 0%, rgb(241, 244, 243) 100%);
}
@media screen and (max-width: 820px) {
  .bg_gradation_01 {
    background: transparent;
  }
}

.ttl_cmn_01 {
  font-size: 1.5em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_01 {
    font-size: 1.125em;
  }
}
.ttl_cmn_01:before {
  content: attr(data-en);
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 3em;
  line-height: 1.2;
  margin-bottom: 4px;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_01:before {
    font-size: 2.44em;
  }
}

.ttl_cmn_02 {
  text-align: center;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_02 {
    font-size: 1.75em;
  }
}
.ttl_cmn_02:before {
  content: attr(data-en);
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.33em;
  margin-bottom: 0.5em;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_02:before {
    font-size: 0.5em;
  }
}

.ttl_cmn_03 {
  text-align: center;
  font-family: "Josefin Sans", sans-serif;
  font-size: 2.75em;
  font-weight: 600;
}
.ttl_cmn_03.align_left {
  text-align: left;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_03.align_left {
    text-align: center;
  }
}

.ttl_cmn_04 {
  padding-left: 72px;
  font-size: 0.75em;
  /* font-weight: 300; */
  line-height: 1.2;
  position: relative;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_04 {
    padding-left: 0;
  }
}
.ttl_cmn_04:before {
  content: attr(data-en);
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 3.66em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_04:before {
    font-size: 3em;
  }
}
.ttl_cmn_04:after {
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  background-color: #156743;
  position: absolute;
  top: 20px;
  left: 0;
}
@media screen and (max-width: 820px) {
  .ttl_cmn_04:after {
    left: unset;
    right: calc(100% + 6px);
  }
}
.ttl_cmn_04.c_white:after {
  background-color: #fff;
}

.para_cmn_01 {
  font-size: 1.125em;
  font-weight: 500;
  line-height: 2;
}
@media screen and (max-width: 820px) {
  .para_cmn_01 {
    font-size: 1em;
  }
}
.para_cmn_01 p {
  margin-bottom: 1.8em;
}
.para_cmn_01 p:last-child {
  margin-bottom: 0;
}

.btn_cmn_01 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 144px;
  height: 48px;
  border: 2px solid #00AE68;
  border-radius: 50px;
  background-color: #fff;
  color: #00AE68;
  font-size: 0.875em;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding-bottom: 2px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .btn_cmn_01 {
    max-width: 242px;
    font-size: 1em;
    justify-content: flex-start;
    padding: 0 32px;
  }
}
.btn_cmn_01:after {
  content: "";
  display: block;
  width: 24px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #00AE68 url(../images/ico_arrow_right_01_white.svg) no-repeat center/14px;
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
}
.btn_cmn_01:hover {
  background-color: #00AE68;
  color: #fff;
}
.btn_cmn_01:hover:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/14px;
}

.btn_cmn_02 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 180px;
  height: 40px;
  border: 2px solid #00AE68;
  border-radius: 50px;
  background-color: #fff;
  color: #00AE68;
  font-size: 1em;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.5;
  padding: 0 1em 1px 0;
  position: relative;
}
@media screen and (max-width: 820px) {
  .btn_cmn_02 {
    max-width: 242px;
    font-size: 1em;
    justify-content: flex-start;
    padding: 0 32px;
    height: 48px;
  }
}
.btn_cmn_02:after {
  content: "";
  display: block;
  width: 27px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #00AE68 url(../images/ico_arrow_right_01_white.svg) no-repeat center/14px;
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 820px) {
  .btn_cmn_02:after {
    right: 9px;
  }
}
.btn_cmn_02:hover {
  background-color: #00AE68;
  color: #fff;
}
.btn_cmn_02:hover:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/14px;
}

.btn_cmn_03 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 442px;
  border-radius: 8px;
  background-color: #156743;
  color: #fff;
  font-size: 1.25em;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1.5em;
  padding: 0.45em 1.2em;
  transition: 0.3s;
}
@media screen and (max-width: 820px) {
  .btn_cmn_03 {
    border-radius: 0 0 13px 13px;
    font-size: 1.125em;
    padding: 20px 1em 20px 1.2em;
    letter-spacing: 0;
  }
}
.btn_cmn_03:after {
  content: "";
  display: block;
  width: 1.6em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_right_01_maincolor.svg) no-repeat center/0.8em;
}

.btn_download_01 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 176px;
  height: 48px;
  border-radius: 50px;
  border: 2px solid #00AE68;
  background-color: #fff;
  color: #00AE68;
  font-size: 0.875em;
  font-weight: 600;
}
@media (hover: hover) {
  .btn_download_01:hover {
    background-color: #00AE68;
    color: #fff;
  }
}
@media screen and (max-width: 820px) {
  .btn_download_01 {
    gap: 16px;
    padding-left: 25px;
    width: 100%;
    max-width: 280px;
    border-radius: 8px;
    background-color: #00AE68;
    color: #fff;
    font-size: 1.125em;
    font-weight: 700;
  }
  .btn_download_01:after {
    content: "";
    display: block;
    width: 24px;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/17px;
  }
}

.btn_contact_01, .thanks_content a, .download_content a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 176px;
  height: 48px;
  border-radius: 50px;
  background-color: #003D25;
  color: #fff;
  font-size: 0.875em;
  font-weight: 600;
}
@media (hover: hover) {
  .btn_contact_01:hover, .thanks_content a:hover, .download_content a:hover {
    background-color: #00AE68;
  }
}
@media screen and (max-width: 820px) {
  .btn_contact_01, .thanks_content a, .download_content a {
    gap: 16px;
    padding-left: 25px;
    width: 100%;
    max-width: 280px;
    border-radius: 8px;
    background-color: #003D25;
    color: #fff;
    font-size: 1.125em;
    font-weight: 700;
  }
  .btn_contact_01:after, .thanks_content a:after, .download_content a:after {
    content: "";
    display: block;
    width: 24px;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background: #fff url(../images/ico_arrow_right_01_textcolor.svg) no-repeat center/17px;
  }
}

.list_kome > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_kome > li:before {
  content: "※";
}

.list_dot > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_dot > li:before {
  content: "・";
}

.list_ast > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_ast > li:before {
  content: "＊";
}

.list_maru > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_maru > li:before {
  content: "●";
}

.list_square > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_square > li:before {
  content: "■";
}

.list_number {
  counter-reset: number 0;
}
.list_number > li {
  counter-increment: number 1;
}
.list_number > li:before {
  content: counter(number);
}

.single_pagination {
  position: relative;
}
.single_pagination .inner {
  max-width: calc(795px + var(--sideW) * 2);
  padding-top: 5em;
}
@media screen and (max-width: 820px) {
  .single_pagination .inner {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 2em;
  }
}
.single_pagination ul {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 5%;
}
.single_pagination li {
  font-family: "Josefin Sans", sans-serif;
  font-size: 1.2em;
  font-weight: 400;
  line-height: 1.5;
}
.single_pagination li a span {
  display: block;
  padding-top: 6px;
}
.single_pagination li.prev {
  width: 100%;
}
@media screen and (max-width: 820px) {
  .single_pagination li.prev {
    display: flex;
    align-items: center;
  }
}
.single_pagination li.prev a {
  display: inline-flex;
  align-items: center;
  gap: 16px;
}
.single_pagination li.prev a:before {
  content: "";
  display: block;
  width: 32px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  border: 2px solid #003D25;
  background: #fff url(../images/ico_arrow_right_01_textcolor.svg) no-repeat center/12px;
  transform: rotate(180deg);
}
@media screen and (max-width: 820px) {
  .single_pagination li.prev a:before {
    background-size: 12px;
    width: 32px;
  }
}
.single_pagination li.prev a:hover:before {
  background: #003D25 url(../images/ico_arrow_right_01_white.svg) no-repeat center/12px;
}
.single_pagination li.archive {
  flex-shrink: 0;
}
.single_pagination li.archive a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 96px;
  height: 32px;
  border-radius: 50px;
  border: 2px solid #003D25;
  padding-top: 6px;
  background-color: #fff;
}
@media screen and (max-width: 820px) {
  .single_pagination li.archive a {
    width: 100px;
  }
}
.single_pagination li.archive a:hover {
  background-color: #003D25;
  color: #fff;
}
.single_pagination li.next {
  width: 100%;
  text-align: right;
}
.single_pagination li.next a {
  display: inline-flex;
  align-items: center;
  gap: 16px;
}
.single_pagination li.next a:after {
  content: "";
  display: block;
  width: 32px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  border: 2px solid #003D25;
  background: #fff url(../images/ico_arrow_right_01_textcolor.svg) no-repeat center/12px;
}
@media screen and (max-width: 820px) {
  .single_pagination li.next a:after {
    background-size: 12px;
    width: 32px;
  }
}
.single_pagination li.next a:hover:after {
  background: #003D25 url(../images/ico_arrow_right_01_white.svg) no-repeat center/12px;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  opacity: 1;
  visibility: visible;
  transition: 0.5s;
}
.loading.end {
  opacity: 0;
  visibility: hidden;
}

.hbm_btn {
  position: relative;
  z-index: 1;
  padding: 0;
  border: none;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 48px;
  aspect-ratio: 1/1;
  position: relative;
  border-radius: 50%;
  border: 2px solid #003D25;
  position: relative;
  transition: 0.3s;
}
.hbm_btn .bar {
  transition: inherit;
  display: block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background-color: #003D25;
  position: absolute;
  left: calc(50% - 2px);
}
.hbm_btn .bar:nth-child(1) {
  top: calc(50% - 10px);
}
.hbm_btn .bar:nth-child(2) {
  top: calc(50% - 2px);
}
.hbm_btn .bar:nth-child(3) {
  top: calc(50% + 6px);
}
.hbm_btn:hover {
  background-color: #F1F4F3;
}
.hbm_btn.js-active {
  background-color: transparent;
  border: none;
}
.hbm_btn.js-active .bar {
  width: 32px;
  height: 1px;
  border-radius: 0;
}
.hbm_btn.js-active .bar:nth-child(1) {
  top: calc(50% - 2px);
  transform: rotate(135deg);
  left: calc(50% - 16px);
}
.hbm_btn.js-active .bar:nth-child(2) {
  top: calc(50% - 2px);
  transform: rotateX(90deg);
  left: calc(50% - 16px);
}
.hbm_btn.js-active .bar:nth-child(3) {
  top: calc(50% - 2px);
  transform: rotate(-135deg);
  left: calc(50% - 16px);
}
@media screen and (max-width: 820px) {
  .hbm_btn.js-active {
    background-color: #fff;
    border: 2px solid #003D25;
  }
  .hbm_btn.js-active .bar {
    width: 24px;
    height: 2px;
    border-radius: 50px;
  }
  .hbm_btn.js-active .bar:nth-child(1) {
    top: calc(50% - 1px);
    transform: rotate(135deg);
    left: calc(50% - 12px);
  }
  .hbm_btn.js-active .bar:nth-child(2) {
    top: calc(50% - 1px);
    transform: rotateX(90deg);
    left: calc(50% - 12px);
  }
  .hbm_btn.js-active .bar:nth-child(3) {
    top: calc(50% - 1px);
    transform: rotate(-135deg);
    left: calc(50% - 12px);
  }
}

.gnavi {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  height: 100%;
  background-color: #E8F7EF;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}
.gnavi.js-active {
  opacity: 1;
  visibility: visible;
}
@media screen and (max-width: 820px) {
  .gnavi {
    background-color: transparent;
  }
}
.gnavi .inner_l {
  height: 100%;
  display: flex;
  gap: 7.54%;
}
@media screen and (max-width: 820px) {
  .gnavi .inner_l {
    gap: 0;
    padding: 0;
  }
}
.gnavi .inner_l .box_image {
  width: 35.06%;
  flex-shrink: 0;
  padding: 120px 0 0;
}
@media screen and (max-width: 820px) {
  .gnavi .inner_l .box_image {
    width: 24px;
    background-color: rgba(0, 61, 37, 0.4);
  }
  .gnavi .inner_l .box_image img {
    display: none;
  }
}
.gnavi .inner_l .box_nav {
  margin: 0 var(--extend) 0 0;
  padding-right: var(--sideW);
  flex-grow: 1;
  height: 100%;
  overflow: scroll;
  overscroll-behavior-y: none;
}
@media screen and (max-width: 820px) {
  .gnavi .inner_l .box_nav {
    padding: 0 9.6vw;
    background-color: #E8F7EF;
  }
}
.gnavi .inner_l .box_nav > ul {
  margin-top: 4em;
}
@media screen and (max-width: 820px) {
  .gnavi .inner_l .box_nav > ul {
    margin-top: 24px;
    border-top: 1px solid rgba(0, 61, 37, 0.3);
  }
}
.gnavi .gnavi_cta {
  margin: 4em 0 0;
  max-width: 552px;
  display: flex;
  gap: 8px 28px;
}
@media screen and (max-width: 820px) {
  .gnavi .gnavi_cta {
    flex-direction: column;
    margin: 2em 0 0;
  }
  .gnavi .gnavi_cta.sp {
    margin-top: 88px;
  }
}
.gnavi .gnavi_cta a {
  max-width: unset;
  width: 100%;
  height: 86px;
  font-size: 1.375em;
}
@media screen and (max-width: 820px) {
  .gnavi .gnavi_cta a {
    height: 48px;
    font-size: 1.125em;
  }
}
.gnavi .gnavi_end {
  margin-top: 5em;
  margin-bottom: 6em;
  width: 100%;
  max-width: 552px;
}
@media screen and (max-width: 820px) {
  .gnavi .gnavi_end {
    margin: 2em 0 2.25em;
    text-align: center;
  }
}
.gnavi .gnavi_end .policy {
  font-size: 0.75em;
  /* font-weight: 300; */
  margin-right: 38px;
}
.gnavi .gnavi_end .policy:hover {
  color: #00AE68;
}
@media screen and (max-width: 820px) {
  .gnavi .gnavi_end .policy {
    text-decoration: underline;
    margin-right: 0;
  }
}
.gnavi .gnavi_end .copyright {
  display: inline-block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.75em;
  font-weight: 600;
  color: rgba(0, 61, 37, 0.5);
}
@media screen and (max-width: 820px) {
  .gnavi .gnavi_end .copyright {
    font-size: 10px;
  }
}

.list_gnavi {
  width: 100%;
  max-width: 552px;
}
.list_gnavi > li {
  border-bottom: 1px solid rgba(0, 61, 37, 0.3);
  padding-top: 20px;
}
.list_gnavi > li:nth-last-child(2), .list_gnavi > li:nth-last-child(3) {
  padding: 20px 0 14px;
}
.list_gnavi > li:last-child {
  padding: 20px 0;
}
.list_gnavi .parent {
  display: block;
  line-height: 1;
  font-size: 1.25em;
  font-weight: 600;
  padding-top: 16px;
}
@media screen and (max-width: 820px) {
  .list_gnavi .parent {
    padding-top: 0;
    font-size: 1.125em;
  }
}
.list_gnavi .parent:before {
  content: attr(data-en);
  font-family: "Josefin Sans", sans-serif;
  font-size: 2.2em;
  vertical-align: middle;
  margin-right: 16px;
}
@media screen and (max-width: 820px) {
  .list_gnavi .parent:before {
    display: block;
    font-size: 2em;
  }
}
.list_gnavi .parent:hover {
  opacity: 0.6;
}
.list_gnavi span.parent {
  pointer-events: none;
}
.list_gnavi .recruit {
  font-size: 2.75em;
  font-weight: 600;
  line-height: 1.2;
  padding: 2px 0 10px;
}
@media screen and (max-width: 820px) {
  .list_gnavi .recruit {
    font-size: 2em;
    font-weight: 700;
  }
}
.list_gnavi .child {
  margin-top: 4px;
  padding-top: 6px;
  padding-bottom: 10px;
  border-top: 1px dashed rgba(0, 61, 37, 0.3);
}
@media screen and (max-width: 820px) {
  .list_gnavi .child {
    margin-top: 10px;
    padding: 0;
  }
}
.list_gnavi .child > li {
  font-size: 0.875em;
  margin-bottom: 0.125em;
}
@media screen and (max-width: 820px) {
  .list_gnavi .child > li {
    font-size: 1em;
    border-top: 1px dashed rgba(0, 61, 37, 0.3);
    margin-bottom: 0;
    padding: 10px 0;
  }
  .list_gnavi .child > li:first-child {
    border-top: none;
  }
}
.list_gnavi .child a {
  display: inline-block;
  /* font-weight: 300; */
  padding-left: 28px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .list_gnavi .child a {
    padding: 0;
  }
}
.list_gnavi .child a:after {
  position: absolute;
  top: 7px;
  left: 0;
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid #003D25;
  border-right: 0;
}
@media screen and (max-width: 820px) {
  .list_gnavi .child a:after {
    content: none;
  }
}
.list_gnavi .child a[data-en]:before {
  content: attr(data-en);
  display: inline-block;
  width: 96px;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.875em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .list_gnavi .child a[data-en]:before {
    content: none;
  }
}
.list_gnavi .child a:hover {
  opacity: 0.5;
}

.header {
  position: fixed;
  z-index: 9;
  top: 0;
  left: 0;
  width: 100%;
  padding: 16px 16px 0;
  transition: transform 0.3s;
}
.header.hide-top {
  transform: translateY(-100%);
}
@media screen and (max-width: 820px) {
  .header.js-active .header__logo {
    transform: translateX(var(--sideW));
  }
}
.header__inner {
  background-color: rgba(255, 255, 255, 0.85);
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px 12px 24px;
  transition: background-color 0.3s;
}
@media screen and (max-width: 820px) {
  .header__inner {
    padding: 0;
    background-color: transparent;
    align-items: flex-start;
  }
}
.header__right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.header__logo {
  width: 95px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 820px) {
  .header__logo {
    width: 70px;
    margin-top: 7px;
  }
}
.header.is-transparent .header__inner {
  background-color: transparent;
}

.footer {
  padding: 3.75em 0 2.5em;
  background-color: #F1F4F3;
}
@media screen and (max-width: 820px) {
  .footer {
    padding-top: 0;
  }
}
.footer .inner_l:before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: rgba(21, 103, 67, 0.5);
}
@media screen and (max-width: 820px) {
  .footer .inner_l:before {
    content: none;
  }
}
.footer .inner_l {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 820px) {
  .footer .inner_l {
    flex-direction: column;
  }
}
.footer__logo {
  width: 100%;
  margin: 5em 0 3.125em;
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 820px) {
  .footer__logo {
    order: 2;
    margin: 4em 0;
    justify-content: space-between;
    align-items: flex-end;
  }
}
.footer__logo .logo {
  display: block;
  width: 95px;
}
@media screen and (max-width: 820px) {
  .footer__logo .logo {
    width: 156px;
  }
  .footer__logo .logo img {
    max-width: unset;
    width: 100%;
  }
}
.footer__logo .btn_instagram {
  display: flex;
  align-items: center;
}
.footer__logo .btn_instagram:after {
  content: "";
  display: block;
  width: 15px;
  aspect-ratio: 1/1;
  background: url(../images/icon_arrow_right_up_01_maincolor.svg) no-repeat center/contain;
}
.footer__logo .btn_instagram img {
  display: block;
  width: 40px;
}

@media screen and (max-width: 820px) {
  .footer_address {
    order: 3;
  }
}
.footer_address ul li {
  margin-bottom: 1.5em;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .footer_address ul li {
    margin-bottom: 2em;
  }
}
.footer_address ul li:last-child {
  margin-bottom: 0;
}
.footer_address ul li .place {
  font-family: "Josefin Sans", sans-serif;
  font-weight: 600;
  margin-bottom: 6px;
}
.footer_address ul li address {
  font-size: 0.75em;
}
@media screen and (max-width: 820px) {
  .footer_address ul li address {
    font-size: 0.875em;
  }
}
.footer_address ul li .btn_googlemap {
  margin-top: 8px;
  display: block;
  max-width: 120px;
}
@media screen and (max-width: 820px) {
  .footer_address ul li .btn_googlemap {
    max-width: 160px;
  }
}
.footer_address ul li .btn_googlemap img {
  display: block;
}

.footer_menu {
  display: flex;
  gap: 42px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .footer_menu {
    order: 1;
    flex-direction: column;
    gap: 0;
  }
}
.footer_menu:after {
  content: "";
  display: block;
  width: 182px;
  aspect-ratio: 182/154;
  background: url(../images/company_logo02.png) no-repeat center/contain;
  position: absolute;
  bottom: -30px;
  right: 0;
}
@media screen and (max-width: 820px) {
  .footer_menu:after {
    content: none;
  }
}
.footer_menu > ul > li {
  margin-bottom: 56px;
}
@media screen and (max-width: 820px) {
  .footer_menu > ul > li {
    margin-bottom: 0;
    padding: 1em 0;
    border-top: 1px dashed rgba(0, 61, 37, 0.5);
  }
}
.footer_menu > ul > li:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .footer_menu > ul > li:last-child {
    border-bottom: 1px dashed rgba(0, 61, 37, 0.5);
  }
}
.footer_menu a:hover {
  opacity: 0.5;
}
.footer_menu .parent {
  font-weight: 600;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 8px;
}
.footer_menu .parent:before {
  content: attr(data-en);
  display: block;
  background-color: rgba(21, 103, 67, 0.5);
  color: #fff;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.8125em;
  padding: 4px 0 0;
  width: 96px;
  text-align: center;
  border-radius: 4px;
}
.footer_menu .parent_recruit {
  font-weight: 600;
  line-height: 1.5;
  display: flex;
  align-items: center;
  gap: 8px;
}
.footer_menu .parent_recruit:before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 12px solid rgba(0, 61, 37, 0.3);
  border-right: 0;
}
.footer_menu .child {
  padding-left: 34px;
  margin-top: 0.75em;
}
@media screen and (max-width: 820px) {
  .footer_menu .child {
    padding-left: 0;
  }
}
.footer_menu .child > li {
  font-size: 0.875em;
  margin-bottom: 0.25em;
}
.footer_menu .child a {
  display: inline-block;
  /* font-weight: 300; */
  padding-left: 14px;
  position: relative;
}
.footer_menu .child a:after {
  position: absolute;
  top: 7px;
  left: 0;
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid #003D25;
  border-right: 0;
}
.footer_menu .child a[data-en]:before {
  content: attr(data-en);
  display: inline-block;
  width: 90px;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.875em;
  font-weight: 600;
}

.footer_end {
  margin-top: 5em;
  width: 100%;
  text-align: center;
}
@media screen and (max-width: 820px) {
  .footer_end {
    order: 4;
    text-align: left;
    margin-top: 6.25em;
    position: relative;
  }
  .footer_end:after {
    content: "";
    display: block;
    width: 182px;
    aspect-ratio: 182/154;
    background: url(../images/company_logo02.png) no-repeat center/contain;
    position: absolute;
    bottom: 17px;
    right: -6.4vw;
  }
}
.footer_end .policy {
  font-size: 0.75em;
  /* font-weight: 300; */
  margin-right: 38px;
}
.footer_end .policy:hover {
  color: #00AE68;
}
.footer_end .copyright {
  display: inline-block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.75em;
  font-weight: 600;
  color: rgba(0, 61, 37, 0.5);
}

.footer_contact {
  margin-bottom: 0;
  padding: 5em 0;
  background-color: #F1F4F3;
}
.footer_contact h2 {
  margin-bottom: 36px;
}

.report_download {
  display: block;
  margin-bottom: 3.75em;
}
@media screen and (max-width: 820px) {
  .report_download {
    position: relative;
    margin-bottom: 2.5em;
  }
}
.report_download h3 {
  max-width: 380px;
  text-align: center;
  border-radius: 16px 16px 0 0;
  padding: 18px 10px 10px;
  background-color: #003D25;
  color: #fff;
  font-size: 1.5em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .report_download h3 {
    font-size: 1em;
    width: -moz-fit-content;
    width: fit-content;
    padding: 6px 12px 4px;
    border-radius: 8px 8px 0 0;
  }
}
.report_download .content {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2.66%;
  background-color: #DFEECD;
  border: 4px solid #003D25;
  border-radius: 0 16px 16px 16px;
  padding: 36px 2.985% 52px;
}
@media screen and (max-width: 820px) {
  .report_download .content {
    flex-direction: column;
    gap: 0;
    border: 2px solid #003D25;
    border-radius: 0 0px 16px 16px;
    padding: 40px 0 0;
  }
}
.report_download .content > .image {
  flex-shrink: 0;
  width: 39.52%;
  display: block;
  overflow: hidden;
  aspect-ratio: 445/320;
}
@media screen and (max-width: 820px) {
  .report_download .content > .image {
    order: 2;
    padding: 0 6.7%;
    width: 100%;
    aspect-ratio: 280/189;
  }
}
.report_download .content > .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.report_download dl {
  width: 56.78%;
}
@media screen and (max-width: 820px) {
  .report_download dl {
    display: contents;
  }
}
.report_download dl dt {
  font-size: 2em;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .report_download dl dt {
    order: 1;
    padding: 0 6.7%;
    font-size: 1.5em;
    font-weight: 700;
    margin-bottom: 16px;
  }
}
@media screen and (max-width: 820px) {
  .report_download dl dd {
    order: 3;
    padding: 0 6.7%;
  }
}
.report_download dl dd > p {
  margin-top: 1.5em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .report_download dl dd > p {
    margin-top: 1em;
    font-weight: 400;
  }
}
.report_download dl .flex_child {
  margin-top: 24px;
  display: flex;
  gap: 24px;
}
@media screen and (max-width: 820px) {
  .report_download dl .flex_child {
    order: 4;
    margin-top: 32px;
  }
}
.report_download dl .flex_child .image {
  flex-shrink: 0;
  width: 111px;
}
@media screen and (max-width: 820px) {
  .report_download dl .flex_child .image {
    position: absolute;
    top: -24px;
    right: 20px;
    width: 82px;
  }
}
.report_download dl .flex_child .text {
  padding-top: 12px;
  font-weight: 600;
  line-height: 1.5;
}
.report_download dl .flex_child .text p {
  margin-bottom: 0.3em;
}
@media screen and (max-width: 820px) {
  .report_download dl .flex_child .text p {
    border-top: 1px solid #003D25;
    border-bottom: 1px solid #003D25;
    line-height: 1.5;
    padding: 0.5em 0;
    font-weight: 700;
    margin-bottom: 0.5em;
  }
}
.report_download dl .flex_child .text ul li {
  margin-bottom: 0.3em;
}
@media screen and (max-width: 820px) {
  .report_download dl .flex_child .text ul li {
    font-weight: 700;
  }
}
.report_download dl .flex_child .text ul li:last-child {
  margin-bottom: 0;
}
.report_download .btn_cmn_03 {
  margin: 0 auto;
}
.report_download .btn_cmn_03--wrap {
  width: 100%;
  margin: 28px 0 0;
}
@media screen and (max-width: 820px) {
  .report_download .btn_cmn_03--wrap {
    order: 5;
    margin: 2.5em 0 0;
  }
}
.report_download:hover .content > .image img {
  transform: scale(1.05);
}
.report_download:hover .btn_cmn_03 {
  background-color: #00AE68;
}
.report_download:hover .btn_cmn_03:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/0.8em;
}

.contact {
  padding-left: 73px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .contact {
    padding-left: 0;
  }
}
.contact .label {
  width: 160px;
  aspect-ratio: 1/1;
  background-color: #fff;
  background-clip: content-box;
  border-radius: 50%;
  display: grid;
  place-content: center;
  text-align: center;
  color: #156743;
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
  position: absolute;
  top: 0;
  left: 0;
}
.contact .label:before {
  content: "";
  position: absolute;
  top: -4px;
  left: -4px;
  width: calc(100% + 8px);
  height: calc(100% + 8px);
  border-radius: 50%;
  padding: 4px; /* 線の太さ */
  background: repeating-conic-gradient(#1f6b43 0deg 4deg, transparent 4deg 8deg);
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #000 0);
  mask: radial-gradient(farthest-side, transparent calc(100% - 4px), #000 0);
}
.contact .label_sp {
  order: 1;
  padding: 0 var(--sideW);
  font-size: 1.125em;
  font-weight: 700;
  height: 64px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 24px;
  position: relative;
}
.contact .label_sp:before {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 1/1;
  background: url(../images/footer_contact_label_bg.jpg) no-repeat center/contain;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.contact .label_sp span {
  display: block;
  background-color: #fff;
  position: relative;
  padding: 0.2em 0;
}
.contact .content {
  margin-left: 73px;
  background-color: #fff;
  border-radius: 16px;
  padding: 66px 3.33% 56px 11.02%;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2.65%;
}
@media screen and (max-width: 820px) {
  .contact .content {
    margin-left: 0;
    flex-direction: column;
    align-items: unset;
    padding: 24px 0 0;
  }
}
.contact .content .text {
  width: 50.41%;
}
@media screen and (max-width: 820px) {
  .contact .content .text {
    display: contents;
  }
}
.contact .content .text h3 {
  font-size: 1.5em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .contact .content .text h3 {
    order: 2;
    padding: 0 var(--sideW);
    margin-bottom: 24px;
  }
}
.contact .content .text p {
  margin-top: 10px;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .contact .content .text p {
    order: 4;
    padding: 0 var(--sideW);
    margin-top: 20px;
    font-weight: 400;
  }
}
.contact .content .images {
  flex-shrink: 0;
  width: 46.94%;
  margin-top: 6px;
  display: flex;
}
@media screen and (max-width: 820px) {
  .contact .content .images {
    order: 2;
    width: 100%;
    padding: 0 var(--sideW);
  }
}
.contact .content .images .image {
  width: 100%;
  display: block;
  overflow: hidden;
  aspect-ratio: 149/156;
}
.contact .content .images .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.contact .btn_cmn_03 {
  margin: 0 auto;
}
.contact .btn_cmn_03--wrap {
  width: calc(100% + 73px + 11.02%);
  margin: 54px 0 0 calc(-73px - 11.02%);
}
@media screen and (max-width: 820px) {
  .contact .btn_cmn_03--wrap {
    order: 5;
    width: 100%;
    margin: 2.5em 0 0;
  }
}
.contact:hover .btn_cmn_03 {
  background-color: #00AE68;
}
.contact:hover .btn_cmn_03:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/0.8em;
}

.top_hero {
  height: 100vh;
  margin-bottom: 5em;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 820px) {
  .top_hero {
    display: block;
    margin-bottom: 0;
  }
}
.top_hero .lottie {
  position: absolute;
  top: -9.11%;
  right: -11.71%;
  width: 79%;
  aspect-ratio: 1/1;
}
@media screen and (max-width: 820px) {
  .top_hero .lottie {
    transform: translateX(50%) translateY(37.5%) rotate(90deg);
    width: 189.6%;
    right: 50%;
  }
}
.top_hero .inner {
  max-width: calc(1000px + var(--sideW) * 2);
  position: relative;
  padding-top: var(--headerHeight);
}
@media screen and (max-width: 820px) {
  .top_hero .inner {
    padding-top: 7.5em;
  }
}
.top_hero .large {
  color: #156743;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 3.125em;
  line-height: 1.5;
  font-feature-settings: "palt";
  margin-bottom: 90px;
}
.top_hero .large span {
  margin-left: 0.5em;
}
.top_hero .large span:nth-child(3) {
  margin-left: 2em;
}
@media screen and (max-width: 820px) {
  .top_hero .large {
    font-size: 10.4vw;
    margin-right: var(--extend);
    margin-bottom: 48px;
  }
}
.top_hero .medium {
  width: -moz-fit-content;
  width: fit-content;
  color: #156743;
  font-size: 1.25em;
  font-weight: 600;
  letter-spacing: 0.3em;
  line-height: 1.5;
  border-bottom: 1px solid #156743;
  padding-bottom: 0.5em;
  margin-bottom: 20px;
}
@media screen and (max-width: 820px) {
  .top_hero .medium {
    padding-bottom: 0.5em;
    margin-bottom: 0.25em;
    width: 100%;
    text-align: center;
    font-size: 1em;
    letter-spacing: 0em;
  }
}
.top_hero .small {
  color: #156743;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .top_hero .small {
    text-align: center;
    font-size: 0.75em;
  }
}

.top_about {
  background: linear-gradient(0deg, rgba(241, 244, 243, 0) 0%, rgb(241, 244, 243) 100%);
  padding: 8em 0 3.75em;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .top_about {
    padding: 5em 0 0;
    margin-bottom: 0;
  }
}
.top_about--layout {
  display: flex;
  gap: 2.98%;
}
@media screen and (max-width: 820px) {
  .top_about--layout {
    display: block;
  }
}
.top_about .box_left {
  flex-shrink: 0;
  width: 43.29%;
}
@media screen and (max-width: 820px) {
  .top_about .box_left {
    width: auto;
    margin-bottom: 4em;
  }
}
.top_about--ttl {
  margin-bottom: 70px;
}
@media screen and (max-width: 820px) {
  .top_about--ttl {
    margin-bottom: 27px;
  }
}
.top_about--lead {
  margin-bottom: 100px;
}
@media screen and (max-width: 820px) {
  .top_about--lead {
    margin-right: -1em;
    margin-bottom: 3em;
  }
}
.top_about .box_right {
  flex-grow: 1;
  background-color: #fff;
  padding: 30px 18px 32px 30px;
  border-radius: 24px;
}
@media screen and (max-width: 820px) {
  .top_about .box_right {
    margin: 0 -4.6vw;
    padding: 17px 4.7%;
  }
}
.top_about .box_right ul {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 6%;
}
@media screen and (max-width: 820px) {
  .top_about .box_right ul {
    gap: 19px 16px;
  }
}
.top_about .box_right ul li {
  width: 29.3333333333%;
  position: relative;
}
.top_about .box_right ul li:after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: rgba(0, 61, 37, 0.3);
  position: absolute;
  top: 0;
  left: 110%;
}
@media screen and (max-width: 820px) {
  .top_about .box_right ul li:after {
    left: calc(100% + 8px);
  }
}
.top_about .box_right ul li:nth-child(3n):after {
  content: none;
}

.top_strengths {
  background: url(../images/top_strengths_01.jpg) no-repeat top center/cover;
  padding: 6em 0 9.5em;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .top_strengths {
    padding: 5em 0 7em;
    background: url(../images/top_strengths_01_sp.jpg) no-repeat top center/cover;
  }
}
.top_strengths--ttl {
  margin-bottom: 28px;
}
@media screen and (max-width: 820px) {
  .top_strengths--ttl {
    margin-bottom: 16px;
  }
}
.top_strengths--lead {
  margin-bottom: 54px;
  text-align: center;
  font-size: 1.125em;
  font-weight: 600;
  line-height: 1.77;
}
@media screen and (max-width: 820px) {
  .top_strengths--lead {
    font-size: 1em;
    margin-bottom: 2em;
  }
}
.top_strengths ul {
  display: flex;
  gap: 2.07%;
}
@media screen and (max-width: 820px) {
  .top_strengths ul {
    flex-direction: column;
    gap: 1em;
  }
}
.top_strengths ul li {
  width: 100%;
}
.top_strengths--card:nth-child(1) a {
  padding-top: 5%;
}
.top_strengths--card:nth-child(1) h3 {
  margin-bottom: 0.5em;
}
.top_strengths--card:nth-child(1) span {
  margin-top: 1.42em;
}
.top_strengths--card:nth-child(2) a {
  padding-top: 5%;
}
.top_strengths--card:nth-child(2) h3 {
  margin-bottom: 0.928em;
}
@media screen and (max-width: 820px) {
  .top_strengths--card:nth-child(2) h3 {
    margin-bottom: 0.5em;
  }
}
.top_strengths--card:nth-child(2) span {
  margin-top: 1.42em;
}
.top_strengths--card:nth-child(3) a {
  padding-top: 2%;
}
.top_strengths--card:nth-child(3) span {
  margin-top: 0.85em;
}
@media screen and (max-width: 820px) {
  .top_strengths--card:nth-child(3) span {
    margin-top: 0.5em;
  }
}
.top_strengths--card:nth-child(3) p {
  margin-top: 0.25em;
}
@media screen and (max-width: 820px) {
  .top_strengths--card:nth-child(3) p {
    letter-spacing: 0;
  }
}
.top_strengths--card a {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  aspect-ratio: 1/1;
  border-radius: 50%;
  padding-left: 7.85%;
  padding-right: 7.85%;
  border: 1px solid #003D25;
  background-color: rgba(255, 255, 255, 0.7);
  position: relative;
}
.top_strengths--card a:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px dashed #003D25;
  position: absolute;
  top: 0;
  left: 4px;
}
.top_strengths--card a h3 {
  text-align: center;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: clamp(10px, 2.04vw, 28px);
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .top_strengths--card a h3 {
    font-size: 1.5em;
  }
}
.top_strengths--card a p {
  text-align: center;
  /* font-weight: 300; */
  font-size: clamp(10px, 1.17vw, 16px);
}
@media screen and (max-width: 820px) {
  .top_strengths--card a p {
    font-size: 0.875em;
    line-height: 1.5;
  }
}
.top_strengths--card a span {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 8.5em;
  height: 2.857em;
  border: 2px solid #00AE68;
  border-radius: 50px;
  background-color: #fff;
  color: #00AE68;
  font-size: clamp(10px, 1.02vw, 14px);
  font-weight: 600;
  letter-spacing: 0.02em;
  padding-bottom: 2px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .top_strengths--card a span {
    font-size: 0.875em;
    max-width: 120px;
    letter-spacing: 0.2em;
  }
}
.top_strengths--card a span:after {
  content: "";
  display: block;
  width: 1.714em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #00AE68 url(../images/ico_arrow_right_01_white.svg) no-repeat center/1em;
  position: absolute;
  right: 0.428em;
  top: 50%;
  transform: translateY(-50%);
}
.top_strengths--card a:hover {
  background-color: rgba(0, 174, 104, 0.05);
}
.top_strengths--card a:hover span {
  background-color: #00AE68;
  color: #fff;
}
.top_strengths--card a:hover span:after {
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/14px;
}

.top_service {
  padding-top: 6em;
}
@media screen and (max-width: 820px) {
  .top_service {
    margin-top: -2em;
    background-color: #156743;
    padding: 5em 0;
    border-radius: 40px 40px 0 0;
    color: #fff;
  }
}
.top_service h2 {
  margin-bottom: 28px;
}
.top_service--lead {
  margin-bottom: 50px;
  text-align: center;
  font-size: 1.125em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .top_service--lead {
    font-size: 1em;
    margin-bottom: 40px;
  }
}
.top_service ul {
  display: flex;
  gap: 0 2.19%;
}
@media screen and (max-width: 820px) {
  .top_service ul {
    flex-direction: column;
    gap: 0;
  }
}
.top_service ul li {
  width: 100%;
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
.top_service ul li:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.5);
}
.top_service ul li a {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: white;
  position: relative;
}
@media screen and (max-width: 820px) {
  .top_service ul li a {
    padding: 28px 0 24px;
  }
}
.top_service ul li a:after {
  content: "";
  display: block;
  width: 2em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_right_01_subcolor.svg) no-repeat center/1.0625em;
  position: absolute;
  bottom: 0.75em;
  right: 1em;
  transition: 0.3s;
}
@media screen and (max-width: 820px) {
  .top_service ul li a:after {
    bottom: unset;
    top: 28px;
    right: 0;
  }
}
.top_service ul li a h3 {
  display: flex;
  align-items: center;
  height: 5.75em;
  border-radius: 8px 8px 0 0;
  background: #156743 url(../images/top_service_01.svg) no-repeat top center/cover;
  font-size: clamp(10px, 1.756vw, 24px);
  font-weight: 600;
  line-height: 1.5;
  padding: 0 7.16%;
}
@media screen and (max-width: 820px) {
  .top_service ul li a h3 {
    height: unset;
    border-radius: 0;
    background: transparent;
    font-size: 1.25em;
    padding: 0;
    margin-bottom: 20px;
  }
}
.top_service ul li a p {
  flex-grow: 1;
  border-radius: 0 0 8px 8px;
  background-color: #156743;
  position: relative;
  overflow: hidden;
  padding: calc(1.5em + 4px) 7.16% 40px;
  font-size: clamp(10px, 1.171vw, 16px);
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .top_service ul li a p {
    border-radius: 0;
    padding: 0;
    font-size: 0.875em;
  }
}
.top_service ul li a p:before {
  content: "";
  display: block;
  width: 100%;
  height: 4px;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: 1px;
  content: none;
}
.top_service ul li a:hover {
  color: rgba(255, 255, 255, 0.7);
}
.top_service ul li a:hover:after {
  background: #00AE68 url(../images/ico_arrow_right_01_white.svg) no-repeat center/1.0625em;
}

.top_works {
  padding-bottom: 11.25em;
}
@media screen and (max-width: 820px) {
  .top_works {
    padding-bottom: 0;
    margin-bottom: 7.5em;
  }
}
.top_works h2 {
  margin-bottom: 36px;
}
.top_works ul {
  display: flex;
  gap: 2.487%;
}
@media screen and (max-width: 820px) {
  .top_works ul {
    flex-direction: column;
    gap: 52px;
  }
}
.top_works ul > li {
  width: 100%;
}
.top_works ul > li a {
  display: block;
}
.top_works ul > li a .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 382/424;
  margin-bottom: 0.875em;
}
.top_works ul > li a .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.top_works ul > li a h3 {
  font-size: 0.875em;
  font-weight: 600;
  margin-bottom: 0.25em;
}
.top_works ul > li a p {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.125em;
  font-weight: 600;
  line-height: 1.5;
  opacity: 0.5;
}
.top_works ul > li a:hover img {
  transform: scale(1.05);
}
.top_works ul > li a:hover p {
  opacity: 1;
}

@media screen and (max-width: 820px) {
  .top_case {
    margin-bottom: 7.5em;
  }
}
.top_case h2 {
  margin-bottom: 36px;
}
.top_case ul {
  display: flex;
  gap: 2.5em 2.4%;
}
@media screen and (max-width: 820px) {
  .top_case ul {
    flex-direction: column;
  }
}
.top_case ul li {
  width: 31.7333333333%;
}
@media screen and (max-width: 820px) {
  .top_case ul li {
    width: 100%;
  }
}
.top_case--card {
  display: block;
}
.top_case--card .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 382/246;
  border-radius: 4px;
  margin-bottom: 1em;
}
.top_case--card .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.top_case--card h3,
.top_case--card .ttl {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.125em;
  font-weight: 600;
}
.top_case--card p {
  margin-top: 0.5em;
  color: rgba(0, 61, 37, 0.5);
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .top_case--card p {
    font-size: 0.875em;
    font-weight: 400;
    line-height: 1.5;
  }
}
.top_case--card .date {
  margin-top: 1em;
  font-size: 0.75em;
  /* font-weight: 300; */
  opacity: 0.5;
}
.top_case--card:hover img {
  transform: scale(1.05);
}
.top_case--card:hover h3 {
  text-decoration: underline;
}
.top_case--card:hover p {
  color: #003d25;
}
.top_case--link {
  margin: 5em 0 0 auto;
}
@media screen and (max-width: 820px) {
  .top_case--link {
    margin: 3.75em 0 0 0;
  }
}

.top_column h2 {
  margin-bottom: 36px;
}
.top_column ul {
  display: flex;
  gap: 2.5em 2.487%;
}
@media screen and (max-width: 820px) {
  .top_column ul {
    flex-direction: column;
  }
}
.top_column ul > li {
  width: 23.13475%;
}
@media screen and (max-width: 820px) {
  .top_column ul > li {
    width: 100%;
  }
}
.top_column--card .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 280/180;
  border-radius: 4px;
  margin-bottom: 1em;
}
.top_column--card .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.top_column--card h3,
.top_column--card .ttl {
  font-weight: 600;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 820px) {
  .top_column--card h3,
  .top_column--card .ttl {
    margin-bottom: 0.5em;
  }
}
.top_column--card .cat {
  display: inline-block;
  border: 1px solid rgba(0, 61, 37, 0.3);
  padding: 0 0.66em;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 2;
  margin-right: 6px;
}
.top_column--card .date {
  font-size: 0.75em;
  /* font-weight: 300; */
  line-height: 2;
}
.top_column--card p {
  margin-top: 0.625em;
  color: rgba(0, 61, 37, 0.5);
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .top_column--card p {
    font-size: 0.875em;
    font-weight: 400;
    line-height: 1.5;
  }
}
.top_column--card:hover img {
  transform: scale(1.05);
}
.top_column--card:hover h3 {
  text-decoration: underline;
}
.top_column--card:hover p {
  color: #003d25;
}
.top_column--link {
  margin: 5em 0 0 auto;
}

.top_information {
  margin-bottom: 0;
  padding: 5em 0 7.5em;
  background: linear-gradient(0deg, rgba(241, 244, 243, 0) 0%, rgb(241, 244, 243) 100%);
}
@media screen and (max-width: 820px) {
  .top_information {
    padding: 5em 0;
  }
}
.top_information h2 {
  margin-bottom: 36px;
}
@media screen and (max-width: 820px) {
  .top_information h2 {
    margin-bottom: 42px;
  }
  .top_information h2 span {
    display: block;
    font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    font-weight: 700;
  }
}
.top_information dl {
  border: 1px solid #156743;
  border-radius: 8px;
  background-color: #fff;
  padding: 30px 7.62% 30px 3.98%;
  display: flex;
  align-items: center;
  gap: 3.98%;
}
@media screen and (max-width: 820px) {
  .top_information dl {
    padding: 24px 29px;
  }
}
.top_information dl dt {
  flex-shrink: 0;
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
}
.top_information dl dd {
  flex-grow: 1;
  padding-left: 3.98%;
  border-left: 1px solid #156743;
}
@media screen and (max-width: 820px) {
  .top_information dl dd {
    border-left: none;
    padding-left: 0;
  }
}

.list_information > li {
  margin-bottom: 30px;
}
.list_information > li:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .list_information > li {
    border-bottom: 1px dashed rgba(0, 61, 37, 0.5);
    margin-bottom: 24px;
    padding-bottom: 24px;
  }
  .list_information > li:last-child {
    border: none;
  }
}

.card_information_01 {
  display: flex;
  align-items: center;
  gap: 32px;
}
@media screen and (max-width: 820px) {
  .card_information_01 {
    display: block;
  }
}
.card_information_01 .date {
  flex-shrink: 0;
  border-right: 1px dashed rgba(0, 61, 37, 0.5);
  width: 117px;
  font-family: "Josefin Sans", sans-serif;
  font-size: 1.75em;
  font-weight: 600;
  line-height: 1.2;
  padding: 12px 0 4px;
}
@media screen and (max-width: 820px) {
  .card_information_01 .date {
    border: none;
    width: 100%;
    font-size: 1.375em;
  }
}
.card_information_01 .date .year {
  display: block;
  font-size: 0.5em;
}
@media screen and (max-width: 820px) {
  .card_information_01 .date .year {
    font-size: 0.636em;
  }
}
.card_information_01 p {
  /* font-weight: 300; */
}
.card_information_01:hover p {
  text-decoration: underline;
}

.page-about {
  background-color: #156743;
}
.page-about .section_wrap {
  padding-bottom: 0;
}

.about_cmn_grid {
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 820px) {
  .about_cmn_grid {
    flex-direction: column;
    gap: 40px;
  }
}
.about_cmn_grid .box_left {
  flex-shrink: 0;
  width: 100%;
  max-width: 412px;
  position: sticky;
  top: 134px;
}
@media screen and (max-width: 820px) {
  .about_cmn_grid .box_left {
    position: static;
  }
}
.about_cmn_grid .box_right {
  flex-grow: 1;
}

.about_hero {
  color: #fff;
}
.about_hero .inner {
  display: flex;
  align-items: flex-start;
  padding-bottom: 36px;
}
@media screen and (max-width: 820px) {
  .about_hero .inner {
    flex-direction: column;
    padding-bottom: 0px;
  }
}
.about_hero .box_text {
  flex-shrink: 0;
  width: 51.24%;
  padding: 230px var(--sideW) 5em 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}
@media screen and (max-width: 820px) {
  .about_hero .box_text {
    width: 100%;
    padding: 6.25em 0 2.5em;
    border-bottom: none;
  }
}
.about_hero .box_text .ttl {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.33;
  margin-bottom: 1.8em;
}
@media screen and (max-width: 820px) {
  .about_hero .box_text .ttl {
    font-size: 1.875em;
    margin-right: calc(var(--sideW) * -1);
    margin-bottom: 1.2em;
  }
}
.about_hero .box_text .para {
  max-width: 515px;
  font-size: 1.125em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .about_hero .box_text .para {
    font-size: 1em;
  }
}
.about_hero .box_text .para p {
  margin-bottom: 1.8em;
}
.about_hero .box_text .para p:last-child {
  margin-bottom: 0;
}
.about_hero .box_image {
  position: sticky;
  top: 0;
  flex-grow: 1;
  margin: 0 var(--extend) 0 0;
  display: block;
  overflow: hidden;
  height: 100vh;
}
@media screen and (max-width: 820px) {
  .about_hero .box_image {
    width: auto;
    position: static;
    aspect-ratio: 3/2;
    height: auto;
  }
}
.about_hero .box_image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.anchor_nav {
  position: sticky;
  z-index: 2;
  top: 104px;
  display: flex;
  align-items: baseline;
  gap: 16px;
  padding: 0 calc(var(--sideW) * 0.5);
}
.anchor_nav .head {
  font-size: 0.75em;
  /* font-weight: 300; */
}
.anchor_nav ul {
  display: flex;
  align-items: baseline;
  gap: 16px;
}
.anchor_nav ul li a {
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.75em;
  color: rgba(255, 255, 255, 0.5);
}

.about_sec_01 {
  padding: 6.25em 0 10em;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .about_sec_01 {
    padding: 6.25em 0 5em;
  }
}
.about_sec_01 .ttl_cmn_04 {
  margin-bottom: 80px;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .ttl_cmn_04 {
    margin-bottom: 3.75em;
  }
}
.about_sec_01--lead01 {
  padding-left: calc(72px - 0.5em);
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 20px;
}
@media screen and (max-width: 820px) {
  .about_sec_01--lead01 {
    padding-left: 0;
    font-size: 2em;
  }
}
.about_sec_01--lead02 {
  padding-left: 72px;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 80px;
}
@media screen and (max-width: 820px) {
  .about_sec_01--lead02 {
    padding-left: 0;
    font-size: 1.2em;
    margin-bottom: 50px;
  }
}
.about_sec_01 .box_flex {
  color: #fff;
  padding-left: 72px;
  display: flex;
  align-items: flex-start;
  gap: 1.875em 8.9%;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex {
    flex-direction: column;
    padding-left: 0;
  }
}
.about_sec_01 .box_flex .box_left {
  position: sticky;
  top: 104px;
  flex-shrink: 0;
  width: 27.16%;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_left {
    width: 100%;
    position: static;
  }
}
.about_sec_01 .box_flex .box_left .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 308/338px;
  border-radius: 4px;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_left .image {
    width: 80%;
  }
}
.about_sec_01 .box_flex .box_left .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.about_sec_01 .box_flex .box_left .name {
  margin-top: 1em;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
}
.about_sec_01 .box_flex .box_left .name .position {
  font-size: 0.66em;
}
.about_sec_01 .box_flex .box_left .dlist_index {
  margin-top: 2em;
}
.about_sec_01 .box_flex .box_left .dlist_index dt {
  font-size: 0.875em;
  font-weight: 600;
  margin-bottom: 0.75em;
}
.about_sec_01 .box_flex .box_left .dlist_index ul li {
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}
.about_sec_01 .box_flex .box_left .dlist_index ul li:first-child {
  border-top: 1px solid rgba(255, 255, 255, 0.5);
}
.about_sec_01 .box_flex .box_left .dlist_index ul li a {
  display: flex;
  font-size: 0.875em;
  /* font-weight: 300; */
  padding: 1em 0 1em 20px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_left .dlist_index ul li a {
    padding-left: 0;
  }
}
.about_sec_01 .box_flex .box_left .dlist_index ul li a:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 11px solid #156743;
  border-right: 0;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_left .dlist_index ul li a:before {
    content: none;
  }
}
@media (hover: hover) {
  .about_sec_01 .box_flex .box_left .dlist_index ul li a:hover {
    background-color: rgba(241, 244, 243, 0.7);
    color: #156743;
  }
}
.about_sec_01 .box_flex .box_right h3 {
  font-size: 1.5em;
  font-weight: 600;
  margin: 2.5em 0 2em;
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_right h3 {
    font-size: 1.25em;
    margin-bottom: 1.5em;
  }
}
.about_sec_01 .box_flex .box_right .para {
  font-size: 1.125em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .about_sec_01 .box_flex .box_right .para {
    font-size: 0.9375em;
  }
}
.about_sec_01 .box_flex .box_right .para p {
  margin-bottom: 1.75em;
}
.about_sec_01 .box_flex .box_right .para p:last-child {
  margin-bottom: 0;
}

.about_sec_02 {
  background-color: #fff;
  padding: 10em 0;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .about_sec_02 {
    padding: 5em 0;
  }
}

.list_philosophy > li {
  padding: 72px 0;
  border-bottom: 1px solid rgba(0, 61, 37, 0.3);
}
@media screen and (max-width: 820px) {
  .list_philosophy > li {
    padding: 50px 0;
  }
}
.list_philosophy > li:first-child {
  padding-top: 0;
}
.list_philosophy > li:first-child .text {
  margin-top: 30px;
  font-size: 1.125em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .list_philosophy > li:first-child .text {
    font-size: 1em;
  }
}
.list_philosophy > li:nth-child(2) ul {
  margin-top: 20px;
  display: flex;
  gap: 3%;
}
@media screen and (max-width: 820px) {
  .list_philosophy > li:nth-child(2) ul {
    flex-direction: column;
    gap: 2.5em;
  }
}
.list_philosophy > li:nth-child(2) ul li {
  width: 100%;
}
.list_philosophy > li:nth-child(2) ul li h4 {
  height: 4.5em;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: min(3vw, 2.125em);
  font-weight: 500;
  margin-bottom: 16px;
}
@media screen and (max-width: 820px) {
  .list_philosophy > li:nth-child(2) ul li h4 {
    height: auto;
    font-size: 2em;
  }
}
.list_philosophy > li:nth-child(2) ul li p {
  /* font-weight: 300; */
}
.list_philosophy > li:nth-child(3) ul {
  margin-top: 40px;
  display: flex;
  gap: 3%;
}
@media screen and (max-width: 820px) {
  .list_philosophy > li:nth-child(3) ul {
    flex-direction: column;
    gap: 20px;
  }
}
.list_philosophy > li:nth-child(3) ul li {
  width: 100%;
}
.list_philosophy h3 {
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.5;
  border: 1px solid #003D25;
  width: -moz-fit-content;
  width: fit-content;
  padding: 5px 18px;
}
.list_philosophy .large {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.32;
  margin-top: 12px;
  margin-bottom: 32px;
}
@media screen and (max-width: 820px) {
  .list_philosophy .large {
    font-size: 2em;
    margin-top: 20px;
    margin-bottom: 20px;
  }
}
.list_philosophy .images {
  display: flex;
  gap: 3%;
}
.list_philosophy .images .image {
  width: 100%;
}

.about_sec_03 {
  background-color: #fff;
  padding: 0 0 10em;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .about_sec_03 {
    padding: 0 0 6.25em;
  }
}
.about_sec_03 .box_right {
  max-width: 714px;
}
.about_sec_03--table {
  width: 100%;
}
@media screen and (max-width: 820px) {
  .about_sec_03--table {
    font-size: 0.9375em;
  }
}
.about_sec_03--table tr th {
  border-right: 1px solid rgba(0, 61, 37, 0.15);
  border-bottom: 1px solid rgba(0, 61, 37, 0.15);
  padding: 0.25em 14px;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .about_sec_03--table tr th {
    display: block;
    border-right: none;
    border-bottom: none;
    padding: 1em 0 0;
    margin-bottom: 0.25em;
  }
}
.about_sec_03--table tr td {
  border-bottom: 1px solid rgba(0, 61, 37, 0.15);
  padding: 0.25em 14px;
}
@media screen and (max-width: 820px) {
  .about_sec_03--table tr td {
    display: block;
    padding: 0 0 1em;
  }
}
.about_sec_03--table tr:nth-child(1) th, .about_sec_03--table tr:nth-child(1) td {
  border-top: 1px solid rgba(0, 61, 37, 0.15);
}
@media screen and (max-width: 820px) {
  .about_sec_03--table tr:nth-child(1) td {
    border-top: none;
  }
}
@media screen and (max-width: 820px) {
  .about_sec_03--table ul {
    margin-top: 0.75em;
  }
}
.about_sec_03--table ul li {
  margin-bottom: 2em;
}
.about_sec_03--table ul li p {
  font-weight: 600;
}
.about_sec_03--table ul li a {
  display: block;
  border-radius: 50px;
  overflow: hidden;
  width: 100%;
  max-width: 160px;
  margin-top: 14px;
}
@media screen and (max-width: 820px) {
  .about_sec_03--table ul li a {
    max-width: 140px;
    margin-top: 12px;
  }
}
.about_sec_03 .dlist_network {
  margin-top: 7.5em;
}
@media screen and (max-width: 820px) {
  .about_sec_03 .dlist_network {
    margin-top: 5em;
  }
}
.about_sec_03 .dlist_network dt {
  line-height: 1.5;
  margin-bottom: 20px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 820px) {
  .about_sec_03 .dlist_network dt {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
}
.about_sec_03 .dlist_network dt:after {
  content: "";
  display: block;
  width: 130px;
  aspect-ratio: 130/38;
  background: url(../images/logo_maces.png) no-repeat center/contain;
}
@media screen and (max-width: 820px) {
  .about_sec_03 .dlist_network dt:after {
    width: 115px;
  }
}
.about_sec_03 .dlist_network dt span {
  font-size: 1.5em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .about_sec_03 .dlist_network dt span {
    font-size: 1.25em;
  }
}
.about_sec_03 .dlist_network dt span:before {
  content: attr(data-en);
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.667em;
}
.about_sec_03 .dlist_network dd {
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .about_sec_03 .dlist_network dd {
    font-size: 0.9375em;
  }
}
.about_sec_03 .dlist_network dd p {
  margin-bottom: 20px;
}
.about_sec_03 .dlist_network dd a {
  font-weight: 600;
  text-decoration: underline;
}

.strengths_hero {
  padding: 10em 0;
}
@media screen and (max-width: 820px) {
  .strengths_hero {
    padding: 6.25em 0 5em;
  }
}
.strengths_hero .inner_l {
  display: flex;
  align-items: flex-start;
}
@media screen and (max-width: 820px) {
  .strengths_hero .inner_l {
    flex-direction: column;
    gap: 26px;
  }
}
.strengths_hero .box_text {
  flex-grow: 1;
  margin-right: -50vw;
  position: relative;
}
@media screen and (max-width: 820px) {
  .strengths_hero .box_text {
    margin-right: 0;
  }
}
.strengths_hero .box_text p {
  margin-top: 1.8em;
}
.strengths_hero .box_image {
  flex-shrink: 0;
  width: 65.83%;
  border-radius: 8px;
  overflow: hidden;
}
@media screen and (max-width: 820px) {
  .strengths_hero .box_image {
    width: auto;
  }
}
.strengths_hero h1 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.32;
  margin-bottom: 36px;
}
@media screen and (max-width: 820px) {
  .strengths_hero h1 {
    font-size: 1.875em;
    margin-bottom: 26px;
  }
}

.strengths_grid {
  display: flex;
  align-items: flex-start;
  gap: 11%;
}
@media screen and (max-width: 820px) {
  .strengths_grid {
    flex-direction: column-reverse;
  }
}
.strengths_grid .box_left {
  flex-shrink: 0;
  width: 280px;
  position: sticky;
  top: 104px;
}
@media screen and (max-width: 820px) {
  .strengths_grid .box_left {
    display: contents;
  }
  .strengths_grid .box_left .banner_download {
    width: 176px;
    position: fixed;
    z-index: 5;
    bottom: 20px;
    left: 20px;
  }
}
.strengths_grid .box_right {
  flex-grow: 1;
  overflow: hidden;
}

.banner_download {
  display: block;
  border-radius: 16px;
  overflow: hidden;
}
.banner_download:before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 280/136;
  background: url(../images/banner_download_01.jpg?ver=1.0) no-repeat center/cover;
}
.banner_download span {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  background-color: #156743;
  color: #fff;
  font-weight: 600;
  padding: 1em 0;
}
@media screen and (max-width: 820px) {
  .banner_download span {
    font-size: 0.75em;
  }
}
.banner_download span:after {
  content: "";
  display: block;
  width: 2em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff url(../images/ico_arrow_right_01_maincolor.svg) no-repeat center/1em;
}
.banner_download:hover span {
  background-color: #003D25;
}
.banner_download:hover span:after {
  background: #fff url(../images/ico_arrow_right_01_textcolor.svg) no-repeat center/1em;
}

.ttl_strengths_01 {
  margin-bottom: 50px;
  font-size: 2em;
  font-weight: 600;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_01 {
    font-size: 1.6em;
  }
}
.ttl_strengths_01 .label--wrap {
  width: 100%;
}
.ttl_strengths_01 .label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 150px;
  aspect-ratio: 301/91;
  background: url(../images/ttl_strengths_01_label.png) no-repeat center/contain;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_01 .label {
    width: 120px;
  }
}
.ttl_strengths_01 .label .text {
  display: block;
  transform: rotate(-4deg);
  font-size: 23px;
  color: #fff;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_01 .label .text {
    font-size: 18px;
  }
}
.ttl_strengths_01 .strong {
  color: #00AE68;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.65em;
  font-weight: 500;
  line-height: 1.2;
  margin-right: 6px;
  position: relative;
}
.ttl_strengths_01 .strong:before {
  content: "";
  display: block;
  width: 153px;
  aspect-ratio: 153/32;
  background: url(../images/ttl_strengths_01_strong.png) no-repeat center/contain;
  position: absolute;
  bottom: -12px;
  left: 0;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_01 .strong:before {
    width: 123px;
  }
}
.ttl_strengths_01 .strong .text {
  position: relative;
}

.list_strengths_01 > li {
  border-bottom: 1px solid rgba(0, 61, 37, 0.5);
  padding: 2.5em 0;
  display: flex;
  align-items: flex-end;
  gap: 20px 5%;
}
@media screen and (max-width: 820px) {
  .list_strengths_01 > li {
    flex-direction: column;
    align-items: flex-start;
  }
}
.list_strengths_01 > li .box_text {
  flex-grow: 1;
}
.list_strengths_01 > li .box_text h3 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  margin-bottom: 20px;
}
@media screen and (max-width: 820px) {
  .list_strengths_01 > li .box_text h3 {
    font-size: 1.5em;
  }
}
.list_strengths_01 > li .box_image {
  flex-shrink: 0;
  width: 206px;
}
@media screen and (max-width: 820px) {
  .list_strengths_01 > li .box_image {
    width: 100%;
  }
}
.list_strengths_01 > li:first-child {
  padding-top: 0;
}

.list_check_01 {
  /* font-weight: 300; */
}
.list_check_01 > li {
  padding-left: 1.5em;
  position: relative;
}
.list_check_01 > li:before {
  content: "";
  display: block;
  width: 1em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: url(../images/ico_checkbox_01.svg) no-repeat center/contain;
  position: absolute;
  top: 0.4em;
  left: 0;
}

.ttl_strengths_03 {
  margin-bottom: 54px;
  font-size: 2em;
  font-weight: 600;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_03 {
    font-size: 1.6em;
    margin-bottom: 30px;
  }
}
.ttl_strengths_03 .label--wrap {
  width: 100%;
}
.ttl_strengths_03 .label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 260px;
  aspect-ratio: 524/102;
  background: url(../images/ttl_strengths_03_label.png) no-repeat center/contain;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_03 .label {
    width: 208px;
  }
}
.ttl_strengths_03 .label .text {
  display: block;
  transform: rotate(-3deg);
  font-size: 23px;
  color: #fff;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_03 .label .text {
    font-size: 18px;
  }
}
.ttl_strengths_03 .strong {
  display: inline-block;
  margin: 10px 0 20px;
  color: #00AE68;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.65em;
  font-weight: 500;
  line-height: 1.2;
  margin-right: 6px;
  position: relative;
}
.ttl_strengths_03 .strong:before, .ttl_strengths_03 .strong:after {
  content: "";
  display: block;
  width: 307px;
  aspect-ratio: 614/166;
  background: url(../images/ttl_strengths_03_strong.png) no-repeat center/contain;
  position: absolute;
  bottom: -45px;
  left: 0;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_03 .strong:before, .ttl_strengths_03 .strong:after {
    width: 245.6px;
    bottom: -36px;
  }
}
.ttl_strengths_03 .strong .text {
  position: relative;
}

.strengths_02_lead {
  margin-bottom: 3em;
}
.strengths_02_lead p {
  margin-bottom: 1.8em;
}
.strengths_02_lead p:last-child {
  margin-bottom: 0;
}

.ttl_strengths_02_01 {
  padding: 1.5em 0;
  font-weight: 700;
  border-top: 1px solid rgba(0, 61, 37, 0.5);
}
.ttl_strengths_02_01:before {
  content: "●";
}

.list_strengths_02 > li {
  margin-bottom: 3em;
}
.list_strengths_02 > li:last-child {
  margin-bottom: 0;
}
.list_strengths_02 > li .image {
  margin-bottom: 1em;
}
.list_strengths_02 > li h4 {
  font-weight: 700;
  margin-bottom: 0.5em;
}
.list_strengths_02 > li p {
  font-size: 0.875em;
  line-height: 1.5;
  max-width: 691px;
}
.list_strengths_02 > li:nth-child(3) {
  display: flex;
  align-items: flex-end;
  gap: 4%;
}
@media screen and (max-width: 820px) {
  .list_strengths_02 > li:nth-child(3) {
    display: block;
  }
}
.list_strengths_02 > li:nth-child(3) .image {
  width: 100%;
  max-width: 380px;
  margin-bottom: 0;
}
@media screen and (max-width: 820px) {
  .list_strengths_02 > li:nth-child(3) .image {
    max-width: unset;
    margin-bottom: 1em;
  }
}
.list_strengths_02 > li:nth-child(3) .box_text {
  width: 100%;
  max-width: 280px;
}
@media screen and (max-width: 820px) {
  .list_strengths_02 > li:nth-child(3) .box_text {
    max-width: unset;
  }
}

.ttl_strengths_02 {
  margin-bottom: 54px;
  font-size: 2em;
  font-weight: 600;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 {
    font-size: 1.6em;
    margin-bottom: 40px;
  }
}
.ttl_strengths_02 .label--wrap {
  width: 100%;
}
.ttl_strengths_02 .label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 260px;
  aspect-ratio: 524/102;
  background: url(../images/ttl_strengths_02_label.png) no-repeat center/contain;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 .label {
    width: 208px;
  }
}
.ttl_strengths_02 .label .text {
  display: block;
  transform: rotate(-3deg);
  font-size: 23px;
  color: #fff;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 .label .text {
    font-size: 18px;
  }
}
.ttl_strengths_02 .strong {
  display: inline-block;
  margin: 10px 0 20px;
  color: #00AE68;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.65em;
  font-weight: 500;
  line-height: 1.2;
  margin-right: 6px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 .strong {
    line-height: 1.5;
  }
}
.ttl_strengths_02 .strong:before, .ttl_strengths_02 .strong:after {
  content: "";
  display: block;
  width: 307px;
  aspect-ratio: 614/166;
  background: url(../images/ttl_strengths_02_strong.png) no-repeat center/contain;
  position: absolute;
  bottom: -45px;
  left: 0;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 .strong:before, .ttl_strengths_02 .strong:after {
    width: 245px;
    bottom: -36px;
  }
}
.ttl_strengths_02 .strong:after {
  left: 6em;
}
@media screen and (max-width: 820px) {
  .ttl_strengths_02 .strong:after {
    left: 0;
    bottom: unset;
    top: 28px;
  }
}
.ttl_strengths_02 .strong .text {
  position: relative;
}

.para {
  font-size: 1.125em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .para {
    font-size: 1em;
  }
}
.para p {
  margin-bottom: 1.8em;
}
.para p:last-child {
  margin-bottom: 0;
}
.para p.large {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.66em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 1em;
}
@media screen and (max-width: 820px) {
  .para p.large {
    font-size: 1.375em;
    margin-bottom: 1.25em;
  }
}

.question {
  margin: 36px 0;
  padding: 30px;
  border: 1px dashed #003d25;
  max-width: 618px;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .question {
    font-size: 1em;
  }
}
.question span {
  display: block;
}
.question span:first-child {
  margin-bottom: 0.8em;
}
.question span:last-child {
  margin-top: 0.8em;
  color: #00AE68;
}

.dlist_sample {
  margin-top: 5em;
}
@media screen and (max-width: 820px) {
  .dlist_sample {
    margin-top: 3.75em;
  }
}
.dlist_sample dt {
  font-size: 1.125em;
  font-weight: 600;
  padding-left: 1em;
  text-indent: -1em;
  margin-bottom: 0.5em;
}
@media screen and (max-width: 820px) {
  .dlist_sample dt {
    font-size: 1em;
  }
}
.dlist_sample dt:before {
  content: "●";
}
.dlist_sample dd > p {
  font-size: 0.875em;
  /* font-weight: 300; */
  letter-spacing: 0.03em;
  line-height: 1.5;
  margin-bottom: 2em;
}
.dlist_sample table {
  width: 100%;
  max-width: 734px;
}
.dlist_sample table .list_dot {
  font-size: 0.875em;
  line-height: 1.5;
}
.dlist_sample table tr th {
  width: 168px;
  height: 72px;
  border-bottom: 1px solid #003D25;
  border-left: 1px solid #003D25;
  text-align: center;
  font-weight: 600;
  line-height: 1.25em;
}
@media screen and (max-width: 820px) {
  .dlist_sample table tr th {
    display: block;
    width: 100%;
    height: auto;
    padding: 0.75em 0;
    border-bottom: none;
    border-right: 1px solid #003D25;
  }
}
.dlist_sample table tr th span {
  border: 1px solid #003D25;
  border-radius: 8px;
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 6px 10px;
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.285;
  margin: 1em auto 0;
}
.dlist_sample table tr td {
  padding: 28px;
  border-bottom: 1px solid #003D25;
  border-right: 1px solid #003D25;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .dlist_sample table tr td {
    display: block;
    border-left: 1px solid #003D25;
    border-bottom: none;
    padding: 20px var(--sideW);
  }
}
.dlist_sample table tr:nth-child(1) th {
  border-top: 1px solid #003D25;
  background-color: rgba(0, 61, 37, 0.7);
  color: #fff;
  letter-spacing: 0.2em;
}
.dlist_sample table tr:nth-child(1) td {
  border-top: 1px solid #003D25;
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 0 0 28px;
}
@media screen and (max-width: 820px) {
  .dlist_sample table tr:nth-child(1) td {
    flex-direction: column;
    padding: 20px var(--sideW);
  }
}
.dlist_sample table tr:nth-child(1) td .text {
  flex-grow: 1;
  line-height: 1.5;
}
.dlist_sample table tr:nth-child(1) td .label {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  top: 0;
  right: 0;
  width: 206px;
  height: 72px;
  background-color: #DFEECD;
  font-weight: 600;
  line-height: 1.25;
  clip-path: polygon(50px 0%, 100% 0, 100% 100%, 0% 100%);
  padding-left: 70px;
}
@media screen and (max-width: 820px) {
  .dlist_sample table tr:nth-child(1) td .label {
    padding: 40px 0 10px;
    width: 100%;
    clip-path: polygon(50% 0%, 100% 38%, 100% 100%, 0 100%, 0% 38%);
    height: auto;
    align-items: center;
  }
}
.dlist_sample table tr:nth-child(1) td .label span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 102px;
  aspect-ratio: 102/24;
  font-size: 0.875em;
  background-color: #00AE68;
  color: #fff;
  border-radius: 8px;
  margin-bottom: 2px;
}
.dlist_sample table tr:nth-child(2) th {
  border-top: 1px solid #003D25;
  background-color: rgba(0, 61, 37, 0.55);
  color: #fff;
  letter-spacing: 0.2em;
}
.dlist_sample table tr:nth-child(3) th {
  border-top: 1px solid #003D25;
  background-color: rgba(0, 61, 37, 0.4);
  color: #fff;
}
.dlist_sample table tr:nth-child(4) th {
  border-top: 1px solid #003D25;
  background-color: rgba(0, 61, 37, 0.25);
  letter-spacing: 0.2em;
}
.dlist_sample table tr:nth-child(4) td p {
  color: #156743;
  font-weight: 600;
  margin-bottom: 1em;
}
.dlist_sample table tr:nth-child(5) th {
  border-top: 1px solid #003D25;
  background-color: rgba(0, 61, 37, 0.15);
}
@media screen and (max-width: 820px) {
  .dlist_sample table tr:nth-child(5) td {
    border-bottom: 1px solid #003D25;
  }
}

.feature {
  margin-top: 7.5em;
  position: relative;
}
.feature .lottie {
  position: absolute;
  width: 450px;
  position: absolute;
  top: -74px;
  right: -100px;
}
@media screen and (max-width: 820px) {
  .feature .lottie {
    width: 300px;
    top: -120px;
    right: -75px;
  }
}
.feature h3 {
  background-color: #003D25;
  color: #fff;
  font-size: 1.5em;
  font-weight: 600;
  padding: 10px 1em;
}
@media screen and (max-width: 820px) {
  .feature h3 {
    font-size: 1.2em;
  }
}
.feature > ul > li {
  padding: 40px 0;
  border-bottom: 1px solid rgba(0, 61, 37, 0.3);
}
@media screen and (max-width: 820px) {
  .feature > ul > li {
    padding: 30px 0;
  }
}
.feature > ul > li:first-child {
  padding-top: 48px;
}
@media screen and (max-width: 820px) {
  .feature > ul > li:first-child {
    padding-top: 40px;
  }
}
.feature > ul > li h4 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  margin-bottom: 30px;
}
@media screen and (max-width: 820px) {
  .feature > ul > li h4 {
    font-size: 1.5em;
    margin-bottom: 20px;
  }
}

.list_check_02 {
  /* font-weight: 300; */
}
.list_check_02 > li {
  padding-left: 1.5em;
  position: relative;
}
.list_check_02 > li:before {
  content: "";
  display: block;
  width: 1em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: url(../images/ico_checkbox_02.svg) no-repeat center/contain;
  position: absolute;
  top: 0.4em;
  left: 0;
}

.ttl_service_01 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.32;
}
@media screen and (max-width: 820px) {
  .ttl_service_01 {
    font-size: 2.2em;
  }
}

.ttl_service_02 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .ttl_service_02 {
    font-size: 1.5em;
  }
}

.ttl_service_03 {
  border-top: 1px dashed #003D25;
  border-bottom: 1px dashed #003D25;
  padding: 4px 0;
}
.ttl_service_03 span {
  display: flex;
  align-items: center;
  background-color: #E8F7EF;
  font-size: 1.5em;
  font-weight: 600;
  padding: 6px 24px 6px;
}
@media screen and (max-width: 820px) {
  .ttl_service_03 span {
    font-size: 1.2em;
    padding: 6px 12px 6px;
  }
}
.ttl_service_03 span:before {
  flex-shrink: 0;
  content: attr(data-num);
  display: block;
  padding-top: 0.25em;
  width: 72px;
  font-family: "Josefin Sans", sans-serif;
  font-size: 44px;
  font-weight: 600;
  line-height: 1;
}
@media screen and (max-width: 820px) {
  .ttl_service_03 span:before {
    font-size: 35px;
    width: 40px;
  }
}

.service_lead {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
}

.page-service_01 .section_wrap {
  padding-top: 10em;
}
@media screen and (max-width: 820px) {
  .page-service_01 .section_wrap {
    padding-top: 5em;
  }
}
.page-service_01 .ttl_service_02 {
  margin-bottom: 30px;
}

.service_hero_01 {
  padding-top: 195px;
}
@media screen and (max-width: 820px) {
  .service_hero_01 {
    padding-top: 6.25em;
  }
}
.service_hero_01 .ttl_service_01 {
  margin-bottom: 20px;
}

.service_01_lead {
  margin-top: 16px;
  background-color: #156743;
  padding: 44px 3.48% 58px;
  border-radius: 16px;
  display: flex;
  align-items: flex-start;
  gap: 24px 8.45%;
}
@media screen and (max-width: 820px) {
  .service_01_lead {
    flex-direction: column;
    padding: 30px var(--sideW) var(--sideW);
  }
}
.service_01_lead .box_text {
  flex-grow: 1;
  max-width: 576px;
}
.service_01_lead .box_image {
  flex-shrink: 0;
  width: 36.81%;
  border-radius: 8px;
  overflow: hidden;
}
@media screen and (max-width: 820px) {
  .service_01_lead .box_image {
    width: 100%;
  }
}
.service_01_lead h2 {
  color: #fff;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.5em;
  font-weight: 600;
  margin-bottom: 16px;
}
@media screen and (max-width: 820px) {
  .service_01_lead h2 {
    font-size: 1.2em;
  }
}
.service_01_lead p {
  color: #fff;
  /* font-weight: 300; */
  margin-bottom: 24px;
}
@media screen and (max-width: 820px) {
  .service_01_lead p {
    font-size: 0.875em;
  }
}
.service_01_lead ul li {
  margin-bottom: 16px;
  background-color: #E8F7EF;
  border-radius: 8px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 16px;
}
@media screen and (max-width: 820px) {
  .service_01_lead ul li {
    display: block;
    padding: 24px var(--sideW);
    font-size: 0.9375em;
  }
}
.service_01_lead ul li:last-child {
  margin-bottom: 0;
}
.service_01_lead ul li:before {
  content: "";
  display: block;
  width: 3em;
  aspect-ratio: 1/1;
  border-radius: 0.5em;
  background: #156743 url(../images/ico_hatena.png) no-repeat center/20px;
}
@media screen and (max-width: 820px) {
  .service_01_lead ul li:before {
    width: 2.4em;
    background-size: 16px;
    margin: 0 auto 14px;
  }
}

.service_02_lead {
  margin-top: 16px;
  background-color: #156743;
  padding: 44px 3.48% 40px;
  border-radius: 16px;
  display: flex;
  align-items: flex-end;
  gap: 7.38%;
  position: relative;
}
@media screen and (max-width: 820px) {
  .service_02_lead {
    margin-top: 64px;
    flex-direction: column;
    padding: 60px var(--sideW) 40px;
  }
}
.service_02_lead:after {
  content: "";
  display: block;
  width: 47.84%;
  aspect-ratio: 577/309;
  background: url(../images/service_02_00.png) no-repeat center/contain;
  position: absolute;
  right: -10px;
  top: 0;
  transform: translateY(-62.5%);
}
@media screen and (max-width: 820px) {
  .service_02_lead:after {
    width: 60%;
  }
}
.service_02_lead .box_text {
  flex-grow: 1;
  max-width: 432px;
  margin-bottom: 1em;
}
.service_02_lead .box_num {
  flex-shrink: 0;
  width: auto;
  color: #DFEECD;
}
@media screen and (max-width: 820px) {
  .service_02_lead .box_num {
    width: 100%;
  }
}
.service_02_lead .box_num dt {
  font-size: 1.5em;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 10px;
}
@media screen and (max-width: 820px) {
  .service_02_lead .box_num dt {
    font-size: 1.2em;
  }
}
.service_02_lead .box_num dt span {
  display: block;
  font-size: 0.5833em;
  font-weight: 400;
}
.service_02_lead .box_num dd {
  font-size: 3.5625em;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 820px) {
  .service_02_lead .box_num dd {
    font-size: 2.85em;
  }
}
.service_02_lead .box_num dd span {
  font-family: "Josefin Sans", sans-serif;
  font-size: 165px;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .service_02_lead .box_num dd span {
    font-size: 80px;
  }
}
.service_02_lead h2 {
  color: #fff;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.5em;
  font-weight: 600;
  margin-bottom: 16px;
}
.service_02_lead p {
  color: #fff;
  /* font-weight: 300; */
  margin-bottom: 24px;
}

.service_04_lead {
  margin-top: 1em;
  background-color: #156743;
  color: #fff;
  padding: 40px 4.9% 0;
  border-radius: 16px;
  display: flex;
  align-items: flex-start;
  gap: 7.17%;
}
@media screen and (max-width: 820px) {
  .service_04_lead {
    flex-direction: column;
    padding: 20px var(--sideW) 40px;
  }
}
.service_04_lead .box_text {
  flex-grow: 1;
  max-width: 576px;
  padding: 10px 0 40px;
}
.service_04_lead .box_text p {
  /* font-weight: 300; */
  margin-bottom: 1.8em;
}
.service_04_lead .box_text p:last-child {
  margin-bottom: 0;
}
.service_04_lead .box_image {
  flex-shrink: 0;
  width: 50%;
  margin-top: -10%;
}
@media screen and (max-width: 820px) {
  .service_04_lead .box_image {
    width: 100%;
    margin: 0;
  }
}
.service_04_lead ul li {
  margin-bottom: 16px;
  background-color: #E8F7EF;
  border-radius: 8px;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 16px;
}
.service_04_lead ul li:last-child {
  margin-bottom: 0;
}
.service_04_lead ul li:before {
  content: "";
  display: block;
  width: 3em;
  aspect-ratio: 1/1;
  border-radius: 0.5em;
  background: #156743 url(../images/ico_hatena.png) no-repeat center/20px;
}

.list_service_01 > li {
  margin-bottom: 5em;
}
.list_service_01 > li .ttl_service_03 {
  margin-bottom: 34px;
}
.list_service_01 > li:last-child {
  margin-bottom: 0;
}
.list_service_01 > li .box_content {
  display: flex;
  align-items: flex-start;
  gap: 2.5em 7.3%;
  padding-left: 3%;
}
@media screen and (max-width: 820px) {
  .list_service_01 > li .box_content {
    flex-direction: column-reverse;
    padding-left: 0;
  }
}
.list_service_01 > li .box_image {
  flex-shrink: 0;
  width: 28.76%;
  aspect-ratio: 1/1;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 820px) {
  .list_service_01 > li .box_image {
    width: 70%;
    margin: 0 auto;
  }
}
.list_service_01 > li .box_image:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #F1F4F3;
  position: absolute;
  top: 0;
  left: 0;
}
.list_service_01 > li .box_image .lottie {
  width: 86.02%;
  position: relative;
}
.list_service_01 > li .box_text {
  flex-grow: 1;
}

.service_dlist_01 dt {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.5;
  border: 1px solid #003D25;
  padding: 0 5px;
  margin-bottom: 0.375em;
}
.service_dlist_01 dd {
  /* font-weight: 300; */
  margin-bottom: 1.25em;
}
.service_dlist_01 dd:last-of-type {
  margin-bottom: 0;
}

.service_dlist_02 {
  margin-top: 30px;
  border: 1px solid #003D25;
  position: relative;
  padding: 44px 4.85% 22px;
}
.service_dlist_02 > dt {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.5;
  background-color: #156743;
  color: #fff;
  padding: 3px 10px;
  transform: translate(-1px, -1px);
  position: absolute;
  top: 0;
  left: 0;
}
.service_dlist_02 .list_check_02 {
  font-weight: 600;
}
.service_dlist_02 .list_check_02 > li {
  margin-bottom: 0.75em;
}
.service_dlist_02 .list_check_02 > li:last-child {
  margin-bottom: 0;
}

.service_dlist_03 {
  margin-top: 30px;
  font-weight: 600;
}
.service_dlist_03 dt {
  background-color: #E8F7EF;
  font-size: 0.875em;
  padding: 2px 10px;
  margin-bottom: 16px;
}

.list_num_01 > li {
  padding-left: 1em;
  text-indent: -1em;
}
.list_num_01 > li:before {
  content: attr(data-num);
}
.list_num_01 > li .small {
  font-size: 0.875em;
}
.list_num_01 .down {
  display: inline-block;
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.5;
  background-color: #156743;
  color: #fff;
  border-radius: 50px;
  padding: 1px 8px 2px;
  text-indent: 0;
}
@media screen and (max-width: 820px) {
  .list_num_01 .down {
    font-size: 11px;
  }
}
.list_num_01 .down.down_01 {
  margin-left: 32px;
}
@media screen and (max-width: 820px) {
  .list_num_01 .down.down_01 {
    margin-left: 10px;
  }
}
.list_num_01 .down.down_02 {
  margin-left: 64px;
}
@media screen and (max-width: 820px) {
  .list_num_01 .down.down_02 {
    margin-left: 42px;
  }
}

.page-service_02 .section_wrap {
  padding-top: 5em;
}
.page-service_02 .section_wrap > .inner {
  max-width: calc(854px + var(--sideW) * 2);
}

.service_hero_02 {
  padding-top: 160px;
}
@media screen and (max-width: 820px) {
  .service_hero_02 {
    padding-top: 6.25em;
  }
}
.service_hero_02 .ttl_service_01 {
  margin-bottom: 20px;
}

.list_service_02 > li {
  margin-bottom: 5em;
}
.list_service_02 > li:last-child {
  margin-bottom: 0;
}

.card_service_02 .label {
  text-align: center;
  font-family: "Josefin Sans", sans-serif;
  font-size: 1.75em;
  font-weight: 600;
  line-height: 1.25;
}
.card_service_02 .label span {
  display: block;
  font-size: 12px;
  text-decoration: underline;
}
.card_service_02 h2 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.125em;
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 14px;
}
@media screen and (max-width: 820px) {
  .card_service_02 h2 {
    font-size: 1.7em;
  }
}
.card_service_02 .num {
  text-align: center;
  font-size: 3.3125em;
  font-weight: 700;
  line-height: 1.1;
}
@media screen and (max-width: 820px) {
  .card_service_02 .num {
    font-size: 2em;
  }
}
.card_service_02 .num span {
  font-family: "Josefin Sans", sans-serif;
  font-size: 112px;
  font-weight: 600;
  margin-right: 5px;
}
@media screen and (max-width: 820px) {
  .card_service_02 .num span {
    font-size: 80px;
  }
}
.card_service_02 .list_kome {
  font-size: 0.75em;
  line-height: 1.5em;
  text-align: center;
  margin-bottom: 2em;
}
.card_service_02 .box_border {
  border: 1px solid #003D25;
  padding: 16px 3.512% 32px;
}
@media screen and (max-width: 820px) {
  .card_service_02 .box_border {
    padding: 24px var(--sideW) 32px;
  }
}
.card_service_02 h3 {
  font-weight: 700;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 820px) {
  .card_service_02 h3 {
    margin-bottom: 20px;
  }
}
.card_service_02 h3 + p {
  text-align: center;
  line-height: 1.5;
  margin-bottom: 16px;
}
@media screen and (max-width: 820px) {
  .card_service_02 h3 + p {
    font-size: 0.9375em;
  }
}
.card_service_02 .highlights {
  margin-top: 24px;
  display: flex;
  gap: 32px;
}
@media screen and (max-width: 820px) {
  .card_service_02 .highlights {
    flex-direction: column-reverse;
    margin-top: 48px;
    gap: 16px;
  }
}
.card_service_02 .highlights .image {
  flex-shrink: 0;
  width: 144px;
}
@media screen and (max-width: 820px) {
  .card_service_02 .highlights .image {
    width: 70%;
    margin: 0 auto;
  }
}
.card_service_02 .highlights dl {
  flex-grow: 1;
}
.card_service_02 .highlights dl dt {
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 8px;
}
.card_service_02 .highlights dl dt span {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0 20px;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.75em;
  border-left: 1px solid #003D25;
  border-right: 1px solid #003D25;
  margin-bottom: 6px;
}
@media screen and (max-width: 820px) {
  .card_service_02 .highlights dl dt span {
    margin: 0 auto 6px;
  }
}
.card_service_02 .highlights dl dd {
  font-size: 0.875em;
  line-height: 1.5;
}

.page-service_03 .section_wrap {
  padding-top: 5em;
}

.service_03_lead {
  margin-top: 3em;
  background-color: #156743;
  padding: 37px 4.9% 60px 60px;
  border-radius: 16px;
  position: relative;
}
@media screen and (max-width: 820px) {
  .service_03_lead {
    margin-top: 64px;
    flex-direction: column;
    padding: 60px var(--sideW) var(--sideW);
  }
}
.service_03_lead:before {
  content: "";
  display: block;
  width: 51.74%;
  aspect-ratio: 624/287;
  background: url(../images/service_03_01.png) no-repeat center/contain;
  position: absolute;
  right: 0;
  top: 0;
  transform: translateY(-75%);
}
@media screen and (max-width: 820px) {
  .service_03_lead:before {
    width: 70%;
    top: 20px;
  }
}
.service_03_lead h2 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 500;
  line-height: 1.2;
  color: #fff;
  margin-bottom: 0.75em;
  position: relative;
}
@media screen and (max-width: 820px) {
  .service_03_lead h2 {
    font-size: 1.5em;
    margin-bottom: 1.5em;
  }
}
.service_03_lead h2:before {
  content: "";
  display: block;
  width: 157px;
  aspect-ratio: 316/152;
  background: url(../images/ttl_service_03_strong.png) no-repeat center/contain;
  position: absolute;
  bottom: -44px;
  left: -6px;
}
@media screen and (max-width: 820px) {
  .service_03_lead h2:before {
    width: 126px;
    bottom: -36px;
  }
}
.service_03_lead h2 span {
  position: relative;
}
.service_03_lead ul {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media screen and (max-width: 820px) {
  .service_03_lead ul {
    flex-direction: column;
  }
}
.service_03_lead ul > li {
  width: calc((100% - 16px) / 2);
  background-image: linear-gradient(0deg, transparent calc(100% - 2px), #E8F7EF calc(100% - 2px)), linear-gradient(90deg, #fff calc(100% - 2px), #E8F7EF calc(100% - 2px));
  background-size: 6px 6px;
  background-repeat: repeat;
  background-position: center center;
  display: flex;
  gap: 8px;
  padding: 16px 24px 16px 16px;
}
@media screen and (max-width: 820px) {
  .service_03_lead ul > li {
    width: 100%;
    flex-direction: column;
  }
}
.service_03_lead ul > li:before {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 1/1;
  background: url(../images/ico_hatena_02.png) no-repeat center/contain;
  flex-shrink: 0;
}
@media screen and (max-width: 820px) {
  .service_03_lead ul > li:before {
    width: 40px;
    margin: 0 auto 8px;
  }
}
.service_03_lead ul > li .box_text {
  flex-grow: 1;
  font-size: 1.125em;
  font-weight: 600;
  line-height: 1.5;
  color: #156743;
}
@media screen and (max-width: 820px) {
  .service_03_lead ul > li .box_text {
    font-size: 1em;
    text-align: center;
  }
}
.service_03_lead ul > li .box_text span {
  margin-top: 5px;
  display: block;
  background-color: #156743;
  color: #fff;
  padding: 4px 8px;
}

@media screen and (max-width: 820px) {
  .service_03_sec_01 .inner_l {
    width: auto;
    padding: 0;
  }
}
.service_03_sec_01--box {
  background-image: linear-gradient(0deg, transparent calc(100% - 2px), #E8F7EF calc(100% - 2px)), linear-gradient(90deg, #fff calc(100% - 2px), #E8F7EF calc(100% - 2px));
  background-size: 6px 6px;
  background-repeat: repeat;
  background-position: center center;
  border-radius: 16px;
  padding: 3em 6% 7.5em;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01--box {
    padding: 3em var(--sideW) 5em;
  }
}
.service_03_sec_01 h2 {
  width: -moz-fit-content;
  width: fit-content;
  background: url(../images/ttl_service_03_label.png) no-repeat center/contain;
  color: #fff;
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 500;
  line-height: 1.5;
  padding: 0.66em;
  transform: translateX(-1.25em);
  margin-bottom: 20px;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 h2 {
    font-size: 1.5em;
    transform: translateX(-0.5em);
    margin-bottom: 0.5em;
  }
}
.service_03_sec_01 h2 span {
  display: block;
  transform: rotate(-4deg);
}
.service_03_sec_01 ul {
  margin-top: 50px;
}
.service_03_sec_01 ul li {
  display: flex;
  gap: 1.875em 6.88%;
  margin-bottom: 70px;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li {
    flex-direction: column-reverse;
  }
}
.service_03_sec_01 ul li:last-child {
  margin-bottom: 0;
}
.service_03_sec_01 ul li .box_left {
  width: 32%;
  flex-shrink: 0;
  padding-left: 1.7%;
  position: relative;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li .box_left {
    width: 100%;
    padding-left: 0;
  }
}
.service_03_sec_01 ul li .box_left:after {
  content: "";
  display: block;
  width: 64px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: url(../images/service_03_07.png) no-repeat center/contain;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  position: absolute;
  left: 0;
  top: -8px;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li .box_left:after {
    content: none;
    width: 40px;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
.service_03_sec_01 ul li .box_lottie {
  width: 100%;
  aspect-ratio: 339/192;
  background: no-repeat center/contain;
}
.service_03_sec_01 ul li .box_lottie.bg01 {
  background-image: url(../images/service_03_02.svg);
}
.service_03_sec_01 ul li .box_lottie.bg02 {
  background-image: url(../images/service_03_03.svg);
}
.service_03_sec_01 ul li .box_lottie.bg03 {
  background-image: url(../images/service_03_04.svg);
}
.service_03_sec_01 ul li .box_lottie.bg04 {
  background-image: url(../images/service_03_05.svg);
}
.service_03_sec_01 ul li .box_lottie.bg05 {
  background-image: url(../images/service_03_06.svg);
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li .box_right {
    position: relative;
  }
  .service_03_sec_01 ul li .box_right:before {
    content: "";
    display: block;
    aspect-ratio: 1/1;
    border-radius: 50%;
    background: url(../images/service_03_07.png) no-repeat center/contain;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
    width: 40px;
    margin: 0 auto 20px;
  }
}
.service_03_sec_01 ul li h3 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.75em;
  font-weight: 500;
  line-height: 1.4;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li h3 {
    font-size: 1.3em;
  }
}
.service_03_sec_01 ul li p {
  margin-top: 0.5em;
  line-height: 2;
}
@media screen and (max-width: 820px) {
  .service_03_sec_01 ul li p {
    font-size: 0.875em;
  }
}

.service_03_sec_02 {
  margin-bottom: 0;
}
.service_03_sec_02 h2 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.75em;
  font-weight: 500;
  line-height: 1.4;
  margin-bottom: 0.75em;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 h2 {
    font-size: 1.4em;
  }
}
.service_03_sec_02 h2 + p {
  /* font-weight: 300; */
  line-height: 2;
  margin-bottom: 2em;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 h2 + p {
    font-size: 0.875em;
  }
}
.service_03_sec_02 .list_step {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 70px 6.36%;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 .list_step {
    flex-direction: column;
    gap: 0;
  }
  .service_03_sec_02 .list_step > li {
    margin-bottom: 60px;
  }
  .service_03_sec_02 .list_step > li:nth-last-of-child(2) {
    margin-bottom: 20px;
  }
  .service_03_sec_02 .list_step > li:last-child {
    margin-bottom: 0px;
  }
}
.service_03_sec_02 .list_step > li {
  width: 46.82%;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 .list_step > li {
    width: 100%;
  }
}
.service_03_sec_02 .list_step h3 {
  border-top: 1px dashed #003D25;
  border-bottom: 1px dashed #003D25;
  padding: 6px 0;
  margin-bottom: 22px;
}
.service_03_sec_02 .list_step h3 .text {
  display: block;
  background-color: #E8F7EF;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.2;
  padding: 6px 12px 4px;
  display: flex;
  align-items: baseline;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 .list_step h3 .text {
    font-size: 1.2em;
  }
}
.service_03_sec_02 .list_step h3 .text .en {
  flex-shrink: 0;
  margin-right: 0.66em;
}
.service_03_sec_02 .list_step .lottie {
  width: 96.31%;
  margin-left: auto;
}
@media screen and (max-width: 820px) {
  .service_03_sec_02 .list_step .lottie {
    width: 75%;
    margin: 0 auto;
  }
}

.dlist_step > .group {
  display: flex;
  font-weight: 600;
  border-bottom: 1px solid rgba(0, 61, 37, 0.3);
}
.dlist_step > .group > dt {
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 73px;
  background-color: #F1F4F3;
  font-size: 0.875em;
}
.dlist_step > .group > dd {
  line-height: 1.5;
  flex-grow: 1;
  padding: 1em 30px;
}
@media screen and (max-width: 820px) {
  .dlist_step > .group > dd {
    padding: 1em var(--sideW);
    font-size: 0.9375em;
  }
}
.dlist_step > .group:last-child {
  border-bottom: none;
}
.dlist_step > .group:last-child dd {
  padding-bottom: 0;
}
.dlist_step .list_square li {
  margin-bottom: 0.3em;
}
.dlist_step .list_square li:last-child {
  margin-bottom: 0;
}

.dlist_square dt {
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 0.3em;
}
.dlist_square dt:before {
  content: "■";
}
.dlist_square dd {
  padding: 0 0 0 1em;
  font-weight: 400;
  margin-bottom: 0.5em;
}
.dlist_square dd:last-child {
  margin-bottom: 0;
}

.price {
  margin-top: 5em;
}
.price h3 {
  font-size: 1.125em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.66em;
}
.price ul {
  display: flex;
  gap: 2.36%;
}
@media screen and (max-width: 820px) {
  .price ul {
    flex-direction: column;
    gap: 16px;
  }
}
.price ul li {
  width: 100%;
}
.price ul li > dl {
  border: 1px solid #003D25;
  height: 100%;
}
.price ul li > dl > dt {
  background-color: #003D25;
  color: #fff;
  font-size: 1.0625em;
  display: flex;
  align-items: center;
  line-height: 1.5;
  padding: 10px;
}
.price ul li > dl > dt > span {
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  font-size: 13px;
  margin-right: 8px;
  border-right: 1px solid #fff;
  padding-right: 11px;
}
.price ul li > dl > dt > span span {
  font-size: 15px;
}
.price ul li > dl > dd {
  padding: 10px 5.28%;
}
.price ul li > dl > dd .group {
  display: flex;
  font-size: 0.9375em;
  font-weight: 600;
  gap: 13px;
}
.price ul li > dl > dd .group dt:after {
  content: " :";
}

.ttl_works_01 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  height: 28px;
  border: 1px solid #003D25;
  background-color: #DFEECD;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 1.5;
  opacity: 0.5;
  border-radius: 50px;
  padding: 0 8px;
}

.catch_works_01 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.25em;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .catch_works_01 {
    font-size: 1.8em;
  }
}

.works_hero_01 {
  padding-top: 8.5em;
}
@media screen and (max-width: 820px) {
  .works_hero_01 {
    padding-top: 6.25em;
  }
}
.works_hero_01 .ttl_works_01 {
  margin-bottom: 16px;
}
.works_hero_01 .catch_works_01 {
  margin-bottom: 10px;
}
@media screen and (max-width: 820px) {
  .works_hero_01 .catch_works_01 {
    margin-bottom: 16px;
  }
}
.works_hero_01 .item {
  font-size: 0.875em;
  /* font-weight: 300; */
  line-height: 1.5;
}
.works_hero_01 .image {
  margin: 72px var(--extend) 0;
  display: block;
  overflow: hidden;
  height: 600px;
}
@media screen and (max-width: 820px) {
  .works_hero_01 .image {
    margin-top: 40px;
    height: 200px;
  }
}
.works_hero_01 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.list_works_01 {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  opacity: 0.5;
}
.list_works_01 > li {
  font-size: 0.75em;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 8px;
  height: 28px;
  border: 1px solid #003D25;
  border-radius: 50px;
  background-color: #e8f7ef;
}
.list_works_01 + .works_item_01 {
  margin-top: 14px;
}

.works_item_01 {
  opacity: 0.5;
  font-size: 0.75em;
  font-weight: 600;
  margin-bottom: 56px;
}
@media screen and (max-width: 820px) {
  .works_item_01 {
    margin-bottom: 36px;
  }
}

.works_gallery_list > li {
  margin-bottom: 72px;
}
@media screen and (max-width: 820px) {
  .works_gallery_list > li {
    margin-bottom: 20px;
  }
}
.works_gallery_list > li:last-child {
  margin-bottom: 0;
}

.works_gallery_02 {
  display: flex;
}
@media screen and (max-width: 820px) {
  .works_gallery_02 {
    display: block;
  }
  .works_gallery_02 .image {
    margin-bottom: 20px;
  }
}
.works_gallery_02 .image {
  width: 100%;
  display: block;
  overflow: hidden;
  aspect-ratio: 603/474;
}
.works_gallery_02 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.works_gallery_03 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.works_gallery_03 .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 603/414;
}
.works_gallery_03 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.works_gallery_03 .image:nth-child(1) {
  grid-column: 1/2;
  grid-row: 1/3;
  aspect-ratio: unset;
}
.works_gallery_03 .image:nth-child(2) {
  grid-column: 2/3;
  grid-row: 1/2;
}
.works_gallery_03 .image:nth-child(3) {
  grid-column: 2/3;
  grid-row: 2/3;
}

.works_gallery_04 {
  display: flex;
}
@media screen and (max-width: 820px) {
  .works_gallery_04 {
    display: block;
  }
  .works_gallery_04 .image {
    margin-bottom: 20px;
  }
}
.works_gallery_04 .image {
  width: 100%;
  display: block;
  overflow: hidden;
  aspect-ratio: 603/560;
}
.works_gallery_04 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.works_gallery_05 {
  display: flex;
}
.works_gallery_05 .image {
  width: 100%;
  display: block;
  overflow: hidden;
  aspect-ratio: 603/376;
}
.works_gallery_05 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.works_gallery_06 {
  display: flex;
}
@media screen and (max-width: 820px) {
  .works_gallery_06 {
    display: block;
  }
  .works_gallery_06 .image {
    margin-bottom: 20px;
  }
}
.works_gallery_06 .image {
  width: 100%;
  display: block;
  overflow: hidden;
  aspect-ratio: 603/384;
}
.works_gallery_06 .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.page-works_01 .section_wrap,
.page-works_02 .section_wrap,
.page-works_03 .section_wrap {
  padding-top: 3.75em;
}

.page-works_03 .works_hero_01 {
  padding-top: 8.5em;
  background: #F4EFE7;
}
@media screen and (max-width: 820px) {
  .page-works_03 .works_hero_01 {
    padding-top: 6.25em;
  }
}
.page-works_03 .works_hero_01 .image {
  margin: 72px var(--extend) 0;
  padding: 0 var(--sideW);
  display: block;
  overflow: hidden;
  height: 600px;
}
@media screen and (max-width: 820px) {
  .page-works_03 .works_hero_01 .image {
    margin-top: 60px;
    height: 300px;
  }
}
.page-works_03 .works_hero_01 .image img {
  display: block;
  width: 100%;
  max-width: 706px;
  height: auto;
  -o-object-fit: unset;
     object-fit: unset;
  margin: 104px auto 0;
}
@media screen and (max-width: 820px) {
  .page-works_03 .works_hero_01 .image img {
    margin-top: 60px;
  }
}

.layout_split_01 {
  display: flex;
}
@media screen and (max-width: 820px) {
  .layout_split_01 {
    flex-direction: column;
    gap: 5em;
  }
}
.layout_split_01 .box_left {
  width: 100%;
  padding-right: 5.8%;
}
@media screen and (max-width: 820px) {
  .layout_split_01 .box_left {
    padding: 0;
  }
}
.layout_split_01 .box_right {
  width: 100%;
  padding-left: 5.8%;
  border-left: 1px dotted rgba(0, 61, 37, 0.3);
}
@media screen and (max-width: 820px) {
  .layout_split_01 .box_right {
    padding-left: 0;
    border-left: none;
  }
}

.request_hero {
  padding: 162px 0 92px;
}
@media screen and (max-width: 820px) {
  .request_hero {
    padding: 6.25em 0 4em;
  }
}
.request_hero h1 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.318;
}
@media screen and (max-width: 820px) {
  .request_hero h1 {
    font-size: 2.2em;
  }
}
.request_hero p {
  margin-top: 1em;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .request_hero p {
    font-size: 1.2em;
  }
}

.ttl_request_01 {
  background-color: #003D25;
  color: #fff;
  padding: 2px 16px 3px;
  font-size: 1.125em;
  /* font-weight: 300; */
}

.request_sec_01 {
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .request_sec_01 {
    margin-bottom: 3em;
  }
}
.request_sec_01 .list_dot {
  margin-top: 20px;
  font-weight: 600;
}
.request_sec_01 .image {
  margin-top: 20px;
}

.request_sec_02 {
  margin-bottom: 0;
}
.request_sec_02 ul {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 24px 6%;
}
.request_sec_02 ul li {
  width: 29.3333333333%;
  position: relative;
}
.request_sec_02 ul li:after {
  content: "";
  display: block;
  width: 1px;
  height: 100%;
  background-color: rgba(0, 61, 37, 0.3);
  position: absolute;
  top: 0;
  left: 110%;
}
.request_sec_02 ul li:nth-child(3n):after {
  content: none;
}

.container_request {
  max-width: 515px;
}
.container_request > p {
  font-size: 1.125em;
  font-size: 300;
  margin-bottom: 2.4em;
}
@media screen and (max-width: 820px) {
  .container_request > p {
    font-size: 0.9375em;
  }
}
.container_request .wpcf7-form-control-wrap[data-name=your-agreement] {
  margin-top: 50px;
}

.download_content {
  padding: 12.5em 0 12.5em;
  background-color: #F1F4F3;
  text-align: center;
}
@media screen and (max-width: 820px) {
  .download_content {
    padding: 7.5em 0 2.5em;
  }
}
.download_content h1 {
  margin-bottom: 4em;
  font-size: 1.25em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .download_content h1 {
    font-size: 1em;
    margin-bottom: 3em;
  }
}
.download_content h1:before {
  content: attr(data-en);
  display: block;
  font-family: "Josefin Sans", sans-serif;
  font-size: 2.2em;
}
.download_content p {
  /* font-weight: 300; */
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .download_content p {
    font-size: 0.9375em;
    text-align: left;
    margin-bottom: 3em;
  }
}
.download_content a {
  margin: 0 auto;
  width: 100%;
  max-width: 412px;
  height: 84px;
  font-size: 1.25em;
}
@media screen and (max-width: 820px) {
  .download_content a {
    font-size: 1.125em;
    height: 70px;
  }
}

.container_contact {
  padding-top: 162px;
  width: 100%;
  max-width: 515px;
  margin: 0 auto;
}
@media screen and (max-width: 820px) {
  .container_contact {
    padding-top: 7.5em;
  }
}
.container_contact h1 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  text-align: center;
  margin-bottom: 1em;
}
@media screen and (max-width: 820px) {
  .container_contact h1 {
    font-size: 1.875em;
    margin-bottom: 2.5em;
  }
}

.thanks_content {
  padding: 12.5em var(--sideW) 12.5em;
  background-color: #F1F4F3;
  text-align: center;
}
@media screen and (max-width: 820px) {
  .thanks_content {
    padding: 7.5em var(--sideW) 5em;
  }
}
.thanks_content h1 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  margin-bottom: 2em;
}
@media screen and (max-width: 820px) {
  .thanks_content h1 {
    font-size: 1.5em;
  }
}
.thanks_content .para {
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .thanks_content .para {
    font-size: 0.9375em;
    text-align: left;
  }
}
.thanks_content .para p {
  margin-bottom: 1.8em;
}
.thanks_content .para p:last-child {
  margin-bottom: 0;
}
.thanks_content a {
  margin: 0 auto;
  width: 100%;
  max-width: 412px;
  height: 84px;
  font-size: 1.25em;
}

.page-toiawase_privacy_policy .section_wrap {
  padding-top: 10.5em;
}
@media screen and (max-width: 820px) {
  .page-toiawase_privacy_policy .section_wrap {
    padding-top: 7.5em;
  }
}
@media screen and (max-width: 820px) {
  .page-toiawase_privacy_policy .ttl_policy_01 {
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 820px) {
  .dlist_tpolicy {
    font-size: 0.9375em;
  }
}
.dlist_tpolicy .group {
  margin-bottom: 2em;
}
.dlist_tpolicy .group:last-child {
  margin-bottom: 0;
}
.dlist_tpolicy dt {
  font-size: 1.125em;
  font-weight: 700;
  line-height: 1.77;
}
.dlist_tpolicy dd {
  line-height: 2;
}

.page-privacypolicy .mt18 {
  margin-top: 1.8em;
}

.policy_hero {
  padding: 130px 0 40px;
}
@media screen and (max-width: 820px) {
  .policy_hero {
    padding: 7.5em 0 60px;
  }
}
.policy_hero h1 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.318;
}
@media screen and (max-width: 820px) {
  .policy_hero h1 {
    font-size: 2em;
  }
}

.policy_sec_01 {
  margin-bottom: 7.5em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .policy_sec_01 {
    font-size: 0.9375em;
    margin-bottom: 5em;
  }
}
.policy_sec_01 ul li {
  text-indent: -1em;
  padding-left: 1em;
}
.policy_sec_01 h3 {
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
  margin: 3.1em 0 1em;
}
.policy_sec_01 table {
  width: 100%;
  max-width: 720px;
  line-height: 1.5;
}
.policy_sec_01 table tr th {
  width: 104px;
  border-left: 1px solid #003D25;
  border-bottom: 1px solid #003D25;
  border-right: 1px solid #003D25;
  background-color: #F1F4F3;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-align: center;
  vertical-align: middle;
}
.policy_sec_01 table tr td {
  border-bottom: 1px solid #003D25;
  border-right: 1px solid #003D25;
  padding: 8px 1.25em;
}
.policy_sec_01 table tr:nth-child(1) th, .policy_sec_01 table tr:nth-child(1) td {
  border-top: 1px solid #003D25;
}

.policy_sec_02 {
  margin-bottom: 4em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .policy_sec_02 {
    font-size: 0.9375em;
  }
}

.policy_sec_03 {
  margin-bottom: 4em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .policy_sec_03 {
    font-size: 0.9375em;
  }
}

.policy_sec_04 {
  margin-bottom: 0;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .policy_sec_04 {
    font-size: 0.9375em;
  }
}

.ttl_policy_01 {
  background-color: #E8F7EF;
  padding: 10px 1em;
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 30px;
}
@media screen and (max-width: 820px) {
  .ttl_policy_01 {
    font-size: 1.2em;
    margin-bottom: 20px;
  }
}

.ttl_policy_02 {
  margin-bottom: 1.25em;
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1.5;
  position: relative;
}
@media screen and (max-width: 820px) {
  .ttl_policy_02 {
    font-size: 1.125em;
  }
}
.ttl_policy_02:before {
  content: "";
  display: block;
  width: 50px;
  height: 1px;
  background-color: #003D25;
  position: absolute;
  top: 15px;
  right: calc(100% + 24px);
}
@media screen and (max-width: 820px) {
  .ttl_policy_02:before {
    content: none;
  }
}

.ttl_policy_03 {
  font-size: 1.25em;
  font-weight: 600;
  margin-bottom: 1.5em;
}
@media screen and (max-width: 820px) {
  .ttl_policy_03 {
    font-size: 1.125em;
  }
}

.ttl_policy_04 {
  margin-bottom: 1em;
  font-weight: 600;
  position: relative;
}
.ttl_policy_04:before {
  content: "";
  display: block;
  width: 50px;
  height: 1px;
  background-color: #003D25;
  position: absolute;
  top: 15px;
  right: calc(100% + 24px);
}
@media screen and (max-width: 820px) {
  .ttl_policy_04:before {
    content: none;
  }
}

.list_policy_01 {
  padding-left: 74px;
}
@media screen and (max-width: 820px) {
  .list_policy_01 {
    padding-left: 0;
  }
}
.list_policy_01 > li {
  margin-bottom: 4em;
}
@media screen and (max-width: 820px) {
  .list_policy_01 > li {
    margin-bottom: 3em;
  }
}
.list_policy_01 > li:last-child {
  margin-bottom: 0;
}

.list_policy_02 > li {
  margin-bottom: 1.8em;
}
.list_policy_02 > li:last-child {
  margin-bottom: 0;
}
.list_policy_02 > li h4 {
  font-weight: 600;
  margin-bottom: 0.25em;
}

.list_policy_03 {
  margin-top: 3em;
  padding-left: 74px;
}
@media screen and (max-width: 820px) {
  .list_policy_03 {
    margin-top: 2em;
    padding-left: 0;
  }
}
.list_policy_03 > li {
  margin-bottom: 2em;
}
.list_policy_03 > li:last-child {
  margin-bottom: 0;
}

.list_policy_04 > li {
  text-indent: -2.5em;
  padding-left: 2.5em;
}

.list_policy_num_01 > li {
  text-indent: -1.1875em;
  padding-left: 1.1875em;
}

.policy_dlist_01 dt {
  font-weight: 600;
}

.policy_dlist_02 dt {
  font-weight: 600;
}
.policy_dlist_02 dt:before {
  content: "［";
}
.policy_dlist_02 dt:after {
  content: "］";
}

.post_hero .ttl {
  font-size: 1.5em;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .post_hero .ttl {
    font-size: 1.375em;
  }
}
.post_hero .date {
  margin-top: 10px;
  font-size: 0.875em;
  font-weight: 600;
  opacity: 0.5;
}
@media screen and (max-width: 820px) {
  .post_hero .date {
    font-size: 0.75em;
  }
}

.post_content {
  padding-top: 5em;
  /* font-weight: 300; */
}
@media screen and (max-width: 820px) {
  .post_content {
    padding-top: 3.75em;
    font-size: 0.9375em;
  }
}
.post_content > *:first-child {
  margin-top: 0 !important;
}
.post_content p {
  margin-top: 1.8em;
}

.archive_hero_01 {
  padding: 150px 0 38px;
}
@media screen and (max-width: 820px) {
  .archive_hero_01 {
    padding: 7.5em 0 40px;
  }
}
.archive_hero_01 h1 {
  font-family: "Josefin Sans", sans-serif;
  font-size: 2.75em;
  font-weight: 600;
}
@media screen and (max-width: 820px) {
  .archive_hero_01 h1 {
    font-size: 2.2em;
  }
}

.archive_pickup {
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .archive_pickup {
    margin-bottom: 3.75em;
  }
}
.archive_pickup h2 {
  font-size: 1.25em;
  font-weight: 600;
  margin-bottom: 20px;
}
.archive_pickup--list {
  display: flex;
  gap: 2.5em 2.29%;
}
@media screen and (max-width: 820px) {
  .archive_pickup--list {
    flex-direction: column;
  }
}
.archive_pickup--list > li {
  width: 31.8066666667%;
}
@media screen and (max-width: 820px) {
  .archive_pickup--list > li {
    width: 100%;
  }
}

.archive_case {
  margin-bottom: 0;
}
.archive_case .inner_l:before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: #003D25;
  opacity: 0.3;
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .archive_case .inner_l:before {
    margin-bottom: 3.75em;
  }
}
.archive_case .container {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}
.archive_case h2 {
  font-size: 1.25em;
  font-weight: 600;
}
.archive_case--list {
  margin-top: 48px;
  display: flex;
  flex-wrap: wrap;
  gap: 52px 3.33%;
}
@media screen and (max-width: 820px) {
  .archive_case--list {
    gap: 2.5em;
  }
}
.archive_case--list > li {
  width: 31.1133333333%;
}
@media screen and (max-width: 820px) {
  .archive_case--list > li {
    width: 100%;
  }
}

.single-case-study .section_wrap {
  overflow: hidden;
}
.single-case-study .section_wrap > .inner_l {
  padding-bottom: 7.5em;
  position: relative;
}
.single-case-study .section_wrap > .inner_l:before {
  content: "";
  display: block;
  width: 200vw;
  height: 100%;
  background: linear-gradient(0deg, #f1f4f3 0%, #f1f4f3 90%, rgba(241, 244, 243, 0) 90%, rgba(241, 244, 243, 0) 100%);
  position: absolute;
  bottom: 0;
  left: -50vw;
}
@media screen and (max-width: 820px) {
  .single-case-study .section_wrap > .inner_l:before {
    background: linear-gradient(0deg, #f1f4f3 0%, #f1f4f3 97%, rgba(241, 244, 243, 0) 97%, rgba(241, 244, 243, 0) 100%);
  }
}

.case_hero {
  margin-bottom: 56px;
}
.case_hero .ttl {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.25em;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 820px) {
  .case_hero .ttl {
    font-size: 1.8em;
  }
}
.case_hero .client--wrap {
  margin-top: 1em;
}
.case_hero .client {
  font-size: 0.875em;
  /* font-weight: 300; */
  line-height: 1.5;
}

.case_content {
  padding-top: 4em;
}
.case_content .text {
  /* font-weight: 300; */
}
.case_content .image {
  margin-top: 2.2em;
}

.case_sec_01 {
  margin-bottom: 48px;
}

.case_sec_02 {
  margin-bottom: 48px;
}

.case_sec_03 {
  margin-bottom: 0;
}

.ttl_case_01 {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 0.9em;
}
@media screen and (max-width: 820px) {
  .ttl_case_01 {
    font-size: 1.5em;
  }
}
.ttl_case_01 .label {
  display: block;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "MS Pゴシック", "MS PGothic", sans-serif;
  font-size: 0.4666em;
  padding-bottom: 0.4em;
  letter-spacing: 0.3em;
  line-height: 1.6;
  width: -moz-fit-content;
  width: fit-content;
  border-bottom: 1px solid #003D25;
  margin-bottom: 1.5em;
}

.dlist_newly_case {
  margin-bottom: 376px !important;
}
@media screen and (max-width: 820px) {
  .dlist_newly_case {
    margin-bottom: 3.75em !important;
  }
}
.dlist_newly_case .top_case--card h3 {
  font-size: 1em;
}
.dlist_newly_case dd ul li {
  margin-bottom: 30px !important;
}

.related_case {
  position: relative;
  margin-bottom: 0;
  padding-top: 5em;
}
.related_case .inner_l:before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: rgba(0, 61, 37, 0.5);
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .related_case .inner_l:before {
    margin-bottom: 3.75em;
  }
}
.related_case dt {
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 1.75em;
}
.related_case dd ul {
  display: flex;
  gap: 2.5em 2.48%;
}
@media screen and (max-width: 820px) {
  .related_case dd ul {
    flex-wrap: wrap;
  }
}
.related_case dd ul li {
  width: 23.14%;
}
@media screen and (max-width: 820px) {
  .related_case dd ul li {
    width: 100%;
  }
}
.related_case .top_case--card .ttl {
  font-size: 1em;
  color: #003D25;
}
.related_case .top_case--card:hover .ttl {
  text-decoration: underline;
}

.column_cat_list {
  margin-top: 1em;
}
@media screen and (max-width: 820px) {
  .column_cat_list {
    margin-top: 1.5em;
  }
}
.column_cat_list ul {
  display: flex;
  flex-wrap: wrap;
  margin-left: -0.875em;
}
.column_cat_list ul li {
  border-right: 1px solid #003D25;
  padding: 0 0.875em;
}
@media screen and (max-width: 820px) {
  .column_cat_list ul li {
    padding: 0 0.5em;
  }
}
.column_cat_list ul li a {
  display: block;
  padding: 4px 1.125em;
  border-radius: 8px;
  font-size: 0.875em;
  font-weight: 600;
  line-height: 1.2;
}
@media screen and (max-width: 820px) {
  .column_cat_list ul li a {
    font-size: 0.8125em;
  }
}
.column_cat_list ul li a.is-current, .column_cat_list ul li a:hover {
  background-color: rgba(0, 61, 37, 0.15);
}

.column_hero {
  margin-bottom: 3.5em;
}
@media screen and (max-width: 820px) {
  .column_hero {
    margin-bottom: 2.5em;
  }
}
.column_hero .ttl {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 2.75em;
  font-weight: 500;
  line-height: 1.318;
}
@media screen and (max-width: 820px) {
  .column_hero .ttl {
    font-size: 1.875em;
  }
}
.column_hero .cat--wrap {
  margin-top: 1em;
}
.column_hero .cat {
  width: -moz-fit-content;
  width: fit-content;
  border: 1px solid #003D25;
  border-radius: 2px;
  padding: 4px 8px;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 1.5;
}

.layout_split_02 {
  position: relative;
  display: flex;
  gap: 3.75em 11.02%;
}
@media screen and (max-width: 820px) {
  .layout_split_02 {
    flex-direction: column;
  }
}
.layout_split_02 .box_left {
  flex-grow: 1;
  padding-left: 8.54%;
  position: relative;
}
@media screen and (max-width: 820px) {
  .layout_split_02 .box_left {
    padding-left: 0;
    display: flex;
    flex-direction: column;
  }
  .layout_split_02 .box_left .column_image {
    order: 1;
  }
  .layout_split_02 .box_left .column_author {
    order: 2;
  }
  .layout_split_02 .box_left .list_sns_share {
    order: 4;
  }
  .layout_split_02 .box_left .post_content {
    order: 3;
  }
  .layout_split_02 .box_left .single_pagination {
    order: 5;
  }
}
.layout_split_02 .box_left .list_sns_share {
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 820px) {
  .layout_split_02 .box_left .list_sns_share {
    position: static;
  }
}
.layout_split_02 .box_right {
  position: relative;
  flex-shrink: 0;
  width: 280px;
}
@media screen and (max-width: 820px) {
  .layout_split_02 .box_right {
    width: 100%;
  }
}
.layout_split_02 .box_right .banner_download {
  position: sticky;
  top: 104px;
}
@media screen and (max-width: 820px) {
  .layout_split_02 .box_right .banner_download {
    position: static;
  }
}

@media screen and (max-width: 820px) {
  .list_sns_share {
    margin-top: 2.5em;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 1em;
  }
}
.list_sns_share .label {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  aspect-ratio: 2/1;
  border: 1px solid #003D25;
  font-family: "Josefin Sans", sans-serif;
  font-size: 0.75em;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
  padding-top: 4px;
  margin-bottom: 1.3em;
}
@media screen and (max-width: 820px) {
  .list_sns_share .label {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 820px) {
  .list_sns_share ul {
    display: flex;
    justify-content: flex-end;
    gap: 1em;
  }
}
.list_sns_share ul li {
  width: 40px;
  margin-bottom: 1em;
}
@media screen and (max-width: 820px) {
  .list_sns_share ul li {
    width: 32px;
    margin-bottom: 0;
  }
}
.list_sns_share ul li:last-child {
  margin-bottom: 0;
}
.list_sns_share ul li a {
  display: block;
}

.column_image {
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 16px;
}

.column_author {
  padding-left: 72px;
  padding-bottom: 1em;
  border-bottom: 1px solid rgba(0, 61, 37, 0.3);
  background: url(../images/column_author_01.svg) no-repeat top left/48px;
}
.column_author .position {
  font-size: 0.75em;
  /* font-weight: 300; */
  opacity: 0.5;
}
.column_author .name {
  font-weight: 600;
}

.dlist_related_column,
.dlist_newly_case {
  margin-bottom: 3.75em;
}
.dlist_related_column dt,
.dlist_newly_case dt {
  font-size: 0.875em;
  font-weight: 600;
  padding-bottom: 10px;
  color: #1B1B1B;
  border-bottom: 1px solid rgba(27, 27, 27, 0.3);
  margin-bottom: 24px;
}
.dlist_related_column dd > ul > li,
.dlist_newly_case dd > ul > li {
  margin-bottom: 40px;
}
.dlist_related_column dd > ul > li:last-child,
.dlist_newly_case dd > ul > li:last-child {
  margin-bottom: 0;
}
.dlist_related_column dd .single_column--card .image,
.dlist_newly_case dd .single_column--card .image {
  display: block;
  overflow: hidden;
  aspect-ratio: 280/180;
  border-radius: 4px;
  margin-bottom: 1em;
}
.dlist_related_column dd .single_column--card .image img,
.dlist_newly_case dd .single_column--card .image img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.dlist_related_column dd .single_column--card h3,
.dlist_newly_case dd .single_column--card h3 {
  font-size: 0.875em;
  font-weight: 600;
  margin-bottom: 0.75em;
}
.dlist_related_column dd .single_column--card .cat,
.dlist_newly_case dd .single_column--card .cat {
  opacity: 0.65;
  border-radius: 2px;
  display: inline-block;
  border: 1px solid #003D25;
  padding: 0 0.66em;
  font-size: 0.75em;
  font-weight: 600;
  line-height: 2;
  margin-right: 6px;
}
.dlist_related_column dd .single_column--card .date,
.dlist_newly_case dd .single_column--card .date {
  font-size: 0.75em;
  font-weight: 600;
  line-height: 2;
}
.dlist_related_column dd .single_column--card:hover img,
.dlist_newly_case dd .single_column--card:hover img {
  transform: scale(1.05);
}
.dlist_related_column dd .single_column--card:hover h3,
.dlist_newly_case dd .single_column--card:hover h3 {
  text-decoration: underline;
}

.dlist_cat_column {
  margin-bottom: 25em;
}
@media screen and (max-width: 820px) {
  .dlist_cat_column {
    margin-bottom: 3.75em;
  }
}
.dlist_cat_column dt {
  font-size: 0.875em;
  font-weight: 600;
  padding-bottom: 10px;
  color: #1B1B1B;
  border-bottom: 1px solid rgba(27, 27, 27, 0.3);
  margin-bottom: 24px;
}
.dlist_cat_column dd {
  color: #1B1B1B;
}
.dlist_cat_column dd ul li {
  margin-bottom: 4px;
}
.dlist_cat_column dd ul li a {
  font-family: 0.75em;
  font-weight: 600;
  display: block;
  padding: 0.1em 8px;
}
.dlist_cat_column dd ul li a.is-current, .dlist_cat_column dd ul li a:hover {
  background-color: #F1F4F3;
}
.dlist_cat_column dd ul li:first-child a {
  font-size: 0.875em;
  /* font-weight: 300; */
  padding: 0;
}
.dlist_cat_column dd ul li:first-child a:hover {
  background-color: transparent;
  font-weight: 600;
  opacity: 0.7;
}

.related_column {
  margin-bottom: 0;
  padding-top: 7.5em;
}
@media screen and (max-width: 820px) {
  .related_column {
    padding-top: 5em;
  }
}
.related_column .inner_l:before {
  content: "";
  display: block;
  width: 100%;
  height: 1px;
  background-color: rgba(0, 61, 37, 0.5);
  margin-bottom: 5em;
}
@media screen and (max-width: 820px) {
  .related_column .inner_l:before {
    margin-bottom: 3.75em;
  }
}
.related_column dt {
  font-weight: 600;
  line-height: 1.5;
  margin-bottom: 1.75em;
}
.related_column dd ul {
  display: flex;
  gap: 2.5em 2.48%;
}
@media screen and (max-width: 820px) {
  .related_column dd ul {
    flex-wrap: wrap;
  }
}
.related_column dd ul li {
  width: 23.14%;
}
@media screen and (max-width: 820px) {
  .related_column dd ul li {
    width: 100%;
  }
}
.related_column .top_column--card .ttl {
  font-size: 1em;
  color: #003D25;
}
.related_column .top_column--card:hover .ttl {
  text-decoration: underline;
}

.error404_ttl {
  font-family: "Shippori Mincho", "Noto Serif JP", "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
  font-size: 1.875em;
  font-weight: 600;
  line-height: 1.5;
}
.error404_text {
  margin-top: 3.75em;
  /* font-weight: 300; */
}
.error404_link {
  margin-top: 3.75em;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 176px;
  height: 48px;
  border-radius: 50px;
  background-color: #003D25;
  color: #fff;
  font-size: 0.875em;
  font-weight: 600;
}
.error404_link:hover {
  background-color: #00AE68;
}