/*!*********************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[3].use[3]!./src/scss/design.scss ***!
  \*********************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/*-------------------------------------------------------------------------------
  media query
--------------------------------------------------------------------------------*/
/*-------------------------------------------------------------------------------
  font setting
--------------------------------------------------------------------------------*/
/*-------------------------------------------------------------------------------
  color setting
--------------------------------------------------------------------------------*/
/*-------------------------------------------------------------------------------
  space setting
--------------------------------------------------------------------------------*/
/*-------------------------------------------------------------------------------
  border setting
--------------------------------------------------------------------------------*/
/*!
 * ress.css v1.0.0
 * MIT License
 * top_original reset
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  box-sizing: border-box;
  overflow-y: scroll; /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%; /* iOS 8+ */
}

*,
::before,
::after {
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  padding: 0; /* Reset `padding` and `margin` of all elements */
  margin: 0;
}
*:focus {
  outline: none;
}

/* # =================================================================
   # General elements
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0;
}

hr {
  overflow: visible; /* Show the overflow in Edge and IE */
}

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
html,
body,
p,
ol,
ul,
li,
dl,
dt,
dd,
blockquote,
figure,
fieldset,
legend,
textarea,
pre,
iframe,
hr,
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  padding: 0;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

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

ul {
  list-style: none;
}

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

td,
th {
  padding: 0;
  font-weight: normal;
  text-align: left;
}

summary {
  display: list-item; /* Add the correct display in all browsers */
}

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden],
template {
  display: none; /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: 1px dotted; /* Add a bordered underline effect in all browsers */
  text-decoration: none; /* Remove text decoration in Firefox 40+ */
}

a {
  background-color: transparent; /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects; /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
}

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

b,
strong {
  font-weight: bolder; /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */
}

dfn {
  font-style: italic; /* Address styling not present in Safari and Chrome */
}

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000;
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

[type=number] {
  width: auto; /* Firefox 36+ */
}

[type=search] {
  -webkit-appearance: textfield; /* Safari 8+ */
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none; /* Safari 8 */
}

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit; /* Specify font inheritance of form elements */
  margin: 0;
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule. */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: 0;
  padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
  color: inherit;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
}

::-webkit-file-upload-button {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

[type=search] {
  -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px; /* Correct the outline style in Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none; /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

svg:not(:root) {
  overflow: hidden; /* Internet Explorer 11- */
}

audio,
canvas,
progress,
video {
  display: inline-block; /* Internet Explorer 11+, Windows Phone 8.1+ */
}

iframe {
  border: 0;
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

/* # =================================================================
   # Selection
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc; /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

::selection {
  background-color: #b3d4fc; /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

/*-------------------------------------------------------------------------------
  default style
--------------------------------------------------------------------------------*/
* {
  box-sizing: border-box;
  word-break: break-all;
}

html {
  font-size: 100%;
}

/**
 * メディアクエリ
 *
 * @param {number} $size 画面サイズ
 * @param {string} $width max or min
 * @param {string} $orientation デバイスの向き portrait or landscape
 */
/**
 * 単位を除いた数値を返す
 *
 * @param {number} $value 単位あり数値
 * @return {number} 単位なし数値
 * @example strip-unit(16px) => 16
 *          strip-unit(1rem) => 1
 */
/**
 * pxをremで返す
 *
 * @param {number} $number pxサイズ
 * @return {number} 単位ありremサイズ
 * @example $root-font-size : 16px の場合
 *          rem(10) 10px => 0.625rem
 */
/**
 * clampを使用した可変サイズ指定関数
 *
 * @param {number} $min-size 最小サイズpx
 * @param {number} $max-size 最大サイズpx
 * @param {number} $min-viewport-px 最小ビューポートpx
 * @param {number} $max-viewport-px 最大ビューポートpx
 * @return {string} clamp
 * @example fluid(16, 32) => clamp(1rem, 1.67vw + 0.667rem, 2rem)
 *           320pxから1280pxの間で16pxから32pxまでサイズが変わる
 *          fluid(10px, 18px, 480px, 1024px) => clamp(0.625rem, 1.47vw + 0.184rem, 1.125rem)
 *           480pxから1024pxの間で10pxから18pxまでサイズが変わる
 */
/**
 * フォントサイズ
 *
 * @param {number} $pixel フォントサイズ、px基準で指定
 */
/**
 * 可変フォントサイズ
 *
 * @param {number} $min-px 最小サイズpx
 * @param {number} $max-px 最大サイズpx
 * @param {number} $min-viewport-px 最小ビューポートpx
 * @param {number} $max-viewport-px 最大ビューポートpx
 */
/**
 * トランジション
 *
 * @param {number} $time トランジションの時間
 * @param {string} $easing イージングの指定
 */
/**
 * 疑似要素を使用したアイコンフォント
 *
 * @param {string} $code アイコンコード
 * @param {number} $size フォントサイズ
 * @param {number} $weight フォントウェイト
 * @param {string} $color フォントカラー
 * @param {string} $family フォントファミリー Material Symbols Outlined or Font Awesome 6 Pro
 */
/**
 * スクロールバー
 *
 * @param {number} $width 横幅
 * @param {number} $track-color トラックの色
 * @param {number} $thumb-color スクロールバーの色
 */
/**
 * フォント一括設定
 *
 * @param {number} $fontWeight フォントの太さ
 * @param {number} $letterSpacing 文字間
 * @param {number} $lineHeight 行間
 * @param {string} $fontFamily フォントファミリー
 */
/*-------------------------------------------------------------------------------
  form 設定
--------------------------------------------------------------------------------*/
.contact_form_unit {
  /* 全体の余白変数 */
  --space-size: 10px;
  --head-width: 250px;
  /* ラジオボタン変数 */
  --radio-outer: 20px;
  --radio-inner: 10px;
  /* チェックボックス変数 */
  --checkbox-outer: 20px;
  --checkbox-inner: 10px;
  /* スクロールバー変数 */
  --scroll-width: 5px;
  --track-color: #ffffff;
  --thumb-color: #09B464;
  padding-top: calc(var(--space-size) * 6);
  /* テーブル・リスト */
}
.contact_form_unit table {
  border-collapse: separate;
  border-spacing: 0 var(--space-size);
}
.contact_form_unit dl {
  display: flex;
  margin-top: var(--space-size);
}
.contact_form_unit dl dt {
  flex-shrink: 0;
  height: -moz-fit-content;
  height: fit-content;
  padding: var(--space-size) 0;
}
.contact_form_unit tr th, .contact_form_unit tr dt, .contact_form_unit dl th, .contact_form_unit dl dt {
  width: var(--head-width);
  display: flex;
  align-items: center;
  gap: calc(var(--space-size) * 2);
}
.contact_form_unit tr th .item_label_required, .contact_form_unit tr dt .item_label_required, .contact_form_unit dl th .item_label_required, .contact_form_unit dl dt .item_label_required {
  padding: 0.1em 0.5em;
  color: #ffffff;
  background-color: #09B464;
  border-radius: 5px;
}
.contact_form_unit tr th .item_label_required > span, .contact_form_unit tr dt .item_label_required > span, .contact_form_unit dl th .item_label_required > span, .contact_form_unit dl dt .item_label_required > span {
  display: block;
  font-size: 0.8rem;
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  width: 100%;
}
@media (max-width: 768px) {
  .contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
    display: block;
    margin-top: var(--space-size);
  }
}
.contact_form_unit tr td > input,
.contact_form_unit tr td > select,
.contact_form_unit tr td > textarea, .contact_form_unit tr dd > input,
.contact_form_unit tr dd > select,
.contact_form_unit tr dd > textarea, .contact_form_unit dl td > input,
.contact_form_unit dl td > select,
.contact_form_unit dl td > textarea, .contact_form_unit dl dd > input,
.contact_form_unit dl dd > select,
.contact_form_unit dl dd > textarea {
  padding: var(--space-size) calc(var(--space-size) * 2);
  background-color: #F4FFC3;
  border-radius: 5px;
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  /* セレクトボックス */
}
.contact_form_unit tr td:has(select), .contact_form_unit tr dd:has(select), .contact_form_unit dl td:has(select), .contact_form_unit dl dd:has(select) {
  position: relative;
}
.contact_form_unit tr td:has(select)::before, .contact_form_unit tr dd:has(select)::before, .contact_form_unit dl td:has(select)::before, .contact_form_unit dl dd:has(select)::before {
  content: "▼";
  position: absolute;
  top: 50%;
  right: calc(var(--space-size) * 2);
  transform: translateY(-50%);
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  /* テキストエリア */
}
.contact_form_unit tr td textarea, .contact_form_unit tr dd textarea, .contact_form_unit dl td textarea, .contact_form_unit dl dd textarea {
  height: 200px;
  display: block;
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  /* ラジオボタン */
}
.contact_form_unit tr td .radio_list > li label input[type=radio], .contact_form_unit tr dd .radio_list > li label input[type=radio], .contact_form_unit dl td .radio_list > li label input[type=radio], .contact_form_unit dl dd .radio_list > li label input[type=radio] {
  display: none;
}
.contact_form_unit tr td .radio_list > li label input[type=radio] + .radio_text, .contact_form_unit tr dd .radio_list > li label input[type=radio] + .radio_text, .contact_form_unit dl td .radio_list > li label input[type=radio] + .radio_text, .contact_form_unit dl dd .radio_list > li label input[type=radio] + .radio_text {
  display: flex;
  align-items: center;
  gap: var(--space-size);
  position: relative;
}
.contact_form_unit tr td .radio_list > li label input[type=radio] + .radio_text::before, .contact_form_unit tr dd .radio_list > li label input[type=radio] + .radio_text::before, .contact_form_unit dl td .radio_list > li label input[type=radio] + .radio_text::before, .contact_form_unit dl dd .radio_list > li label input[type=radio] + .radio_text::before {
  content: "";
  width: var(--radio-outer);
  aspect-ratio: 1;
  flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid #595959;
}
.contact_form_unit tr td .radio_list > li label input[type=radio] + .radio_text::after, .contact_form_unit tr dd .radio_list > li label input[type=radio] + .radio_text::after, .contact_form_unit dl td .radio_list > li label input[type=radio] + .radio_text::after, .contact_form_unit dl dd .radio_list > li label input[type=radio] + .radio_text::after {
  content: "";
  width: var(--radio-inner);
  aspect-ratio: 1;
  border-radius: 50%;
  position: absolute;
  left: calc((var(--radio-outer) - var(--radio-inner)) / 2);
  transition: all 0.3s ease;
}
.contact_form_unit tr td .radio_list > li label input[type=radio]:checked + span::after, .contact_form_unit tr dd .radio_list > li label input[type=radio]:checked + span::after, .contact_form_unit dl td .radio_list > li label input[type=radio]:checked + span::after, .contact_form_unit dl dd .radio_list > li label input[type=radio]:checked + span::after {
  background-color: #595959;
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  /* チェックボックス */
}
.contact_form_unit tr td .check_list > li .label_checkbox .check_text, .contact_form_unit tr dd .check_list > li .label_checkbox .check_text, .contact_form_unit dl td .check_list > li .label_checkbox .check_text, .contact_form_unit dl dd .check_list > li .label_checkbox .check_text {
  display: flex;
  align-items: center;
  gap: var(--space-size);
  position: relative;
}
.contact_form_unit tr td .check_list > li .label_checkbox .check_text::before, .contact_form_unit tr dd .check_list > li .label_checkbox .check_text::before, .contact_form_unit dl td .check_list > li .label_checkbox .check_text::before, .contact_form_unit dl dd .check_list > li .label_checkbox .check_text::before {
  content: "";
  width: var(--checkbox-outer);
  aspect-ratio: 1;
  border: 1px solid #595959;
}
.contact_form_unit tr td .check_list > li .label_checkbox .check_text::after, .contact_form_unit tr dd .check_list > li .label_checkbox .check_text::after, .contact_form_unit dl td .check_list > li .label_checkbox .check_text::after, .contact_form_unit dl dd .check_list > li .label_checkbox .check_text::after {
  content: "";
  width: var(--checkbox-inner);
  aspect-ratio: 1;
  position: absolute;
  top: calc(50% - var(--checkbox-inner) / 2);
  left: calc((var(--checkbox-outer) - var(--checkbox-inner)) / 2);
  transition: all 0.3s ease;
}
.contact_form_unit tr td .check_list > li .label_checkbox .check_text.checked::after, .contact_form_unit tr dd .check_list > li .label_checkbox .check_text.checked::after, .contact_form_unit dl td .check_list > li .label_checkbox .check_text.checked::after, .contact_form_unit dl dd .check_list > li .label_checkbox .check_text.checked::after {
  background: #595959;
}
.contact_form_unit tr td, .contact_form_unit tr dd, .contact_form_unit dl td, .contact_form_unit dl dd {
  /* ファイルアップロード */
}
.contact_form_unit tr td .uploaded_file p span, .contact_form_unit tr dd .uploaded_file p span, .contact_form_unit dl td .uploaded_file p span, .contact_form_unit dl dd .uploaded_file p span {
  font-size: 0.8rem;
  margin-left: 0.5rem;
}
.contact_form_unit {
  /* プライバシーポリシー */
}
.contact_form_unit .form_privacy_unit {
  margin-top: calc(var(--space-size) * 3);
}
.contact_form_unit .form_privacy_unit .form_privacy_block {
  padding: calc(var(--space-size) * 3);
  background-color: #F4FFC3;
  border-radius: 5px;
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_ttl {
  font-weight: bold;
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item {
  height: 200px;
  margin-top: calc(var(--space-size) * 2);
  overflow-y: scroll;
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item::-webkit-scrollbar {
  width: var(--scroll-width);
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item::-webkit-scrollbar-track {
  background: var(--track-color);
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item::-webkit-scrollbar-thumb {
  background: var(--thumb-color);
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item .privacy_text {
  padding-right: calc(var(--space-size) * 2);
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item .privacy_text + .privacy_text {
  margin-top: 1em;
}
.contact_form_unit .form_privacy_unit .form_privacy_block .form_privacy_item .privacy_text .highlight {
  display: block;
  font-weight: bold;
}
.contact_form_unit .form_privacy_unit {
  /* プライバシーポリシー同意 checkbox */
}
.contact_form_unit .form_privacy_unit .form_privacy_check {
  width: -moz-fit-content;
  width: fit-content;
  margin: calc(var(--space-size) * 2) auto 0;
}
.contact_form_unit .form_privacy_unit .form_privacy_check .label_checkbox .check_text {
  display: flex;
  align-items: center;
  gap: var(--space-size);
  position: relative;
}
.contact_form_unit .form_privacy_unit .form_privacy_check .label_checkbox .check_text::before {
  content: "";
  width: var(--checkbox-outer);
  aspect-ratio: 1;
  border: 1px solid #595959;
}
.contact_form_unit .form_privacy_unit .form_privacy_check .label_checkbox .check_text::after {
  content: "";
  width: var(--checkbox-inner);
  aspect-ratio: 1;
  position: absolute;
  top: calc(50% - var(--checkbox-inner) / 2);
  left: calc((var(--checkbox-outer) - var(--checkbox-inner)) / 2);
  transition: all 0.3s ease;
}
.contact_form_unit .form_privacy_unit .form_privacy_check .label_checkbox .check_text.checked::after {
  background: #595959;
}
.contact_form_unit .form_privacy_unit .form_privacy_check .policy_error {
  text-align: center;
}
.contact_form_unit {
  /* 送信ボタン */
}
.contact_form_unit .form_actions {
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  gap: calc(var(--space-size) * 10);
  margin: calc(var(--space-size) * 4) auto 0;
}
@media (max-width: 768px) {
  .contact_form_unit .form_actions {
    flex-direction: column;
    gap: calc(var(--space-size) * 2);
  }
}
.contact_form_unit .form_actions .btn_contact_submit.disable > span {
  display: block;
  color: #e75b74;
}
.contact_form_unit {
  /* ハニーポット非表示 */
}
.contact_form_unit input[name=mail_confirm] {
  display: none;
}
.contact_form_unit {
  /* エラーメッセージの指定 */
}
.contact_form_unit .item_error_list,
.contact_form_unit .policy_error {
  margin-top: 0.2rem;
  font-size: 0.8rem;
  color: #e75b74;
}
.contact_form_unit {
  /* エラー時の背景色 */
}
.contact_form_unit.form_input .has_error {
  background-color: rgba(231, 91, 116, 0.1);
}
.contact_form_unit {
  /* 確認画面 */
}
.contact_form_unit.form_confirm table {
  border-spacing: 0 calc(var(--space-size) * 4);
}
.contact_form_unit.form_confirm dl {
  margin-top: calc(var(--space-size) * 4);
}
.contact_form_unit {
  /* 送信完了画面 */
}
.contact_form_unit.form_thanks h3 {
  font-size: 27px;
  font-size: 1.6875rem;
}
.contact_form_unit.form_thanks p {
  margin-top: calc(var(--space-size) * 3);
}

/*-------------------------------------------------------------------------------
  loading item
--------------------------------------------------------------------------------*/
.loading_mask {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  background: #09B464;
  z-index: 9999;
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

/*-------------------------------------------------------------------------------
  modal image
--------------------------------------------------------------------------------*/
.modal-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
}
.modal-wrapper .modal-close {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 1000;
}
.modal-wrapper .modal-close > span {
  display: block;
  font-size: clamp(1.875rem, 1.3661202186vw + 1.2192622951rem, 2.5rem);
  color: #ffffff;
}
.modal-wrapper .modal-inner {
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 10px;
}
.modal-wrapper .modal-inner .modal-item .modal-img,
.modal-wrapper .modal-inner .modal-item .modal-iframe {
  max-width: 90vw;
  max-height: 90vh;
  vertical-align: bottom;
}
@media (max-width: 768px) {
  .modal-wrapper .modal-inner .modal-item .modal-img,
  .modal-wrapper .modal-inner .modal-item .modal-iframe {
    max-width: 100vmin;
  }
}
.modal-wrapper .modal-inner .modal-gallery {
  width: 100%;
}
.modal-wrapper .modal-inner .modal-gallery .modal-btns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.modal-wrapper .modal-inner .modal-gallery .modal-btns .modal-count > span,
.modal-wrapper .modal-inner .modal-gallery .modal-btns .modal-prev > span,
.modal-wrapper .modal-inner .modal-gallery .modal-btns .modal-next > span {
  display: block;
  font-size: clamp(1rem, 0.5464480874vw + 0.737704918rem, 1.25rem);
  letter-spacing: 0.4em;
  margin-right: -0.4em;
  color: #ffffff;
}
.modal-wrapper .modal-inner .modal-gallery .modal-btns {
  /* ← が表示されてないときに真ん中に表示したい用 */
}
.modal-wrapper .modal-inner .modal-gallery .modal-btns {
  /* → が表示されてないときに真ん中に表示したい用 */
}
.modal-wrapper button:focus {
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.5), -2px 0 15px rgba(0, 229, 154, 0.2), 2px 0 15px rgba(9, 180, 100, 0.5);
}

/*-------------------------------------------------------------------------------
  一覧ページのページャ
--------------------------------------------------------------------------------*/
.pagination_unit {
  display: flex;
}
.pagination_unit .pagination_prev button.hidden, .pagination_unit .pagination_next button.hidden {
  visibility: hidden;
}

.pagination_btns_list {
  display: flex;
}
.pagination_btns_list li.current {
  pointer-events: none;
}

/*-------------------------------------------------------------------------------
  詳細ページのページャ
--------------------------------------------------------------------------------*/
.single-pager_unit {
  display: flex;
}

/*-------------------------------------------------------------------------------
  body global
--------------------------------------------------------------------------------*/
body {
  font-size: 18px;
  font-size: 1.125rem;
  color: #333333;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  line-height: 1.8;
  background: #ffffff;
  overflow-x: hidden;
}

/*-------------------------------------------------------------------------------
  img global
--------------------------------------------------------------------------------*/
img {
  max-width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/*-------------------------------------------------------------------------------
  link global
--------------------------------------------------------------------------------*/
a {
  color: #09B464;
  text-decoration: none;
}
@media (min-width: 769px) {
  a {
    transition: all 0.3s ease;
  }
}
a[href], a[data-href] {
  cursor: pointer;
}

/*-------------------------------------------------------------------------------
  table global
--------------------------------------------------------------------------------*/
table {
  width: 100%;
}
table th {
  font-weight: bold;
  vertical-align: text-top;
}
table th,
table td {
  text-align: left;
}

/*-------------------------------------------------------------------------------
  text global
--------------------------------------------------------------------------------*/
strong,
b {
  font-weight: bold;
}

em {
  font-style: italic;
}

/*-------------------------------------------------------------------------------
  input global
--------------------------------------------------------------------------------*/
input[type=text],
input[type=tel],
input[type=email],
input[type=url],
input[type=search],
input[type=password],
input[type=number],
input[type=file],
input[type=date],
textarea {
  width: 100%;
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
}
input[type=text]::-moz-placeholder, input[type=tel]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=file]::-moz-placeholder, input[type=date]::-moz-placeholder, textarea::-moz-placeholder {
  color: #d5d5d5;
}
input[type=text]::placeholder,
input[type=tel]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=search]::placeholder,
input[type=password]::placeholder,
input[type=number]::placeholder,
input[type=file]::placeholder,
input[type=date]::placeholder,
textarea::placeholder {
  color: #d5d5d5;
}

select,
label {
  width: 100%;
  cursor: pointer;
}

/*-------------------------------------------------------------------------------
  input button global
--------------------------------------------------------------------------------*/
input[type=submit],
input[type=reset],
input[type=button],
button {
  cursor: pointer;
}
@media (min-width: 769px) {
  input[type=submit],
  input[type=reset],
  input[type=button],
  button {
    transition: all 0.3s ease;
  }
}

/*-------------------------------------------------------------------------------
  cmn
--------------------------------------------------------------------------------*/
::-webkit-scrollbar {
  background: #e4e4e4;
  width: 5px;
}

::-webkit-scrollbar-thumb {
  background-color: #0db77d;
}

html {
  scroll-behavior: smooth;
}

body {
  position: relative;
}
body::after {
  position: absolute;
  content: "";
  top: clamp(11.25rem, 42.9487179487vw + -1.6346153846rem, 32.1875rem);
  left: 0;
  width: 100%;
  height: clamp(18.75rem, 38.4615384615vw + 7.2115384615rem, 37.5rem);
  background: #F4FFC3;
  z-index: -2;
}
body.index::after {
  height: clamp(37.5rem, 51.2820512821vw + 22.1153846154rem, 62.5rem);
  top: clamp(15.625rem, 60.2564102564vw + -2.4519230769rem, 45rem);
}

/*---------- sp link tel ----------*/
a[href=""] {
  pointer-events: none;
}
a[href^="tel:"] {
  cursor: default;
  pointer-events: none;
}
@media (max-width: 768px) {
  a[href^="tel:"] {
    pointer-events: auto;
  }
}

/*---------- br ----------*/
@media (min-width: 769px) {
  .sp_only {
    display: none;
  }
}

@media (max-width: 768px) {
  .pc_only {
    display: none;
  }
}

@media (max-width: 560px) {
  .pad_over {
    display: none;
  }
}

@media (min-width: 561px) {
  .pad_under {
    display: none;
  }
}

/*---------- boxer --------*/
.boxer {
  width: 100%;
  height: 100%;
  overflow: hidden;
  vertical-align: top;
  transition: all 0.3s ease;
}
.boxer img {
  transition: all 0.3s ease;
}
.boxer + .boxer {
  display: none;
}
@media (min-width: 769px) {
  .boxer:hover {
    opacity: 1;
  }
  .boxer:hover img {
    transform: scale(1.1);
  }
}
@media (min-width: 769px) and (max-width: 768px) {
  .boxer:hover img {
    transform: none;
  }
}

/*---------- center ----------*/
.center {
  margin: 0 auto;
  text-align: center;
}
@media (max-width: 768px) {
  .center {
    text-align: left;
  }
}

/*---------- color ----------*/
.color_white {
  color: #fff;
}

/*---------- aタグ処理 ----------*/
a {
  display: block;
  cursor: pointer;
}

/*---------- アニメーション ----------*/
@keyframes slideInOutX {
  0% {
    transform: translateX(0%) rotate(-180deg);
    opacity: 1;
  }
  48% {
    transform: translateX(-100%) rotate(-180deg);
    opacity: 0;
  }
  49% {
    transform: translateX(-100%) rotate(-180deg);
    opacity: 0;
  }
  50% {
    transform: translateX(100%) rotate(-180deg);
    opacity: 0;
  }
  51% {
    transform: translateX(100%) rotate(-180deg);
    opacity: 1;
  }
  100% {
    transform: translateX(0%) rotate(-180deg);
    opacity: 1;
  }
}
@keyframes slideOutinX {
  0% {
    transform: translateX(0%);
    opacity: 1;
  }
  48% {
    transform: translateX(100%);
    opacity: 0;
  }
  49% {
    transform: translateX(100%);
    opacity: 0;
  }
  50% {
    transform: translateX(-100%);
    opacity: 0;
  }
  51% {
    transform: translateX(-100%);
    opacity: 1;
  }
  100% {
    transform: translateX(0%);
    opacity: 1;
  }
}
/*---------- 基本ロゴ ----------*/
.cmn_logo {
  display: inline-block;
  position: relative;
  color: #333;
  font-weight: 700;
  letter-spacing: calc(10 * 0.001em);
  line-height: 1.2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.5rem, 1.0256410256vw + 1.1923076923rem, 2rem);
}
.cmn_logo.color_white {
  color: #fff;
}

/*---------- タイトル ----------*/
.cmn_ttl {
  position: relative;
  display: block;
  margin-bottom: clamp(1.875rem, 2.5641025641vw + 1.1057692308rem, 3.125rem);
}

.cmn_ttl_en {
  display: block;
  word-break: keep-all;
  overflow-wrap: normal;
  white-space: normal;
  color: rgba(209, 244, 13, 0.8);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.75rem, 6.9565217391vw + 0.9239130435rem, 8.75rem);
  margin-left: -0.2%;
}
.color_white .cmn_ttl_en {
  color: #fff;
}
.cmn_ttl_en.index_service_en {
  position: absolute;
  color: rgba(0, 229, 154, 0.8);
  font-size: clamp(4rem, 6.9565217391vw + 2.1739130435rem, 10rem);
  mix-blend-mode: multiply;
  top: clamp(0.625rem, 6.4102564103vw + -1.2980769231rem, 3.75rem);
  right: -0.3%;
  white-space: nowrap;
  z-index: 1;
}
.cmn_ttl_en.index_strengths_en {
  position: absolute;
  font-size: clamp(4rem, 6.9565217391vw + 2.1739130435rem, 10rem);
  top: clamp(0.625rem, 6.4102564103vw + -1.2980769231rem, 3.75rem);
  left: -0.3%;
  white-space: nowrap;
}

.cmn_ttl_ja {
  display: block;
  position: relative;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.0625rem, 1.6666666667vw + 0.5625rem, 1.875rem);
  color: #333;
  margin-top: clamp(0.3125rem, 3.2051282051vw + -0.6490384615rem, 1.875rem);
  padding-left: clamp(1.5625rem, 2.5641025641vw + 0.7932692308rem, 2.8125rem);
  white-space: nowrap;
}
.cmn_ttl_ja::before {
  display: block;
  position: absolute;
  content: "";
  left: 0;
  top: 54%;
  width: clamp(1.0625rem, 1.6666666667vw + 0.5625rem, 1.875rem);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #009443;
  transform: translateY(-50%);
}
.color_white .cmn_ttl_ja {
  color: #fff;
}
.color_white .cmn_ttl_ja::before {
  background: #fff;
}

.cmn_sttl {
  display: block;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.5;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.0625rem, 0.8974358974vw + 0.7932692308rem, 1.5rem);
  color: #009443;
}

/*---------- 基本テキスト ----------*/
.cmn_txt_lg {
  position: relative;
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.3846153846vw + 0.8221153846rem, 1.125rem);
}
@media (max-width: 1024px) {
  .cmn_txt_lg {
    line-height: 1.75;
  }
}

.cmn_txt_md {
  position: relative;
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.2564102564vw + 0.7980769231rem, 1rem);
}
@media (max-width: 768px) {
  .cmn_txt_md {
    line-height: 1.5;
  }
}

/*---------- 基本コンテナ ----------*/
:root {
  --wrapper_width: 1600px;
}

.base_wrapper {
  width: 100%;
  max-width: calc(var(--wrapper_width) + 16vw);
  margin: 0 auto;
  padding: 0 8vw;
}
@media (max-width: 768px) {
  .base_wrapper {
    padding: 0 4vw;
  }
}

.base_wrapper--narrow {
  padding: 0 4vw;
}
@media (max-width: 1024px) {
  .base_wrapper--narrow {
    padding: 0;
  }
}

/*---------- 背景白の入れ物 ----------*/
.bg_wrapper {
  position: relative;
  width: 100%;
  border-top-left-radius: clamp(2.5rem, 10.2564102564vw + -0.5769230769rem, 7.5rem);
  border-top-right-radius: clamp(2.5rem, 10.2564102564vw + -0.5769230769rem, 7.5rem);
}
.bg_wrapper.bg_gradation {
  background: url(../images/bg_gra.jpg) repeat-y right top;
  overflow: hidden;
}
.bg_wrapper.bg_yellow {
  background: #F4FFC3;
  padding-top: clamp(3.125rem, 12.8205128205vw + -0.7211538462rem, 9.375rem);
  overflow: hidden;
  z-index: 1;
}
.bg_wrapper.bg_white {
  background: #fff;
  padding-top: clamp(3.125rem, 12.8205128205vw + -0.7211538462rem, 9.375rem);
  overflow: hidden;
}
.bg_wrapper.bg_inner-page {
  background: #fff;
  padding-top: clamp(1.875rem, 6.4102564103vw + -0.0480769231rem, 5rem);
  padding-bottom: clamp(5rem, 15.3846153846vw + 0.3846153846rem, 12.5rem);
  margin-top: clamp(5rem, 15.3846153846vw + 0.3846153846rem, 12.5rem);
}

/*---------- カテゴリーリスト ----------*/
.category_list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.625rem, 1.7948717949vw + 0.0865384615rem, 1.5rem);
  margin-bottom: clamp(1.875rem, 8.9743589744vw + -0.8173076923rem, 6.25rem);
}
.category_list.archive_list {
  justify-content: center;
  margin-bottom: clamp(1.875rem, 7.6923076923vw + -0.4326923077rem, 5.625rem);
}
.category_li a {
  display: block;
  padding: clamp(0.75rem, 1.0256410256vw + 0.4423076923rem, 1.25rem) clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem) clamp(0.75rem, 1.0256410256vw + 0.4423076923rem, 1.25rem);
  background: #D1F40D;
  border-radius: 30px;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.3846153846vw + 0.8221153846rem, 1.125rem);
  transition: all 0.3s ease;
}
.category_li a:hover {
  background: #009443;
  color: #D1F40D;
}
.category_li.current span {
  display: block;
  padding: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem) clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  background: #009443;
  color: #D1F40D;
  border-radius: 30px;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.3846153846vw + 0.8221153846rem, 1.125rem);
  transition: all 0.3s ease;
}

/*---------- 基本ボタン ----------*/
.cmn_btn_wrapper {
  position: relative;
  margin-top: clamp(1.875rem, 6.4102564103vw + -0.0480769231rem, 5rem);
}

.cmn_btn_link {
  position: relative;
  z-index: 1;
  display: inline-flex;
  gap: clamp(0.5rem, 0.641025641vw + 0.3076923077rem, 0.8125rem);
  height: clamp(3.75rem, 3.3333333333vw + 2.75rem, 5.375rem);
  border-radius: 60px;
  overflow: hidden;
}
.cmn_btn_link::before {
  position: absolute;
  content: "";
  inset: 0;
  border-radius: 60px;
  background: #009443;
  z-index: -1;
  transform: translateX(101%);
}
@media (min-width: 769px) {
  .cmn_btn_link:hover::before {
    transform: translateX(0);
    transition: transform 0.5s ease;
    background-color: #009443;
  }
  .cmn_btn_link:not(:hover)::before {
    transform: translateX(101%);
    background-color: #D1F40D;
    transition: transform 0.5s linear 0.2s, background-color 0.1s linear 0s; /* 0.5秒遅れて戻る */
  }
}

.cmn_btn_txt {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  padding-left: clamp(1.875rem, 1.2820512821vw + 1.4903846154rem, 2.5rem);
  padding-right: clamp(1.875rem, 1.2820512821vw + 1.4903846154rem, 2.5rem);
  border-radius: 60px;
  color: #009443;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.3846153846vw + 0.8221153846rem, 1.125rem);
  transition: all 0.3s ease;
  overflow: hidden;
}
.cmn_btn_txt::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #D1F40D;
  z-index: -2;
}
@media (min-width: 769px) {
  .cmn_btn_link:hover .cmn_btn_txt {
    color: #D1F40D;
  }
}

.cmn_btn_arrow {
  position: relative;
  flex-shrink: 0;
  aspect-ratio: 1;
  height: 100%;
  border-radius: 50%;
  background: #D1F40D;
  z-index: 1;
  transition: background-color 0.1s linear 0s;
}
@media (min-width: 769px) {
  .cmn_btn_link:hover .cmn_btn_arrow {
    background: #009443;
  }
  .cmn_btn_link:not(:hover) .cmn_btn_arrow {
    background-color: #D1F40D;
  }
}

.cmn_btn_inner {
  position: absolute;
  inset: 0;
  width: 50px;
  aspect-ratio: 1;
  margin: auto;
  overflow: hidden;
}
.cmn_btn_inner::before {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  background: #009443;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: clamp(1.25rem, 0.3623188406vw + 1.1548913043rem, 1.5625rem) auto;
          mask-size: clamp(1.25rem, 0.3623188406vw + 1.1548913043rem, 1.5625rem) auto;
  -webkit-mask-image: url(../images/arrow_btn.svg);
          mask-image: url(../images/arrow_btn.svg);
  transform: translateX(0);
  transition: background-color 0.3s linear;
}
@media (min-width: 769px) {
  .cmn_btn_link:hover .cmn_btn_inner::before {
    animation-name: slideOutinX;
    animation-duration: 0.6s;
    animation-timing-function: cubic-bezier(0.85, 0, 0.15, 1);
    background: #D1F40D;
  }
}

/*---------- NO IMG ----------*/
.cmn_noimg {
  display: flex;
  background: linear-gradient(303.72deg, #E2E920 2.01%, #0FB583 97.99%);
  color: #fff;
  font-weight: 700;
  letter-spacing: calc(80 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.125rem, 0.4838709677vw + 0.9556451613rem, 1.5rem);
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
  transform-origin: center center;
  transition: all 0.3s ease;
}
@media (max-width: 560px) {
  .cmn_noimg {
    font-size: clamp(1.125rem, 7.1428571429vw + -0.75rem, 1.75rem);
  }
}
@media (min-width: 769px) {
  *:hover > .cmn_noimg {
    transform: scale(1.1);
  }
}

/*-------------------------------------------------------------------------------
  header
--------------------------------------------------------------------------------*/
.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: clamp(4.375rem, 5.8139534884vw + 1.5843023256rem, 8.125rem);
  z-index: 50;
  padding-left: clamp(1.5rem, 4.6153846154vw + 0.1153846154rem, 3.75rem);
  padding-right: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
}

.nav {
  display: flex;
  align-items: center;
  gap: clamp(1.25rem, 9.2592592593vw + -6.0416666667rem, 4.375rem);
  z-index: 51;
}
@media (max-width: 1260px) {
  .nav {
    flex-direction: column;
    justify-content: center;
    position: fixed;
    width: 60vw;
    height: 80svh;
    gap: clamp(1.25rem, 1.2820512821vw + 0.8653846154rem, 1.875rem);
    left: 20vw;
    top: 10svh;
    border-radius: clamp(1.875rem, 8.3333333333vw + -0.3125rem, 6.25rem);
    overflow-y: auto;
    transform: translateY(-120%);
    transition: all 0.5s 0s ease;
    background: #fff;
    box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.1);
  }
}
@media (max-width: 1260px) and (max-width: 768px) {
  .nav {
    width: 80vw;
    left: 10vw;
  }
}
@media (max-width: 1260px) and (max-width: 480px) {
  .nav {
    width: 90vw;
    left: 5vw;
  }
}
@media (max-width: 1260px) {
  .nav.js-open {
    transform: translateY(0);
  }
}

.hd-nav {
  display: flex;
  gap: clamp(0.9375rem, 6.4814814815vw + -4.1666666667rem, 3.125rem);
}
@media (max-width: 1260px) {
  .hd-nav {
    flex-direction: column;
    align-items: center;
    gap: clamp(0.9375rem, 0.641025641vw + 0.7451923077rem, 1.25rem);
  }
}
.hd-nav li {
  height: clamp(1.375rem, 0.7407407407vw + 0.7916666667rem, 1.625rem);
  overflow: hidden;
}
.hd-nav li:nth-child(1) {
  width: clamp(3.5rem, 1.8518518519vw + 2.0416666667rem, 4.125rem);
}
.hd-nav li:nth-child(2) {
  width: clamp(5.625rem, 3.7037037037vw + 2.7083333333rem, 6.875rem);
}
.hd-nav li:nth-child(3) {
  width: clamp(5.0625rem, 1.8518518519vw + 3.6041666667rem, 5.6875rem);
}
.hd-nav li:nth-child(4) {
  width: clamp(7.5rem, 3.7037037037vw + 4.5833333333rem, 8.75rem);
}
.hd-nav li:nth-child(5) {
  width: clamp(3.625rem, 2.5925925926vw + 1.5833333333rem, 4.5rem);
}
.hd-nav li:nth-child(6) {
  width: clamp(10rem, 3.7037037037vw + 7.0833333333rem, 11.25rem);
}
@media (max-width: 1260px) {
  .hd-nav li:nth-child(1), .hd-nav li:nth-child(2), .hd-nav li:nth-child(3), .hd-nav li:nth-child(4), .hd-nav li:nth-child(5), .hd-nav li:nth-child(6) {
    width: clamp(16.875rem, 23.0769230769vw + 9.9519230769rem, 28.125rem);
    height: clamp(2.25rem, 1.2820512821vw + 1.8653846154rem, 2.875rem);
    border-radius: 5px;
    display: block;
    background: #D1F40D;
  }
}
.hd-nav a {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  color: #222;
  transition: all 0.3s ease;
}
.hd-nav a::before, .hd-nav a::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
}
.hd-nav a::before {
  content: attr(title);
  transform: translateY(0);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.15;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(0.9375rem, 0.9259259259vw + 0.2083333333rem, 1.25rem);
}
@media (max-width: 1260px) {
  .hd-nav a::before {
    font-size: clamp(0.9375rem, 0.641025641vw + 0.7451923077rem, 1.25rem);
  }
}
.hd-nav a::after {
  content: attr(data-item);
  transform: translateY(100%);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.15;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.7407407407vw + 0.2916666667rem, 1.125rem);
}
@media (max-width: 1260px) {
  .hd-nav a::after {
    font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  }
}
@media (min-width: 769px) {
  .hd-nav a:hover::before {
    transform: translateY(-100%);
  }
  .hd-nav a:hover::after {
    transform: translateY(0);
  }
}

.hd-phone {
  display: flex;
  position: relative;
  flex-direction: column;
}

.hd-number {
  display: block;
  color: #222;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.15;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.75rem, 0.7407407407vw + 1.1666666667rem, 2rem);
}
@media (max-width: 1260px) {
  .hd-number {
    font-size: clamp(1.75rem, 1.5384615385vw + 1.2884615385rem, 2.5rem);
  }
}

.hd-hour {
  display: block;
  color: #333;
  font-weight: 600;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.15;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.8125rem, 0.3703703704vw + 0.5208333333rem, 0.9375rem);
}
@media (max-width: 1260px) {
  .hd-hour {
    font-weight: 600;
    letter-spacing: calc(0 * 0.001em);
    line-height: 1.15;
    font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
    font-size: clamp(0.8125rem, 0.5128205128vw + 0.6586538462rem, 1.0625rem);
  }
}

/*-------------------------------------------------------------------------------
  current
--------------------------------------------------------------------------------*/
body.index .hd-nav li:nth-of-type(1) a {
  color: #09B464;
}
body.company .hd-nav li:nth-of-type(2) a {
  color: #09B464;
}
body.service .hd-nav li:nth-of-type(3) a {
  color: #09B464;
}
body.flow .hd-nav li:nth-of-type(4) a {
  color: #09B464;
}
body.post-type-archive-post .hd-nav li:nth-of-type(5) a {
  color: #09B464;
}
body.category .hd-nav li:nth-of-type(5) a {
  color: #09B464;
}
body.single-post .hd-nav li:nth-of-type(5) a {
  color: #09B464;
}
body.privacy .hd-nav li:nth-of-type(6) a {
  color: #09B464;
}
/*-------------------------------------------------------------------------------
  sp menu
--------------------------------------------------------------------------------*/
.menu-trigger {
  display: none;
  position: fixed;
  right: clamp(0.625rem, 0.5952380952vw + 0.46875rem, 0.9375rem);
  top: clamp(0.625rem, 0.5952380952vw + 0.46875rem, 0.9375rem);
  width: clamp(3.5rem, 2.8455284553vw + 2.1341463415rem, 4.375rem);
  height: clamp(3.125rem, 2.8455284553vw + 1.7591463415rem, 4rem);
  font-size: clamp(0.9375rem, 0.5514705882vw + 0.7720588235rem, 1.125rem);
  border-radius: 5px;
  z-index: 51;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  background: #09B464;
}
@media (max-width: 1260px) {
  .menu-trigger {
    display: flex;
  }
}
.menu-trigger .menu_line {
  position: relative;
  display: block;
  width: 32px;
  height: 20px;
  margin-top: -3px;
}
.menu-trigger .menu_line span {
  display: block;
  position: absolute;
  width: 100%;
  height: 3px;
  border-radius: 1px;
  background: #fff;
  transition: all 0.4s;
}
.menu-trigger .menu_line span:nth-of-type(1) {
  top: 0;
  animation: bar01 0.75s forwards;
}
@keyframes bar01 {
  0% {
    transform: translateY(10px) rotate(30deg);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.menu-trigger .menu_line span:nth-of-type(2) {
  top: 50%;
  transition: all 0.25s 0.25s;
  opacity: 1;
}
.menu-trigger .menu_line span:nth-of-type(3) {
  top: 100%;
  animation: bar03 0.75s forwards;
}
@keyframes bar03 {
  0% {
    transform: translateY(-10px) rotate(-30deg);
  }
  50% {
    transform: translateY(-10px) rotate(0);
  }
  100% {
    transform: translateY(0) rotate(0);
  }
}
.menu-trigger.js-open .menu_line span:nth-of-type(1) {
  animation: active-bar01 0.75s forwards;
}
@keyframes active-bar01 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(10px) rotate(0);
  }
  100% {
    transform: translateY(10px) rotate(30deg);
  }
}
.menu-trigger.js-open .menu_line span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.js-open .menu_line span:nth-of-type(3) {
  animation: active-bar03 0.75s forwards;
}
@keyframes active-bar03 {
  0% {
    transform: translateY(0) rotate(0);
  }
  50% {
    transform: translateY(-10px) rotate(0);
  }
  100% {
    transform: translateY(-10px) rotate(-30deg);
  }
}

/*-------------------------------------------------------------------------------
  mainimg
--------------------------------------------------------------------------------*/
.mainimg_wrapper {
  display: flex;
  align-items: center;
  position: relative;
  width: calc(100% - 6vw);
  height: clamp(15rem, 46.1538461538vw + 1.1538461538rem, 37.5rem);
  margin-left: 6vw;
}
.index .mainimg_wrapper {
  display: block;
  height: auto;
  padding-bottom: clamp(5.625rem, 3.8659793814vw + 3.1507731959rem, 7.5rem);
}

.mainimg_bg {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  border-radius: 0;
  border-top-left-radius: clamp(2.5rem, 4.5454545455vw + 1.1363636364rem, 6.25rem);
  border-bottom-left-radius: clamp(2.5rem, 4.5454545455vw + 1.1363636364rem, 6.25rem);
  background: url(../images/mv_bg_gra.jpg) center/cover;
  z-index: -1;
}
.index .mainimg_bg {
  height: 83%;
}
@media (max-width: 768px) {
  .index .mainimg_bg {
    height: 78%;
  }
}

.mainimg {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 5%;
  width: 100%;
  height: 100%;
  padding-left: clamp(1.875rem, 10.2564102564vw + -1.2019230769rem, 6.875rem);
  overflow: hidden;
}
.index .mainimg {
  justify-content: space-between;
  align-items: flex-start;
  height: auto;
  padding-top: clamp(1.5625rem, 10.8974358974vw + -1.7067307692rem, 6.875rem);
  padding-left: clamp(1.25rem, 11.5384615385vw + -2.2115384615rem, 6.875rem);
}
@media (max-width: 768px) {
  .index .mainimg {
    flex-direction: column;
  }
}

.mainimg_left {
  width: clamp(18.75rem, 31.976744186vw + 3.4011627907rem, 39.375rem);
}
@media (max-width: 768px) {
  .mainimg_left {
    justify-content: space-between;
    gap: 5vw;
    width: 100%;
    margin-bottom: 25px;
  }
}

.mainimg_txtblock {
  width: 100%;
}
@media (max-width: 768px) {
  .mainimg_txtblock {
    width: 90%;
  }
}

.mainimg_right {
  width: clamp(25rem, 56.2015503876vw + -1.976744186rem, 61.25rem);
}
@media (max-width: 768px) {
  .mainimg_right {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-start;
    width: 100%;
    gap: 5%;
  }
}

.mv_img01 {
  border-radius: clamp(1.25rem, 5.8139534884vw + -1.5406976744rem, 5rem);
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  width: 100%;
  aspect-ratio: 917/756;
  overflow: hidden;
}
@media (max-width: 768px) {
  .mv_img01 {
    width: 63%;
    margin-top: clamp(1.25rem, 17.2413793103vw + -3.275862069rem, 5rem);
  }
}
.mv_img01 img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mv_img02 {
  border-radius: clamp(1.25rem, 2.9069767442vw + -0.1453488372rem, 3.125rem);
  width: clamp(15.625rem, 34.1085271318vw + -0.7470930233rem, 37.625rem);
  aspect-ratio: 602/417;
  overflow: hidden;
  margin-top: clamp(1.875rem, 2.9069767442vw + 0.4796511628rem, 3.75rem);
}
@media (max-width: 768px) {
  .mv_img02 {
    position: absolute;
    top: 50px;
    right: 3vw;
    margin-top: 0;
    width: clamp(9.375rem, 34.7222222222vw + -1.0416666667rem, 15.625rem);
    z-index: -1;
  }
}
.mv_img02 img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mv_img03 {
  border-radius: clamp(1.25rem, 2.9069767442vw + -0.1453488372rem, 3.125rem);
  width: clamp(13.125rem, 30.0387596899vw + -1.2936046512rem, 32.5rem);
  aspect-ratio: 52/35;
  overflow: hidden;
  margin-top: 150px;
  margin-left: -6%;
}
@media (max-width: 768px) {
  .mv_img03 {
    margin-left: 0;
    width: 40%;
    margin-top: 0;
    border-radius: clamp(0.625rem, 3.4722222222vw + -0.4166666667rem, 1.25rem);
  }
}
.mv_img03 img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.mv_ttl {
  display: inline-block;
  position: relative;
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(3rem, 5.652173913vw + 1.5163043478rem, 7.875rem);
  color: #fff;
  white-space: nowrap;
}
.mv_ttl::before {
  position: absolute;
  content: "";
  right: 0px;
  bottom: -15px;
  width: clamp(2rem, 3.4793814433vw + -0.2268041237rem, 3.6875rem);
  aspect-ratio: 59/212;
  background: url(../images/ill_mv.png) no-repeat center/cover;
  z-index: 1;
}
@media (max-width: 768px) {
  .mv_ttl::before {
    right: -15px;
  }
}

.mv_txt {
  display: block;
  margin-top: clamp(1.875rem, 0.9689922481vw + 1.4098837209rem, 2.5rem);
  font-weight: 600;
  letter-spacing: calc(10 * 0.001em);
  line-height: 1.8;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1rem, 0.8695652174vw + 0.7717391304rem, 1.75rem);
  color: #fff;
}

.bg_en_wrapper {
  display: block;
  position: absolute;
  right: 20px;
  bottom: clamp(1.25rem, 2.5773195876vw + -0.3994845361rem, 2.5rem);
}
.bg_en_wrapper.intro_en {
  display: flex;
  right: auto;
  left: 0;
  animation: loop-text 20s linear infinite;
  mix-blend-mode: multiply;
}

.bg_en {
  display: block;
  color: rgba(209, 244, 13, 0.8);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(6.25rem, 4.347826087vw + 5.1086956522rem, 10rem);
  white-space: nowrap;
  margin-left: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
}

@keyframes loop-text {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}
.main_ttl {
  display: inline-block;
}

.main_ttl_en {
  display: block;
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(3.5rem, 7.5362318841vw + 1.5217391304rem, 10rem);
  white-space: nowrap;
  color: rgba(0, 229, 154, 0.8);
  margin-left: -125px;
  mix-blend-mode: multiply;
}
@media (max-width: 1260px) {
  .main_ttl_en {
    margin-left: -106px;
  }
}
@media (max-width: 1024px) {
  .main_ttl_en {
    margin-left: -96px;
  }
}
@media (max-width: 768px) {
  .main_ttl_en {
    margin-left: -54px;
  }
}
@media (max-width: 560px) {
  .main_ttl_en {
    margin-left: -38px;
  }
}

.main_ttl_ja {
  display: block;
  font-weight: 700;
  letter-spacing: calc(100 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.625rem, 3.0769230769vw + 0.7019230769rem, 3.125rem);
  color: #fff;
}

/*-------------------------------------------------------------------------------
  main
--------------------------------------------------------------------------------*/
.main {
  position: relative;
  padding-top: clamp(3.125rem, 8.9743589744vw + 0.4326923077rem, 7.5rem);
  margin-bottom: clamp(1.875rem, 4.358974359vw + 0.5673076923rem, 4rem);
  background: #F4FFC3;
}
.index .main {
  padding-top: 0;
  margin-bottom: 0;
}
.company .main, .flow .main {
  margin-bottom: 0;
}

/*-------------------------------------------------------------------------------
  footer
--------------------------------------------------------------------------------*/
.footer {
  position: relative;
  display: block;
  width: 100%;
  margin: 0 auto;
  background: #F4FFC3;
}

.footer_img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: url(../images/footer_bg.jpg) no-repeat 20% top/cover;
}

.ft_contact_wrapper {
  width: 100%;
  padding-bottom: clamp(2.5rem, 7.0512820513vw + 0.3846153846rem, 5.9375rem);
}

.ft_contact_ttl_wrapper {
  position: relative;
  width: 100%;
  height: clamp(4.375rem, 11.5384615385vw + 0.9134615385rem, 10rem);
  mix-blend-mode: multiply;
  overflow: hidden;
}

.ft_contact_ttl {
  position: absolute;
  top: -30px;
  left: -10px;
  display: block;
  color: rgba(209, 244, 13, 0.8);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(7.5rem, 5.1546391753vw + 4.2010309278rem, 10rem);
  white-space: nowrap;
}
@media (max-width: 1024px) {
  .ft_contact_ttl {
    top: -20px;
    font-size: clamp(4.375rem, 9.1911764706vw + 1.6176470588rem, 7.5rem);
  }
}
@media (max-width: 768px) {
  .ft_contact_ttl {
    top: -14px;
  }
}

.ft_contact_unit {
  position: relative;
  width: 60%;
  padding-left: 8vw;
}
@media (max-width: 560px) {
  .ft_contact_unit {
    width: 80%;
  }
}
@media (max-width: 480px) {
  .ft_contact_unit {
    width: 90%;
  }
}
@media (max-width: 420px) {
  .ft_contact_unit {
    width: 100%;
    padding: 0 4vw;
  }
}

.ft_contact_sttl {
  display: block;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.25rem, 0.6060606061vw + 1.0681818182rem, 1.75rem);
  margin-bottom: clamp(1.25rem, 1.5151515152vw + 0.7954545455rem, 2.5rem);
}

.ft_contact_txt {
  position: relative;
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
}

.ft-tel {
  display: flex;
  position: relative;
  flex-direction: column;
  margin-top: clamp(1.875rem, 1.5151515152vw + 1.4204545455rem, 3.125rem);
}

.ft-phone {
  display: block;
  color: #222;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.15;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.4375rem, 2.5vw + 1.5625rem, 4.375rem);
}

.ft-hour {
  display: block;
  color: #333;
  font-weight: 600;
  letter-spacing: calc(100 * 0.001em);
  line-height: 1.15;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1rem, 1.4814814815vw + -0.1666666667rem, 1.5rem);
}

.footer_wrapper {
  position: relative;
  width: 100%;
  padding: 0 8vw;
  padding-top: clamp(1.875rem, 5.1282051282vw + 0.3365384615rem, 4.375rem);
  padding-bottom: clamp(1.875rem, 5.1282051282vw + 0.3365384615rem, 4.375rem);
}
@media (max-width: 1260px) {
  .footer_wrapper {
    padding-right: 4vw;
    padding-left: 4vw;
  }
}

.footer_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #222;
  mix-blend-mode: multiply;
}

.footer_unit {
  display: flex;
  justify-content: space-between;
  gap: clamp(1.875rem, 22.2222222222vw + -15.625rem, 9.375rem);
  align-items: flex-start;
  width: 100%;
}
@media (max-width: 1024px) {
  .footer_unit {
    flex-direction: column;
  }
}

.ft_info {
  width: 40%;
}
@media (max-width: 1024px) {
  .ft_info {
    width: 100%;
  }
}

.ft_txt {
  position: relative;
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  color: #fff;
  margin-top: clamp(0.625rem, 1.9230769231vw + 0.0480769231rem, 1.5625rem);
}

.ft_nav {
  display: flex;
  -moz-column-gap: clamp(1.875rem, 6.4432989691vw + -2.2487113402rem, 5rem);
       column-gap: clamp(1.875rem, 6.4432989691vw + -2.2487113402rem, 5rem);
  row-gap: clamp(0.9375rem, 4.5103092784vw + -1.9490979381rem, 3.125rem);
  z-index: 1;
  flex-wrap: wrap;
  padding-left: clamp(1.875rem, 22.2222222222vw + -15.625rem, 9.375rem);
  border-left: 1px solid rgba(255, 255, 255, 0.5);
  padding-bottom: 15px;
  flex-grow: 1; /* 残りの幅を全部埋める */
  min-width: 0; /* はみ出し防止 */
}
@media (max-width: 1024px) {
  .ft_nav {
    display: none;
  }
}
.ft_nav li a {
  color: #fff;
}
.ft_nav li a:hover {
  color: rgba(255, 255, 255, 0.5);
}

.copyright {
  position: relative;
  display: inline-block;
  margin-top: clamp(1.25rem, 1.2820512821vw + 0.8653846154rem, 1.875rem);
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5154639175vw + 0.5451030928rem, 1.125rem);
  color: rgba(255, 255, 255, 0.5);
  z-index: 1;
}

/*-------------------------------------------------------------------------------
  breadcrumb
--------------------------------------------------------------------------------*/
.breadcrumb {
  display: flex;
  justify-content: flex-end;
  position: relative;
  margin-top: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem);
  margin-right: 8vw;
  font-size: clamp(0.875rem, 0.3846153846vw + 0.7596153846rem, 1.0625rem);
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  flex-wrap: wrap;
}
.breadcrumb li {
  position: relative;
  color: #333;
}
.breadcrumb li:not(:first-child) {
  padding-left: clamp(1.6875rem, 9.358974359vw + -1.1201923077rem, 6.25rem);
}
.breadcrumb li:not(:first-child)::before {
  position: absolute;
  display: block;
  content: "";
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 6px;
  height: 9px;
  background: url(../images/arrow_breadcrumb.png) no-repeat center center/cover;
  margin-left: clamp(0.625rem, 5.1282051282vw + -0.9134615385rem, 3.125rem);
}
.breadcrumb li:first-child {
  padding-left: clamp(1.625rem, 1.5384615385vw + 1.1634615385rem, 2.375rem);
}
.breadcrumb li:first-child::before {
  position: absolute;
  display: block;
  content: "";
  top: 46%;
  left: 0;
  transform: translateY(-50%);
  width: clamp(1rem, 0.5128205128vw + 0.8461538462rem, 1.25rem);
  aspect-ratio: 1/1;
  background: url(../images/home.svg) no-repeat center center/cover;
}
.breadcrumb li a {
  color: #009443;
}

/*-------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------*/
.index_about_unit {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: clamp(3.75rem, 10.3092783505vw + -2.8479381443rem, 8.75rem);
  padding-bottom: clamp(2.5rem, 3.8461538462vw + 1.3461538462rem, 4.375rem);
}
@media (max-width: 1024px) {
  .index_about_unit {
    flex-direction: column;
    gap: clamp(0.3125rem, 5.7947019868vw + -1.2086092715rem, 2.5rem);
  }
}

.index_about_left {
  width: clamp(28.6875rem, 27.1907216495vw + 11.2854381443rem, 41.875rem);
  padding-bottom: clamp(3.75rem, 10.6060606061vw + 0.5681818182rem, 12.5rem);
}
@media (max-width: 1024px) {
  .index_about_left {
    width: 100%;
  }
}
@media (max-width: 480px) {
  .index_about_left {
    padding-bottom: 40px;
  }
}

.index_about_img {
  width: clamp(31.625rem, 36.5979381443vw + 8.2023195876rem, 49.375rem);
  aspect-ratio: 79/65;
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
}
.index_about_img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 1024px) {
  .index_about_img {
    width: 100%;
    aspect-ratio: 79/45;
  }
}

.about_ill {
  position: absolute;
  display: block;
  top: 15px;
  left: clamp(16.25rem, 7.0512820513vw + 14.1346153846rem, 19.6875rem);
  width: clamp(7.5rem, 26.4102564103vw + -0.4230769231rem, 20.375rem);
  aspect-ratio: 326/253;
}
@media (max-width: 420px) {
  .about_ill {
    top: 56px;
    left: auto;
    right: 0;
  }
}
.about_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.index_service_unit {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding-bottom: clamp(3.75rem, 11.5384615385vw + 0.2884615385rem, 9.375rem);
  padding-top: clamp(3.125rem, 12.8205128205vw + -0.7211538462rem, 9.375rem);
}
@media (max-width: 1024px) {
  .index_service_unit {
    flex-direction: column-reverse;
    gap: clamp(1.875rem, 1.6556291391vw + 1.440397351rem, 2.5rem);
  }
}

body {
  overflow-x: clip;
}

.index_service_pin_wrap {
  position: relative;
  z-index: 1;
}
.index_service_pin_wrap > * {
  position: relative;
  z-index: 1;
}

.index_service_pin {
  inline-size: 100%;
  block-size: 100vh;
  margin-bottom: -100vh;
  position: sticky;
  top: 0;
  z-index: -1;
}
.index_service_pin + .pin-spacer {
  z-index: 2 !important;
  mix-blend-mode: multiply;
}

.index_service_right {
  color: #fff;
  width: clamp(26.8125rem, 31.0567010309vw + 6.9362113402rem, 41.875rem);
  padding-top: clamp(0rem, 12.8205128205vw + -3.8461538462rem, 6.25rem);
  margin-left: clamp(2.5rem, 11.5979381443vw + -4.9226804124rem, 8.125rem);
}
@media (max-width: 1024px) {
  .index_service_right {
    width: 100%;
    margin-left: 0;
  }
}

.index_service_left {
  width: clamp(32.0625rem, 36.9845360825vw + 8.3923969072rem, 50rem);
}
@media (max-width: 1024px) {
  .index_service_left {
    width: 100%;
  }
}

.index_service_block {
  display: flex;
  align-items: flex-end;
  position: relative;
  width: 100%;
  aspect-ratio: 79/60;
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
  z-index: -1;
}
.index_service_block:not(:first-child) {
  margin-top: clamp(2.5rem, 7.6923076923vw + 0.1923076923rem, 6.25rem);
}
@media (max-width: 1024px) {
  .index_service_block {
    aspect-ratio: 79/54;
  }
}

.index_service_ttl {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  height: clamp(6.25rem, 12.8205128205vw + 2.4038461538rem, 12.5rem);
  text-align: center;
  padding-bottom: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem);
  z-index: 1;
}
.index_service_ttl::before {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  content: "";
  width: 150%;
  height: 360%;
  background: rgba(0, 148, 67, 0.7);
  border-radius: 50%;
  z-index: -1;
}

.index_service_ttl_en {
  display: block;
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.125rem, 4.0697674419vw + 0.1715116279rem, 4.75rem);
  color: #fff;
  margin-bottom: clamp(0.125rem, 1.0256410256vw + -0.1826923077rem, 0.625rem);
}
@media (max-width: 768px) {
  .index_service_ttl_en {
    font-size: clamp(2.375rem, 10.9195402299vw + -0.4913793103rem, 4.75rem);
  }
}

.index_service_ttl_ja {
  display: block;
  font-weight: 700;
  letter-spacing: calc(100 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1rem, 0.4347826087vw + 0.8858695652rem, 1.375rem);
  color: #fff;
}

.index_service_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
}
.index_service_img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.index_strengths_wrapper {
  padding-top: clamp(0rem, 12.8205128205vw + -3.8461538462rem, 6.25rem);
}

.index_strengths_unit {
  display: flex;
  gap: clamp(3.75rem, 7.7319587629vw + -1.1984536082rem, 7.5rem);
  padding-bottom: clamp(3.75rem, 11.5384615385vw + 0.2884615385rem, 9.375rem);
}
@media (max-width: 1024px) {
  .index_strengths_unit {
    flex-direction: column;
  }
}

.index_strangths_block {
  width: clamp(31.25rem, 18.0412371134vw + 19.7036082474rem, 40rem);
}
@media (max-width: 1024px) {
  .index_strangths_block {
    width: 100%;
  }
}

.index_strengths_sttl {
  margin-bottom: clamp(0.625rem, 2.5641025641vw + -0.1442307692rem, 1.875rem);
}

.index_strangths_img {
  width: 100%;
  aspect-ratio: 32/23;
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
  margin-bottom: clamp(0.9375rem, 4.4871794872vw + -0.4086538462rem, 3.125rem);
}
@media (max-width: 1024px) {
  .index_strangths_img {
    aspect-ratio: 79/45;
  }
}
.index_strangths_img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.index_news_wrapper {
  position: relative;
}

.index_news_unit {
  display: flex;
  align-items: baseline;
  gap: clamp(1.875rem, 16.4728682171vw + -6.0319767442rem, 12.5rem);
  margin-top: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
  margin-bottom: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
  padding-right: clamp(12.5rem, 4.8449612403vw + 10.1744186047rem, 15.625rem);
}
@media (max-width: 768px) {
  .index_news_unit {
    padding-right: 6vw;
    flex-direction: column;
    margin-bottom: 80px;
  }
}

.index_news_txt {
  flex: 1;
}

.index_news_ill {
  position: absolute;
  display: block;
  top: -100px;
  right: clamp(0.9375rem, 44.2307692308vw + -12.3317307692rem, 22.5rem);
  width: clamp(7.5rem, 30.3846153846vw + -1.6153846154rem, 22.3125rem);
  aspect-ratio: 357/327;
  z-index: 1;
}
@media (max-width: 768px) {
  .index_news_ill {
    top: -50px;
  }
}
.index_news_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.index_news-swiper {
  display: block;
  padding-bottom: clamp(3.75rem, 14.1025641026vw + -0.4807692308rem, 10.625rem);
}

.index_news-media {
  width: 100%;
  aspect-ratio: 23/18;
  border-radius: clamp(1.25rem, 1.2820512821vw + 0.8653846154rem, 1.875rem);
  overflow: hidden;
}
.index_news-media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
  transform-origin: center center;
}
@media (min-width: 769px) {
  .index_news-media:hover img {
    transform: scale(1.1);
  }
}

.index_news-content {
  margin-top: clamp(0.9375rem, 0.641025641vw + 0.7451923077rem, 1.25rem);
}

.slide-title {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.75;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.3846153846vw + 0.7596153846rem, 1.0625rem);
  color: #333;
}

.swiper-slide {
  width: clamp(15.625rem, 26.9230769231vw + 7.5480769231rem, 28.75rem);
}

.index-swiper-btn {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  width: clamp(8.125rem, 11.5384615385vw + 4.6634615385rem, 13.75rem);
  top: clamp(11.875rem, 4.8449612403vw + 9.5494186047rem, 15rem);
  right: clamp(0rem, 9.6899224806vw + -4.6511627907rem, 6.25rem);
}
@media (max-width: 768px) {
  .index-swiper-btn {
    top: clamp(15.625rem, -2.8735632184vw + 16.3793103448rem, 15rem);
    right: clamp(0.625rem, 11.4942528736vw + -2.3922413793rem, 3.125rem);
  }
}

.bnr_wrapper {
  background: url(../images/bg_gra.jpg) repeat-y left center;
  overflow: hidden;
  padding-top: clamp(2.5rem, 14.1025641026vw + -1.7307692308rem, 9.375rem);
  padding-bottom: clamp(2.5rem, 14.1025641026vw + -1.7307692308rem, 9.375rem);
}

.bnr_unit {
  display: flex;
  justify-content: space-between;
  gap: 4%;
}
@media (max-width: 768px) {
  .bnr_unit {
    flex-direction: column;
    gap: clamp(0.9375rem, 10.0574712644vw + -1.7025862069rem, 3.125rem);
  }
}

.bnr_block {
  position: relative;
  width: 48%;
  aspect-ratio: 385/202;
}
@media (max-width: 768px) {
  .bnr_block {
    width: 100%;
  }
}

.bnr_bg {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: clamp(1.25rem, 2.9069767442vw + -0.1453488372rem, 3.125rem);
}
@media (max-width: 768px) {
  .bnr_bg {
    border-radius: clamp(1.25rem, 5.7471264368vw + -0.2586206897rem, 2.5rem);
  }
}
.bnr_bg {
  overflow: hidden;
}
.bnr_bg::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 148, 67, 0.8);
  mix-blend-mode: multiply;
  z-index: 1;
}
.bnr_bg img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
  transform-origin: center center;
}
@media (min-width: 769px) {
  .bnr_block:hover .bnr_bg img {
    transform: scale(1.1);
  }
}

.bnr_inner {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  padding-left: clamp(1.5625rem, 5.3294573643vw + -0.9956395349rem, 5rem);
  padding-right: clamp(1.25rem, 4.8449612403vw + -1.0755813953rem, 4.375rem);
  z-index: 2;
}
@media (max-width: 768px) {
  .bnr_inner {
    padding-left: clamp(1.25rem, 11.4942528736vw + -1.7672413793rem, 3.75rem);
    padding-right: clamp(0.9375rem, 10.0574712644vw + -1.7025862069rem, 3.125rem);
  }
}

.bnr_arrow {
  position: relative;
  display: flex;
  align-items: center;
  aspect-ratio: 1;
  width: clamp(3.125rem, 3.488372093vw + 1.4505813953rem, 5.375rem);
  border-radius: 50%;
  background: #D1F40D;
  transition: all 0.3s ease;
}
@media (max-width: 768px) {
  .bnr_arrow {
    width: clamp(3.125rem, 10.3448275862vw + 0.4094827586rem, 5.375rem);
  }
}
@media (min-width: 769px) {
  .bnr_block:hover .bnr_arrow {
    background: #009443;
  }
}

.arrow_inner {
  position: absolute;
  inset: 0;
  width: 50px;
  aspect-ratio: 1;
  margin: auto;
  overflow: hidden;
}
.arrow_inner::before {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  background-color: #009443;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: clamp(1.25rem, 0.484496124vw + 1.0174418605rem, 1.5625rem) auto;
          mask-size: clamp(1.25rem, 0.484496124vw + 1.0174418605rem, 1.5625rem) auto;
  -webkit-mask-image: url(../images/arrow_btn.svg);
          mask-image: url(../images/arrow_btn.svg);
  transition: background-color 0.3s ease 0s;
}
@media (max-width: 768px) {
  .arrow_inner::before {
    -webkit-mask-size: clamp(1.25rem, 1.4367816092vw + 0.8728448276rem, 1.5625rem) auto;
            mask-size: clamp(1.25rem, 1.4367816092vw + 0.8728448276rem, 1.5625rem) auto;
  }
}
@media (min-width: 769px) {
  .bnr_block:hover .arrow_inner::before {
    transition: background-color 0.3s ease;
    animation-name: slideOutinX;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    background: #D1F40D;
  }
}

.bnr_ttl {
  display: flex;
  flex-direction: column;
}

.bnr_ttl_en {
  display: block;
  word-break: keep-all;
  overflow-wrap: normal;
  white-space: normal;
  color: rgba(209, 244, 13, 0.8);
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.625rem, 3.6821705426vw + 0.8575581395rem, 5rem);
  color: rgba(209, 244, 13, 0.8);
}
@media (max-width: 768px) {
  .bnr_ttl_en {
    font-size: clamp(2.625rem, 6.3218390805vw + 0.9655172414rem, 4rem);
  }
}

.bnr_ttl_ja {
  display: block;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1rem, 0.7751937984vw + 0.6279069767rem, 1.5rem);
  color: #fff;
  margin-top: clamp(0.3125rem, 0.641025641vw + 0.1201923077rem, 0.625rem);
}
@media (max-width: 768px) {
  .bnr_ttl_ja {
    font-size: clamp(1rem, 1.1494252874vw + 0.6982758621rem, 1.25rem);
  }
}

/*-------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------*/
.overview_list {
  display: flex;
  border-bottom: 1px solid #8B8B8B;
  padding: 30px 0;
}
@media (max-width: 768px) {
  .overview_list {
    flex-direction: column;
    padding: 15px 0;
  }
}
.overview_list dt {
  width: 30%;
  flex-shrink: 0;
  font-weight: 500;
  letter-spacing: calc(40 * 0.001em);
  line-height: 1.3;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.641025641vw + 0.7451923077rem, 1.25rem);
}
@media (max-width: 768px) {
  .overview_list dt {
    margin-bottom: 5px;
  }
}
.overview_list dd {
  flex: 1;
  font-weight: 500;
  letter-spacing: calc(40 * 0.001em);
  line-height: 1.3;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
}

.access_ill {
  position: absolute;
  display: block;
  top: -50px;
  right: clamp(0.9375rem, 33.9743589744vw + -9.2548076923rem, 17.5rem);
  width: clamp(7.5rem, 36.2820512821vw + -3.3846153846rem, 25.1875rem);
  aspect-ratio: 403/349;
}
@media (max-width: 768px) {
  .access_ill {
    top: -40px;
  }
}
.access_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.access_unit {
  display: flex;
  align-items: baseline;
  gap: clamp(1.875rem, 16.4728682171vw + -6.0319767442rem, 12.5rem);
  margin-bottom: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
}
@media (max-width: 768px) {
  .access_unit {
    flex-direction: column;
  }
}

.access_block {
  display: flex;
  gap: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  align-items: center;
}
@media (max-width: 1260px) {
  .access_block {
    align-items: flex-start;
    flex-direction: column;
  }
}

.access_item {
  display: flex;
  gap: clamp(1.25rem, 3.7037037037vw + -1.6666666667rem, 2.5rem);
  align-items: center;
  width: 50%;
}
@media (max-width: 1260px) {
  .access_item {
    width: 100%;
    flex-direction: column;
    align-items: start;
    gap: clamp(0.625rem, 2.380952381vw + 0rem, 1.875rem);
  }
}

.access_ttl {
  background: #D1F40D;
  color: #009443;
  border-radius: 50px;
  padding: clamp(0.75rem, 1.3043478261vw + 0.4076086957rem, 1.875rem) clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.3;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.2898550725vw + 0.7989130435rem, 1.125rem);
  white-space: nowrap;
}

.access_txt {
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.75;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.7692307692vw + 0.6442307692rem, 1.25rem);
}

.access_map {
  display: block;
  margin-top: clamp(2.5rem, 7.6923076923vw + 0.1923076923rem, 6.25rem);
  width: 100%;
  height: clamp(15.625rem, 65.3846153846vw + -3.9903846154rem, 47.5rem);
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
}
.access_map iframe {
  width: 100%;
  height: 100%;
}

/*-------------------------------------------------------------------------------
  service
--------------------------------------------------------------------------------*/
.service_wrapper {
  padding-bottom: clamp(3.75rem, 14.1025641026vw + -0.4807692308rem, 10.625rem);
}

.service_unit {
  width: 100%;
}
.service_unit:not(:first-child) {
  margin-top: clamp(3.75rem, 11.5384615385vw + 0.2884615385rem, 9.375rem);
}

.service_ttl {
  margin-bottom: clamp(1.875rem, 8.3333333333vw + -0.625rem, 5.9375rem);
}

.service_block {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: clamp(3.75rem, 10.3092783505vw + -2.8479381443rem, 8.75rem);
}
@media (max-width: 1024px) {
  .service_block {
    flex-direction: column;
    gap: clamp(0.9375rem, 4.1390728477vw + -0.1490066225rem, 2.5rem);
  }
}
.service_block + .service_block {
  margin-top: clamp(3.125rem, 8.9743589744vw + 0.4326923077rem, 7.5rem);
  flex-direction: row-reverse;
}
@media (max-width: 1024px) {
  .service_block + .service_block {
    flex-direction: column;
  }
}

.service_txt {
  width: clamp(28.6875rem, 27.1907216495vw + 11.2854381443rem, 41.875rem);
}
@media (max-width: 1024px) {
  .service_txt {
    width: 100%;
  }
}

.service_sttl {
  margin-bottom: clamp(0.625rem, 5.1282051282vw + -0.9134615385rem, 3.125rem);
}

.service_img {
  width: clamp(31.625rem, 36.5979381443vw + 8.2023195876rem, 49.375rem);
  aspect-ratio: 79/47;
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  overflow: hidden;
}
.service_img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 1024px) {
  .service_img {
    width: 100%;
  }
}

/*-------------------------------------------------------------------------------
  flow
--------------------------------------------------------------------------------*/
.flow_wrapper {
  position: relative;
}

.flow_ill {
  position: absolute;
  display: block;
  top: clamp(5.625rem, 14.1025641026vw + 1.3942307692rem, 12.5rem);
  right: clamp(0.9375rem, 13.4615384615vw + -3.1009615385rem, 7.5rem);
  width: clamp(5rem, 13.4615384615vw + 0.9615384615rem, 11.5625rem);
  aspect-ratio: 185/320;
  z-index: 1;
}
.flow_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.flow_caption {
  margin-right: 10vw;
}

.flow_list {
  position: relative;
  counter-reset: number 0;
  margin-top: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  margin-left: clamp(0rem, 6.4102564103vw + -1.9230769231rem, 3.125rem);
  margin-right: clamp(0rem, 6.4102564103vw + -1.9230769231rem, 3.125rem);
}
.flow_list::after {
  position: absolute;
  display: block;
  content: "";
  top: clamp(2rem, 4.1025641026vw + 0.7692307692rem, 4rem);
  left: clamp(2rem, 4.1025641026vw + 0.7692307692rem, 4rem);
  height: 80%;
  width: 1px;
  background: #009443;
}

.flow_unit {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 1.0256410256vw + 0.1923076923rem, 1rem);
}

.flow_number {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: clamp(4rem, 8.2051282051vw + 1.5384615385rem, 8rem);
  aspect-ratio: 1/1;
  border: 1px solid #009443;
  border-radius: 50%;
  color: #009443;
  background: #F4FFC3;
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(0.875rem, 1.2820512821vw + 0.4903846154rem, 1.5rem);
  z-index: 1;
}
.flow_number::after {
  display: block;
  counter-increment: number 1;
  content: counter(number, decimal-leading-zero) " ";
  font-size: clamp(1.625rem, 1.7948717949vw + 1.0865384615rem, 2.5rem);
}

.flow_ttl {
  background: #fff;
  border-radius: 50px;
  color: #009443;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.5;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.0625rem, 1.4102564103vw + 0.6394230769rem, 1.75rem);
  padding-top: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem);
  padding-bottom: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem);
  padding-left: clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  padding-right: clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  flex: 1;
}

.flow_txt {
  margin-left: clamp(4.375rem, 14.6153846154vw + -0.0096153846rem, 11.5rem);
  align-items: center;
  padding-bottom: clamp(0.9375rem, 1.9230769231vw + 0.3605769231rem, 1.875rem);
}

.flow_phone {
  display: flex;
  align-items: center;
}
@media (max-width: 1260px) {
  .flow_phone {
    align-items: flex-start;
    flex-direction: column;
    margin-top: 30px;
  }
}

.flow_phone_ttl {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.9375rem, 0.3846153846vw + 0.8221153846rem, 1.125rem);
  color: #009443;
  margin-right: clamp(0.5rem, 1.2886597938vw + -0.324742268rem, 1.125rem);
}

.flow_phone_number {
  display: block;
  color: #009443;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.8;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.8125rem, 1.6666666667vw + 0.5rem, 2.375rem);
}

.flow_phone_hours {
  padding: 8px 14px;
  border: 1px solid #009443;
  border-radius: 8px;
  color: #009443;
  margin-left: clamp(0.625rem, 2.3195876289vw + -0.8595360825rem, 1.75rem);
  font-weight: 600;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.8125rem, 0.2564102564vw + 0.7355769231rem, 0.9375rem);
}
@media (max-width: 1260px) {
  .flow_phone_hours {
    margin-left: 0;
  }
}

.faq_ill {
  position: absolute;
  display: block;
  top: -50px;
  right: clamp(0.9375rem, 19.2307692308vw + -4.8317307692rem, 10.3125rem);
  width: clamp(10.5rem, 34.4871794872vw + 0.1538461538rem, 27.3125rem);
  aspect-ratio: 437/314;
}
@media (max-width: 768px) {
  .faq_ill {
    top: -40px;
  }
}
.faq_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.faq_unit:not(:first-child) {
  margin-top: clamp(2.5rem, 7.6923076923vw + 0.1923076923rem, 6.25rem);
}

.faq_ttl {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.5;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.25rem, 1.0256410256vw + 0.9423076923rem, 1.75rem);
  color: #009443;
  margin-bottom: clamp(0.9375rem, 1.9230769231vw + 0.3605769231rem, 1.875rem);
}

.faq_list + .faq_list {
  margin-top: clamp(1.25rem, 2.0512820513vw + 0.6346153846rem, 2.25rem);
}

.faq-question,
.faq-answer {
  position: relative;
  display: block;
  z-index: 1;
}

.faq-question {
  cursor: pointer;
}

.faq-answer {
  display: none;
  margin-top: clamp(0.4375rem, 0.3846153846vw + 0.3221153846rem, 0.625rem);
}

.faq_inner {
  display: block;
  position: relative;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.8;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1rem, 0.5128205128vw + 0.8461538462rem, 1.25rem);
  padding-top: clamp(0.875rem, 1.7948717949vw + 0.3365384615rem, 1.75rem);
  padding-bottom: clamp(0.875rem, 1.7948717949vw + 0.3365384615rem, 1.75rem);
  padding-left: clamp(4rem, 9.7435897436vw + 1.0769230769rem, 8.75rem);
  padding-right: clamp(3.125rem, 9.6153846154vw + 0.2403846154rem, 7.8125rem);
  border-radius: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  color: #009443;
}
.faq_inner::before {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  content: "Q";
  font-weight: 700;
  letter-spacing: calc(0 * 0.001em);
  line-height: 1.2;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(2.25rem, 3.5897435897vw + 1.1730769231rem, 4rem);
  color: #009443;
}
@media (max-width: 768px) {
  .faq_inner::before {
    top: 7px;
    transform: translateY(0);
  }
}
.faq-question .faq_inner {
  background-color: #EAEDF3;
}
.faq-answer .faq_inner {
  background-color: #EBF8A3;
}
.faq-answer .faq_inner::before {
  content: "A";
}

.toggle-icon {
  position: absolute;
  display: block;
  top: 50%;
  transform: translateY(-50%);
  right: clamp(1.25rem, 4.4871794872vw + -0.0961538462rem, 3.4375rem);
  transform: translateY(-50%);
  width: clamp(1.25rem, 0.8974358974vw + 0.9807692308rem, 1.6875rem);
  height: clamp(1.25rem, 0.8974358974vw + 0.9807692308rem, 1.6875rem);
  color: #333333;
  transition: transform 0.5s ease;
}
@media (max-width: 768px) {
  .toggle-icon {
    top: clamp(1.125rem, 0.5747126437vw + 0.974137931rem, 1.25rem);
    transform: translateY(0);
  }
}
.toggle-icon::before, .toggle-icon::after {
  position: absolute;
  content: "";
  top: 50%;
  left: 50%;
  width: 4px;
  height: 100%;
  border-radius: 2px;
  background: #009443;
  z-index: 1;
  transform: translate(-50%, -50%);
  transition: transform 0.5s ease;
}
@media (max-width: 768px) {
  .toggle-icon::before, .toggle-icon::after {
    width: 3px;
  }
}
.toggle-icon::before {
  transform: translate(-50%, -50%) rotate(0deg);
}
.toggle-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.faq-question.is-open .toggle-icon::before {
  transform: translate(-50%, -50%) rotate(90deg);
}
.faq-question.is-open .toggle-icon::after {
  transform: translate(-50%, -50%) rotate(270deg);
}

.faq-question .faq_inner {
  transition: background-color 0.2s ease, color 0.2s ease;
}
.faq-question:hover .faq_inner, .faq-question:focus-within .faq_inner, .faq-question.is-open .faq_inner {
  background-color: #d9dee8;
}

/*-------------------------------------------------------------------------------
  news
--------------------------------------------------------------------------------*/
.news_detail_wrapper {
  padding-top: 50px;
  margin-top: 50px;
}

.news_wrapper {
  padding-bottom: clamp(3.75rem, 17.9487179487vw + -1.6346153846rem, 12.5rem);
}

.news_list {
  border-top: 4px solid #D1F40D;
}

.news_unit {
  position: relative;
  padding-top: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  padding-bottom: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  border-bottom: 4px solid #D1F40D;
  overflow: hidden;
}
.news_unit::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(100%);
  background-color: rgba(209, 244, 13, 0.2);
  transition: all 0.3s ease;
}
@media (min-width: 769px) {
  .news_unit:hover::before {
    transform: translateX(0);
  }
}

.news_link {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: clamp(1.25rem, 5.1282051282vw + -0.2884615385rem, 3.75rem);
  z-index: 1;
  padding: 0 clamp(0.625rem, 5.1282051282vw + -0.9134615385rem, 3.125rem);
}
@media (max-width: 560px) {
  .news_link {
    flex-direction: column;
    align-items: normal;
  }
}

.news_block {
  flex: 1;
}

.news_info {
  display: flex;
  gap: clamp(0.625rem, 0.641025641vw + 0.4326923077rem, 0.9375rem);
  align-items: center;
}

.cmn_date {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.75;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1rem, 0.5128205128vw + 0.8461538462rem, 1.25rem);
  color: #009443;
}

.cmn_tag {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.3846153846vw + 0.7596153846rem, 1.0625rem);
  background: #D1F40D;
  color: #009443;
  border-radius: 50px;
  padding: 5px 30px;
}

.news_thumb {
  width: clamp(12.5rem, 14.5161290323vw + 7.4193548387rem, 23.75rem);
  aspect-ratio: 19/15;
  border-radius: clamp(0.625rem, 2.5641025641vw + -0.1442307692rem, 1.875rem);
  overflow: hidden;
}
@media (max-width: 560px) {
  .news_thumb {
    width: 100%;
  }
}
.news_thumb img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
}
@media (min-width: 769px) {
  .news_thumb:hover img {
    transform: scale(1.1);
  }
}

.news_ttl {
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.5;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.25rem, 1.0256410256vw + 0.9423076923rem, 1.75rem);
  margin-top: clamp(0.3125rem, 1.2820512821vw + -0.0721153846rem, 0.9375rem);
  color: #009443;
}
.news_ttl.detail_ttl {
  display: block;
  width: 100%;
  padding-bottom: clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  border-bottom: 4px solid #D1F40D;
  margin-bottom: clamp(1.25rem, 5.1282051282vw + -0.2884615385rem, 3.75rem);
}

.news_txt {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  margin-top: clamp(0.9375rem, 1.9230769231vw + 0.3605769231rem, 1.875rem);
  color: #222;
}

.detail_txt {
  display: block;
  margin-top: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
  font-weight: 500;
  letter-spacing: calc(50 * 0.001em);
  line-height: 2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  color: #222;
}

.news_read {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.read_btn {
  display: flex;
  align-items: center;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  color: #009443;
  margin-top: clamp(1.25rem, 2.5641025641vw + 0.4807692308rem, 2.5rem);
  transition: all 0.3s ease;
}
.read_btn::before {
  display: block;
  content: "";
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: clamp(1.375rem, 0.4347826087vw + 1.2608695652rem, 1.75rem) auto;
          mask-size: clamp(1.375rem, 0.4347826087vw + 1.2608695652rem, 1.75rem) auto;
  -webkit-mask-image: url(../images/icon_read.svg);
          mask-image: url(../images/icon_read.svg);
  background-color: #009443;
  margin-right: clamp(0.5rem, 1.0256410256vw + 0.1923076923rem, 1rem);
  width: clamp(1.375rem, 0.7692307692vw + 1.1442307692rem, 1.75rem);
  aspect-ratio: 28/22;
  transition: all 0.3s ease;
}

.pagination_wrapper {
  margin-top: clamp(1.25rem, 8.9743589744vw + -1.4423076923rem, 5.625rem);
}

.nav-links {
  display: flex;
  justify-content: center;
  align-items: center;
}

.back-to-category {
  position: relative;
  display: flex;
  justify-content: center;
  padding-top: clamp(3.75rem, 14.1025641026vw + -0.4807692308rem, 10.625rem);
  padding-bottom: clamp(5rem, 16.6666666667vw + 0rem, 13.125rem);
}

.news_back-btn {
  position: relative;
  padding-top: clamp(0.625rem, 0.641025641vw + 0.4326923077rem, 0.9375rem);
  padding-bottom: clamp(0.625rem, 0.641025641vw + 0.4326923077rem, 0.9375rem);
}
.news_back-btn a {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  color: #828282;
  background: #E2E2E2;
  border-radius: 50px;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.1;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(0.875rem, 0.5128205128vw + 0.7211538462rem, 1.125rem);
  overflow: hidden;
  padding: clamp(0.625rem, 0.641025641vw + 0.4326923077rem, 0.9375rem);
  padding-left: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
  padding-right: clamp(4.375rem, 5.1282051282vw + 2.8365384615rem, 6.875rem);
  transition: all 0.3s ease;
}
.news_back-btn a span {
  position: relative;
  z-index: 1;
}
.news_back-btn a::before {
  content: "<";
  margin-right: 10px;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.25rem, 1.2820512821vw + 0.8653846154rem, 1.875rem);
  z-index: 1;
}
.news_back-btn a::after {
  position: absolute;
  content: "";
  inset: 0;
  transform: translateX(100%);
  background-color: #D1F40D;
  transition: transform 0.3s ease;
  transform: scaleX(0);
  transform-origin: left;
}
@media (min-width: 769px) {
  .news_back-btn a:hover {
    color: #09B464;
  }
  .news_back-btn a:hover::after {
    transform: scaleX(1);
    transform-origin: right;
  }
}

.news_ill {
  position: absolute;
  display: block;
  top: -50px;
  right: clamp(0.3125rem, 1.2820512821vw + -0.0721153846rem, 0.9375rem);
  width: clamp(4rem, 4.2307692308vw + 2.7307692308rem, 6.0625rem);
  aspect-ratio: 97/173;
  z-index: 1;
  pointer-events: none;
}
@media (max-width: 768px) {
  .news_ill {
    top: -40px;
  }
}
.news_ill img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.page-numbers {
  display: flex;
  justify-content: center;
  align-items: center;
  width: clamp(2.8125rem, 3.2051282051vw + 1.8509615385rem, 4.375rem);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #E2E2E2;
  color: #828282;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.2;
  font-family: "Montserrat", sans-serif;
  font-size: clamp(1.125rem, 1.5384615385vw + 0.6634615385rem, 1.875rem);
  margin-left: clamp(0.1875rem, 0.4487179487vw + 0.0528846154rem, 0.40625rem);
  margin-right: clamp(0.1875rem, 0.4487179487vw + 0.0528846154rem, 0.40625rem);
  transition: all 0.3s ease;
}
@media (min-width: 769px) {
  .page-numbers:hover {
    background: #D1F40D;
    color: #009443;
  }
}
.page-numbers.prev {
  margin-right: clamp(0.4375rem, 0.7692307692vw + 0.2067307692rem, 0.8125rem);
}
.page-numbers.next {
  margin-left: clamp(0.4375rem, 0.7692307692vw + 0.2067307692rem, 0.8125rem);
}
.page-numbers.dots {
  background: none;
  margin: 0;
}
.page-numbers.current {
  background: #009443;
  color: #D1F40D;
}

.swiper_news {
  margin: 0 auto;
}
.swiper_news .swiper {
  position: relative;
  overflow: visible;
  padding-left: clamp(1.25rem, 10.4838709677vw + -2.4193548387rem, 9.375rem);
  padding-right: clamp(1.25rem, 10.4838709677vw + -2.4193548387rem, 9.375rem);
}
@media (max-width: 560px) {
  .swiper_news .swiper {
    padding-left: 0;
    padding-right: 0;
  }
}

.swiper-single-controller {
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.swiper-button-next,
.swiper-button-prev {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(3.125rem, 5.1282051282vw + 1.5865384615rem, 5.625rem);
  height: clamp(3.125rem, 5.1282051282vw + 1.5865384615rem, 5.625rem);
  background-color: #D1F40D;
  border-radius: 50%;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.swiper-button-next::before,
.swiper-button-prev::before {
  content: "";
  display: block;
  -webkit-mask-image: url(../images/arrow_btn.svg);
          mask-image: url(../images/arrow_btn.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  background: #009443;
  width: clamp(1.25rem, 0.641025641vw + 1.0576923077rem, 1.5625rem);
  aspect-ratio: 25/22;
}
@media (min-width: 769px) {
  .swiper-button-next:hover,
  .swiper-button-prev:hover {
    background: #009443;
  }
  .swiper-button-next:hover::before,
  .swiper-button-prev:hover::before {
    transition: background-color 0.3s ease;
    animation-name: slideOutinX;
    animation-duration: 0.6s;
    animation-timing-function: ease;
    background: #D1F40D;
  }
}
.swiper-button-next::after,
.swiper-button-prev::after {
  display: none;
}

.swiper-button-prev::before {
  transform: rotate(-180deg);
}
@media (min-width: 769px) {
  .swiper-button-prev:hover::before {
    animation-name: slideInOutX;
  }
}

.swiper_news-next {
  margin-right: clamp(0rem, 7.2580645161vw + -2.5403225806rem, 5.625rem);
}
@media (max-width: 560px) {
  .swiper_news-next {
    margin-right: -6vw;
  }
}

.swiper_news-prev {
  margin-left: clamp(0rem, 7.2580645161vw + -2.5403225806rem, 5.625rem);
}
@media (max-width: 560px) {
  .swiper_news-prev {
    margin-left: -6vw;
  }
}

.news_media {
  width: 100%;
  aspect-ratio: 1100/580;
  margin: 0 auto;
  overflow: hidden;
  border-radius: clamp(0.9375rem, 4.4871794872vw + -0.4086538462rem, 3.125rem);
}
.news_media img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.thumb-wrapper {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(0.9375rem, 0.9689922481vw + 0.4723837209rem, 1.5625rem);
  margin-top: clamp(1.25rem, 3.8461538462vw + 0.0961538462rem, 3.125rem);
  padding-left: clamp(1.25rem, 10.4838709677vw + -2.4193548387rem, 9.375rem);
  padding-right: clamp(1.25rem, 10.4838709677vw + -2.4193548387rem, 9.375rem);
}
@media (max-width: 768px) {
  .thumb-wrapper {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(0.625rem, 1.4367816092vw + 0.2478448276rem, 0.9375rem);
  }
}
@media (max-width: 560px) {
  .thumb-wrapper {
    padding-left: 0;
    padding-right: 0;
  }
}

.thumb-media {
  position: relative;
  padding-top: 0;
  aspect-ratio: 200/140;
  cursor: pointer;
  border-radius: clamp(0.5rem, 1.5384615385vw + 0.0384615385rem, 1.25rem);
  transition: all 0.3s ease;
  overflow: hidden;
}
.thumb-media::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: #009443;
  opacity: 0;
  mix-blend-mode: multiply;
  transition: all 0.3s ease;
  z-index: 1;
}
.thumb-media img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: all 0.3s ease;
}
.thumb-media-active::before {
  opacity: 0.6;
}
.thumb-media-active img {
  transform: scale(1.1);
}

/*-------------------------------------------------------------------------------
  privacy
--------------------------------------------------------------------------------*/
.privacy_wrapper {
  padding-bottom: clamp(5rem, 15.3846153846vw + 0.3846153846rem, 12.5rem);
}

.privacy_unit {
  margin-bottom: clamp(1.875rem, 3.8461538462vw + 0.7211538462rem, 3.75rem);
}

.privacy_ttl {
  display: block;
  width: 100%;
  padding-bottom: clamp(0.9375rem, 1.2820512821vw + 0.5528846154rem, 1.5625rem);
  margin-bottom: clamp(0.625rem, 1.2820512821vw + 0.2403846154rem, 1.25rem);
  border-bottom: 1px solid #009443;
  font-weight: 700;
  letter-spacing: calc(50 * 0.001em);
  line-height: 1.5;
  font-family: "Noto Sans JP", "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", sans-serif;
  font-size: clamp(1.0625rem, 1.4102564103vw + 0.6394230769rem, 1.75rem);
  color: #009443;
}

.privacy_list {
  margin-top: 10px;
}
.privacy_list li {
  display: flex;
}
.privacy_list li::before {
  content: "・";
  margin-right: 2px;
}

.notfound_wrapper {
  padding-bottom: clamp(5rem, 15.3846153846vw + 0.3846153846rem, 12.5rem);
}

input:not([type=radio]):not([type=checkbox]).val-err,
select.val-err,
textarea.val-err {
  background-color: #FFE4E4 !important;
}

p.val-err {
  color: #e40000;
  font-size: 0.8em;
}
p.val-err::before {
  content: "※";
}

.check_no-through {
  color: #e40000;
}

input:not([type=radio]):not([type=checkbox]).val-through,
select.val-through,
textarea.val-through {
  background-color: #E2FBE2 !important;
}

.check_any_required.val-err input:not([type=radio]):not([type=checkbox]),
.check_any_required.val-err select,
.check_any_required.val-err textarea {
  background-color: #FFE4E4 !important;
}
.check_any_required.val-through input:not([type=radio]):not([type=checkbox]):not(.val-err),
.check_any_required.val-through select:not(.val-err),
.check_any_required.val-through textarea:not(.val-err) {
  background-color: #E2FBE2 !important;
}

/*# sourceMappingURL=common.css.map*/