@charset "UTF-8";
/* stylelint-disable-next-line scss/dollar-variable-pattern */
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* もちろん、より直感的なbox-sizingに設定 */
  padding: 0; /* パディングも常に0に */
  margin: 0; /* マージンは0に */
}

:where([hidden]:not([hidden=until-found])) {
  display: none !important; /* hiddenは非表示を意味します */
}

:where(html) {
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
      -ms-text-size-adjust: none;
          text-size-adjust: none; /* iOSのランドスケープでテキストが調整されないようにする */
  color-scheme: dark light; /* ユーザーがダークテーマを好む場合、自動的にダークテーマになる */
}

@supports not (min-block-size: 100dvb) {
  :where(html) {
    block-size: 100%;
  }
}
:where(body) { /* サファリ以外のブラウザのフォールバック */
  block-size: 100dvb; /* 1dvbは動的ビューポートの長さの1%、100dvbで高さいっぱいに */
  font-family: system-ui, sans-serif; /* timeの代わりにシステムフォントを使用 */
  line-height: 1.5; /* アクセシブルな行の高さ */
  -webkit-font-smoothing: antialiased; /* テキストのレンダリングを改善 */
}

:where(input, button, textarea, select) {
  font: inherit; /* フォーム コントロールは親フォントを継承 */
  color: inherit; /* カラーも継承 */
}

:where(textarea) { /* テキストエリアの水平リサイズを無効に */
  resize: block;
}

:where(button, label, select, summary, [role=button], [role=option]) {
  cursor: pointer; /* インタラクティブなものにカーソルを合わせる */
}

:where(:disabled) {
  cursor: not-allowed; /* フォームコントロール無効時のカーソルを許可しない */
}

:where(label:has(> input:disabled), label:has(+ input:disabled)) {
  cursor: not-allowed; /* ラベルにもカーソルを許可しない */
}

:where(button) {
  border-style: solid; /* ボタンのボーダーのスタイルを設定しやすくする */
}

:where(a) {
  text-underline-offset: 0.2em; /* 下線の上にスペースを追加する */
}

:where(ul, ol) {
  list-style: none; /* ビュレットを削除、必要に応じて手動で追加する */
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block; /* 置換された要素をより予測可能にする */
}

:where(p, h1, h2, h3, h4, h5, h6) {
  font-size: 1em;
  overflow-wrap: break-word; /* 長い単語は改行 */
}

:where(hr) { /* より一貫性のある、スタイリッシュなhr */
  block-size: 0;
  overflow: visible;
  color: inherit;
  border: none;
  -webkit-border-before: #cbcbcb 1px solid;
          border-block-start: #cbcbcb 1px solid;
}

:where(:focus-visible) { /* より一貫性のある、カスタマイズ可能なフォーカスのアウトライン */
  outline: 2px solid var(--color-pri, #5387EB);
  outline-offset: 2px;
}

@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes up-motion {
  0% {
    opacity: 0;
    -webkit-transform: translateY(2rem);
            transform: translateY(2rem);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes up-motion {
  0% {
    opacity: 0;
    -webkit-transform: translateY(2rem);
            transform: translateY(2rem);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes image {
  0% {
    -webkit-filter: blur(5px);
            filter: blur(5px);
    opacity: 0;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
  100% {
    -webkit-filter: blur(0);
            filter: blur(0);
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes image {
  0% {
    -webkit-filter: blur(5px);
            filter: blur(5px);
    opacity: 0;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
  100% {
    -webkit-filter: blur(0);
            filter: blur(0);
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
* {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden; /* animation時のにじみ防止 */
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-font-smoothing: antialiased; /* animation時の文字にじみ防止 */
  -moz-osx-font-smoothing: grayscale; /* animation時の文字にじみ防止 */
}

:root {
  --font-size: 62.5;
  --color-base-bg: #fff;
  --color-base-text: #333;
  --color-primary: #7FCE43;
  --color-secondary: #18B9AC;
  --color-tertiary: #F2F5EF;
  --color-red: #CB0000;
  --color-link: #65bb22;
  --color-link-hover: #56b011;
  --font-jp:Noto Sans JP, sans-serif;
  --font-size1014:clamp(1rem, 0.818rem + 0.78vw, 1.4rem);
  --font-size1113:clamp(1.1rem, 1.009rem + 0.39vw, 1.3rem);
  --font-size1213:clamp(1.2rem, 1.155rem + 0.19vw, 1.3rem);
  --font-size1214:clamp(1.2rem, 1.109rem + 0.39vw, 1.4rem);
  --font-size1215:clamp(1.2rem, 1.091rem + 0.55vw, 1.5rem);
  --font-size1416:clamp(1.4rem, 1.309rem + 0.39vw, 1.6rem);
  --font-size1517:clamp(1.5rem, 1.409rem + 0.39vw, 1.7rem);
  --font-size1618:clamp(1.6rem, 1.509rem + 0.39vw, 1.8rem);
  --font-size1820:clamp(1.8rem, 1.709rem + 0.39vw, 2rem);
  -webkit-font-variant-ligatures: none;
          font-variant-ligatures: none; /* CJK言語（中国語、日本語、韓国語）での句読点の間隔を変更。 */
}

html {
  height: -webkit-fill-available;
  height: -moz-available;
  height: fill-available;
  font-size: calc(var(--font-size) * 0.9%);
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  scroll-padding-top: 0;
  background: #fff;
  scroll-behavior: smooth;
  -webkit-tap-highlight-color: rgba(12, 106, 238, 0.2);
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

html,
body {
  width: 100%;
  min-height: -webkit-fill-available;
  min-height: -moz-available;
  min-height: fill-available;
  padding: 0;
  margin: 0;
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
  -webkit-font-smoothing: antialiased;
}

body {
  position: relative;
  height: 100%;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(1.6rem, 1.509rem + 0.39vw, 1.8rem);
  font-weight: 400;
  font-optical-sizing: auto;
  line-height: 1;
  color: var(--color-base-text);
  overflow-wrap: anywhere;
  background: #fff;
  -webkit-animation: fadein ease-out 0.3s both 0.1s;
          animation: fadein ease-out 0.3s both 0.1s;
}
body.is-gnav-open {
  height: 100%;
  overflow: hidden;
}

body:has(#js-globalnav-sp.is-open) .l-container {
  overflow: auto;
  scrollbar-gutter: stable;
}

:where(section),
:where(article) {
  position: relative;
  text-align: left;
  letter-spacing: clamp(0.01em, 0.013vw, 0.02em);
}

:where(p, dl, dt, dd, ol, ul, li) {
  padding: 0;
  margin: 0;
}

:where(img) {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

:where(strong) {
  font-weight: 700;
}

:where(sup) {
  font-size: 55%;
  vertical-align: super;
}

:where(sub) {
  font-size: 55%;
  vertical-align: sub;
}

.l-main a[href^="tel:"] {
  font-weight: 700;
}
:where(.l-main a:not([class])) {
  color: #65bb22;
  text-decoration: underline;
  text-underline-offset: 0.3em;
}

:where(hr) {
  position: relative;
  width: 100%;
  height: 100px;
  clear: both;
  border: none;
  outline: none;
}
:where(hr)::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background: #F2F5EF;
}

.l-container {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: 0;
  text-align: center;
  word-wrap: break-word;
  overflow-wrap: break-word;
}

main,
.l-main,
article,
section {
  position: relative;
  display: block;
}

.l-main {
  z-index: 3;
  padding-top: 6rem;
  line-height: 1.8;
  text-align: center;
  letter-spacing: clamp(0.05em, 0.1vw, 0.1em);
}

.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 888888;
  width: 100%;
  height: 6.5rem;
  background-color: rgba(255, 255, 255, 0.95);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  opacity: 0;
  -webkit-animation: 0.5s fadein cubic-bezier(0.215, 0.61, 0.355, 1) 0s both;
          animation: 0.5s fadein cubic-bezier(0.215, 0.61, 0.355, 1) 0s both;
}
.l-header__logo {
  position: absolute;
  top: 1.1rem;
  left: min(3vw, 3.5rem);
  z-index: 2;
  display: inline-block;
}
.l-header__logo img {
  position: relative;
  width: 17rem;
  height: 4.2rem;
  -o-object-position: 0 0;
     object-position: 0 0;
}

.l-footer {
  position: relative;
  z-index: 4;
  overflow: hidden;
  text-align: center;
  border-top: #fff solid 2px;
}
.l-footer__inner {
  position: relative;
  display: -ms-grid;
  display: grid;
}
.l-footer__logo-address {
  position: relative;
  text-align: center;
  background-color: #fff;
}
.l-footer__logo-address-inner {
  width: 86%;
  max-width: 36rem;
  padding: clamp(5rem, 7vw, 8.4rem) 0;
  margin: 0 auto;
  text-align: left;
}
.l-footer__logo {
  position: relative;
  display: block;
  width: min(90vw, 23rem);
  margin: 0 auto;
}
.l-footer__address {
  position: relative;
  display: block;
  margin-top: 2.5em;
  font-size: 1.3rem;
  line-height: 2;
}
.l-footer__copyright {
  position: relative;
  display: block;
  margin-top: 2.25em;
  font-size: 1.3rem;
  line-height: 1.25;
  color: #000;
  text-align: left;
  letter-spacing: 0;
}
.l-footer__copyright i {
  font-family: Arial, Helvetica, sans-serif;
}
.l-footer__nav {
  position: relative;
  line-height: 1.5;
}
.l-footer__nav a {
  display: inline-block;
  padding: 0.75em 0;
  color: #000;
  text-decoration: underline;
  text-underline-offset: 0.3em;
  -webkit-transition: color 0.2s ease;
  transition: color 0.2s ease;
}
.l-footer__nav ul {
  margin-top: 0.25em;
}
.l-footer__nav li {
  margin-top: 0.5em;
}
.l-footer__nav-title {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
}
.l-footer__nav--consider {
  padding: clamp(5rem, 7vw, 8.4rem) 7vw;
  font-size: 1.6rem;
  line-height: 1.25;
  color: #000;
  text-align: center;
  background-color: #F5F5F5;
}
.l-footer__nav--consider .l-footer__nav-inner {
  max-width: 36rem;
  padding: 0 0 0.1em 3rem;
  margin: 0 auto;
  text-align: left;
  border-left: #7FCE43 solid 2px;
}
.l-footer__nav--other {
  padding: clamp(5rem, 7vw, 8.4rem) 7vw;
  font-size: 1.6rem;
  line-height: 1.25;
  color: #000;
  text-align: center;
  background-color: #EBEBEB;
}
.l-footer__nav--other .l-footer__nav-inner {
  max-width: 36rem;
  padding: 0 0 0.1em 3rem;
  margin: 0 auto;
  text-align: left;
  border-left: #7FCE43 solid 2px;
}

.p-globalnav-triger {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 888889;
  display: block;
  width: 6rem;
  height: 6rem;
  padding: 0;
  color: #fff;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background: transparent;
  border: none;
  outline: none;
}
.p-globalnav-triger:focus-visible {
  outline: 2px solid #65bb22;
}
.p-globalnav-triger__ic {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}
.p-globalnav-triger__ic i {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3rem;
  height: 2px;
  background: #000;
  border-radius: 0.15rem;
  -webkit-transition: ease-out 0.1s;
  transition: ease-out 0.1s;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
.p-globalnav-triger__ic i::before, .p-globalnav-triger__ic i::after {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: 3rem;
  height: 2px;
  content: "";
  background: #000;
  border-radius: 0.15rem;
}
.p-globalnav-triger__ic i::before {
  margin-top: -0.9rem;
  -webkit-transition: ease-out 0.3s 0.1s;
  transition: ease-out 0.3s 0.1s;
}
.p-globalnav-triger__ic i::after {
  margin-top: 0.7rem;
  -webkit-transition: ease-out 0.3s 0.1s;
  transition: ease-out 0.3s 0.1s;
}
.p-globalnav-triger.is-open i {
  background-color: transparent;
}
.p-globalnav-triger.is-open i::before {
  margin-top: 0;
  -webkit-transform: rotate(155deg);
          transform: rotate(155deg);
}
.p-globalnav-triger.is-open i::after {
  margin-top: 0;
  -webkit-transform: rotate(-155deg);
          transform: rotate(-155deg);
}

.p-globalnav {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100vw;
  padding-top: 6rem;
  padding-bottom: 0;
  pointer-events: none;
  visibility: hidden;
  background: #fff;
  opacity: 0;
  -webkit-transition: 0.5s ease 0.1s;
  transition: 0.5s ease 0.1s;
  -webkit-transform: translateY(-10em);
          transform: translateY(-10em);
}
.p-globalnav.is-open {
  pointer-events: all;
  visibility: visible;
  -webkit-box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2);
          box-shadow: 0 0 1rem rgba(0, 0, 0, 0.2);
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.p-globalnav__inner {
  position: relative;
  display: none;
  max-height: calc(100vh - 6rem);
  overflow-y: auto;
  text-align: center;
}
.is-open .p-globalnav__inner {
  display: block;
}
.p-globalnav__menu01 {
  position: relative;
  width: min(100%, 50rem);
  margin: 0 auto;
  text-align: left;
}
.p-globalnav__menu01 > li {
  position: relative;
  z-index: 2;
  margin-top: 1em;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: 0;
}
.p-globalnav__menu01 a {
  position: relative;
  z-index: 2;
  display: block;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  margin: 0;
  color: #333;
  text-align: center;
  text-decoration: none;
  pointer-events: all;
}
.p-globalnav__contact {
  padding-top: 3.2rem;
  padding-bottom: 6rem;
  text-align: center;
}
.p-globalnav__contact-button {
  position: relative;
  z-index: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: min(100%, 30rem);
  height: 5.6rem;
  padding-right: 0.25em;
  padding-left: 0.25em;
  overflow: hidden;
  color: #fff;
  text-decoration: none !important;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background: transparent;
  background-color: #000;
  border: 2px solid #fff;
  outline: none;
}
.p-globalnav__contact-button > span {
  position: relative;
  z-index: 2;
  padding: 0.2em 0 0.2em 3rem;
  font-size: 2rem;
  font-weight: 700;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1.25;
  text-align: center;
  text-indent: 0;
  letter-spacing: 0;
  white-space: nowrap;
}
.p-globalnav__contact-button i {
  position: absolute;
  top: 55%;
  left: 0;
  z-index: 2;
  width: 2.6rem;
  height: 2.6rem;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.p-mv {
  position: relative;
  width: 100%;
  height: 65rem;
  overflow: hidden;
  text-align: center;
}
.p-mv__inner {
  position: relative;
  width: min(100%, 192rem);
  height: 100%;
  margin: 0 auto;
}
.p-mv__bg-rt {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  width: 90%;
}
.p-mv__bg-lb {
  position: absolute;
  bottom: 45%;
  left: 0;
  z-index: 2;
  width: 90%;
}
.p-mv__bg-rt img, .p-mv__bg-lb img {
  width: 100%;
  max-width: 120rem;
  height: auto;
  -webkit-transition: -webkit-filter 0.5s ease;
  transition: -webkit-filter 0.5s ease;
  transition: filter 0.5s ease;
  transition: filter 0.5s ease, -webkit-filter 0.5s ease;
  -webkit-animation: mvbg 3.5s infinite linear;
          animation: mvbg 3.5s infinite linear;
}
.p-mv__image {
  position: relative;
  z-index: 3;
  width: 100%;
  height: 100%;
  overflow: hidden;
  text-align: right;
}
.p-mv__image img {
  position: absolute;
  top: 5rem;
  left: 50%;
  width: clamp(37rem, 102vw, 42rem);
  max-width: 112rem;
  height: auto;
  opacity: 0;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
  -webkit-animation: mvimage 2s ease-in-out 0s both;
          animation: mvimage 2s ease-in-out 0s both;
}
.p-mv__image picture:nth-child(2) img {
  -webkit-animation: mvimage 1s ease-in-out 0.5s both;
          animation: mvimage 1s ease-in-out 0.5s both;
}
.p-mv__image picture:nth-child(3) img {
  -webkit-animation: mvimage 0.5s ease-in-out 0.7s both;
          animation: mvimage 0.5s ease-in-out 0.7s both;
}
.p-mv__text01 {
  position: absolute;
  top: min(86vw, 37rem);
  left: 50%;
  z-index: 4;
  width: min(90%, 58rem);
  padding: 2rem 1rem;
  clip-path: inset(0 100% 0 0);
  color: #fff;
  background-color: #7FCE43;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-animation: mvtext0101 2.5s ease-out 0.7s both;
          animation: mvtext0101 2.5s ease-out 0.7s both;
}
.p-mv__text01-l {
  display: block;
  font-size: clamp(2rem, 6.7vw, 4rem);
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
.p-mv__text01-l span {
  display: block;
}
.p-mv__text01-l span:nth-child(1) {
  -webkit-animation: mvtext0102 0.9s ease-in 1.3s both;
          animation: mvtext0102 0.9s ease-in 1.3s both;
}
.p-mv__text01-l span:nth-child(2) {
  -webkit-animation: mvtext0102 1s ease-in 1.8s both;
          animation: mvtext0102 1s ease-in 1.8s both;
}
.p-mv__text01-s {
  display: block;
  margin-top: 1rem;
  font-size: clamp(1.4rem, 4vw, 2.2rem);
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.25em;
  -webkit-animation: fadein 0.3s ease-in 3s both;
          animation: fadein 0.3s ease-in 3s both;
}
.p-mv__text02 {
  position: absolute;
  top: min(115vw, 50rem);
  left: 0%;
  z-index: 4;
  width: 100%;
  font-weight: 700;
  color: #fff;
}
.p-mv__text02-01, .p-mv__text02-02 {
  position: relative;
  z-index: 2;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1rem min(10vw, 3em) 1.2rem;
  font-size: clamp(2.2rem, 5vw, 2.6rem);
  line-height: 1;
  opacity: 0;
}
.p-mv__text02-01::before, .p-mv__text02-02::before {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: -1;
  display: inline-block;
  width: 100%;
  height: 100%;
  content: "";
  background-color: #006B93;
  background-color: #7FCE43;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.p-mv__text02-01 span, .p-mv__text02-02 span {
  position: relative;
  display: inline-block;
  font-size: 130%;
  vertical-align: -0.05em;
}
.p-mv__text02-01 span::before, .p-mv__text02-02 span::before {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: -1;
  display: inline-block;
  width: 2em;
  height: 2em;
  content: "";
  background-color: #006B93;
  opacity: 0;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.p-mv__text02-01 {
  -webkit-animation: mvtext0201 7s ease-out 3s infinite;
          animation: mvtext0201 7s ease-out 3s infinite;
}
.p-mv__text02-01::before {
  -webkit-animation: mvtext0202 7s ease-out 3s infinite;
          animation: mvtext0202 7s ease-out 3s infinite;
}
.p-mv__text02-01 span::before {
  -webkit-animation: mvtext0203 7s ease-out 3s infinite;
          animation: mvtext0203 7s ease-out 3s infinite;
}
.p-mv__text02-02 {
  margin: 1rem 0 0 auto;
  -webkit-animation: mvtext0201 7s ease-out 3.5s infinite;
          animation: mvtext0201 7s ease-out 3.5s infinite;
}
.p-mv__text02-02::before {
  -webkit-animation: mvtext0202 7s ease-out 3.5s infinite;
          animation: mvtext0202 7s ease-out 3.5s infinite;
}
.p-mv__text02-02 span::before {
  -webkit-animation: mvtext0203 7s ease-out 3.5s infinite;
          animation: mvtext0203 7s ease-out 3.5s infinite;
}

@-webkit-keyframes mvbg {
  0% {
    -webkit-filter: hue-rotate(0deg);
            filter: hue-rotate(0deg);
  }
  50% {
    -webkit-filter: hue-rotate(70deg);
            filter: hue-rotate(70deg);
  }
  100% {
    -webkit-filter: hue-rotate(0deg);
            filter: hue-rotate(0deg);
  }
}

@keyframes mvbg {
  0% {
    -webkit-filter: hue-rotate(0deg);
            filter: hue-rotate(0deg);
  }
  50% {
    -webkit-filter: hue-rotate(70deg);
            filter: hue-rotate(70deg);
  }
  100% {
    -webkit-filter: hue-rotate(0deg);
            filter: hue-rotate(0deg);
  }
}
@-webkit-keyframes mvimage {
  0% {
    clip-path: circle(0% at 50% 50%);
    opacity: 0.2;
  }
  100% {
    clip-path: circle(100% at 50% 50%);
    opacity: 1;
  }
}
@keyframes mvimage {
  0% {
    clip-path: circle(0% at 50% 50%);
    opacity: 0.2;
  }
  100% {
    clip-path: circle(100% at 50% 50%);
    opacity: 1;
  }
}
@-webkit-keyframes mvtext0101 {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-70%, -50%);
            transform: translate(-70%, -50%);
  }
  10% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-70%, -50%);
            transform: translate(-70%, -50%);
  }
  30% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  100% {
    clip-path: inset(0 0 0 0);
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@keyframes mvtext0101 {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-70%, -50%);
            transform: translate(-70%, -50%);
  }
  10% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-70%, -50%);
            transform: translate(-70%, -50%);
  }
  30% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  100% {
    clip-path: inset(0 0 0 0);
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}
@-webkit-keyframes mvtext0101-pc {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  10% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  30% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
    -webkit-transform: translate(-5%, -50%);
            transform: translate(-5%, -50%);
  }
  100% {
    clip-path: inset(0 0 0 0);
    -webkit-transform: translate(0%, -50%);
            transform: translate(0%, -50%);
  }
}
@keyframes mvtext0101-pc {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  10% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  30% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
    -webkit-transform: translate(-5%, -50%);
            transform: translate(-5%, -50%);
  }
  100% {
    clip-path: inset(0 0 0 0);
    -webkit-transform: translate(0%, -50%);
            transform: translate(0%, -50%);
  }
}
@-webkit-keyframes mvtext0102 {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes mvtext0102 {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes mvtext0201 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  5% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  10% {
    opacity: 1;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  50% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  90% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
}
@keyframes mvtext0201 {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  5% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  10% {
    opacity: 1;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
  50% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  90% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(-10%);
            transform: translateX(-10%);
  }
}
@-webkit-keyframes mvtext0201pc {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
  5% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
  10% {
    opacity: 1;
    -webkit-transform: translateX(-13%);
            transform: translateX(-13%);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateX(7%);
            transform: translateX(7%);
  }
  90% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
}
@keyframes mvtext0201pc {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
  5% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
  10% {
    opacity: 1;
    -webkit-transform: translateX(-13%);
            transform: translateX(-13%);
  }
  80% {
    opacity: 1;
    -webkit-transform: translateX(7%);
            transform: translateX(7%);
  }
  90% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  100% {
    opacity: 0;
    -webkit-transform: translateX(-20%);
            transform: translateX(-20%);
  }
}
@-webkit-keyframes mvtext0202 {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  5% {
    clip-path: inset(0 100% 0 0);
  }
  10% {
    clip-path: inset(0 0 0 0);
  }
  98% {
    clip-path: inset(0 0 0 0);
  }
  100% {
    clip-path: inset(0 100% 0 0);
  }
}
@keyframes mvtext0202 {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  5% {
    clip-path: inset(0 100% 0 0);
  }
  10% {
    clip-path: inset(0 0 0 0);
  }
  98% {
    clip-path: inset(0 0 0 0);
  }
  100% {
    clip-path: inset(0 100% 0 0);
  }
}
@-webkit-keyframes mvtext0203 {
  0% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  15% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  20% {
    -webkit-transform: translate(-50%, -50%) scale(1.5);
            transform: translate(-50%, -50%) scale(1.5);
  }
  25% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(2);
            transform: translate(-50%, -50%) scale(2);
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(2);
            transform: translate(-50%, -50%) scale(2);
  }
}
@keyframes mvtext0203 {
  0% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  15% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(0);
            transform: translate(-50%, -50%) scale(0);
  }
  20% {
    -webkit-transform: translate(-50%, -50%) scale(1.5);
            transform: translate(-50%, -50%) scale(1.5);
  }
  25% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(2);
            transform: translate(-50%, -50%) scale(2);
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(2);
            transform: translate(-50%, -50%) scale(2);
  }
}
.p-nav {
  position: relative;
  padding-top: clamp(3em, 14vw, 7em);
  padding-bottom: clamp(4em, 17vw, 7em);
}
.p-nav__bg {
  position: absolute;
  top: 10%;
  left: 50%;
  z-index: 0;
  width: min(100%, 100rem);
  height: auto;
  -webkit-transform: translate(-50%, 0%);
          transform: translate(-50%, 0%);
}
.p-nav__inner {
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto 0.8rem auto 0.8rem auto 0.8rem auto;
      grid-template-areas: "title title" "illust illust" "menu01 menu02" "button-cta button-cta";
  -ms-grid-columns: 1fr 0.5rem 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.8rem 0.5rem;
  width: min(94%, 116rem);
  margin: 0 auto;
}
.p-nav__title {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  position: relative;
  grid-area: title;
}
.p-nav__title > span {
  display: block;
}
.is-active .p-nav__title > span:nth-child(1) {
  -webkit-animation: navtitle 1.5s ease-out 0s both;
          animation: navtitle 1.5s ease-out 0s both;
}
.is-active .p-nav__title > span:nth-child(2) {
  -webkit-animation: navtitle 1.5s ease-out 0.4s both;
          animation: navtitle 1.5s ease-out 0.4s both;
}
.p-nav__illust {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  position: relative;
  grid-area: illust;
  padding: 1rem 0;
  text-align: center;
}
.p-proposal-subsection__header > .p-nav__illust {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-nav__illust {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
}
.p-nav__illust img {
  width: 16rem;
  height: auto;
  margin: 0 auto;
}
.p-nav__menu01 {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  grid-area: menu01;
  text-align: right;
}
.p-nav__menu01 li:nth-child(2) {
  text-align: left;
}
.p-nav__menu01 li:nth-child(2) a {
  margin: 0;
}
.p-nav__menu02 {
  -ms-grid-row: 5;
  -ms-grid-column: 3;
  grid-area: menu02;
}
.p-nav__menu02 li:nth-child(2) {
  text-align: right;
}
.p-nav__menu02 li:nth-child(2) a {
  margin: 0;
}
.p-nav__menu01 li + li, .p-nav__menu02 li + li {
  margin-top: 0.6rem;
}
.p-nav__menu01 a, .p-nav__menu02 a {
  position: relative;
  z-index: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  width: min(100%, 34rem);
  height: clamp(3.2em, 15vw, 8rem);
  padding-right: 0.1em;
  padding-bottom: 1rem;
  padding-left: 0.1em;
  overflow: hidden;
  color: #fff;
  text-decoration: none !important;
  letter-spacing: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background: transparent;
  background-color: #7FCE43;
  border: 2px solid #fff;
  outline: none;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}
.p-nav__menu01 a > span, .p-nav__menu02 a > span {
  font-size: min(3.2vw, 1.7rem);
  font-weight: 700;
  line-height: 1.25;
  text-align: center;
}
.p-nav__menu01 a::after, .p-nav__menu02 a::after {
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: 2;
  width: 3.5rem;
  height: 1.2rem;
  content: "";
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2212%22%20viewBox%3D%220%200%2035%2012%22%20width%3D%2235%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m0%200h35v12h-35z%22%2F%3E%3Cpath%20d%3D%22m6%202%206%205h-12z%22%20fill%3D%22%23fff%22%20transform%3D%22matrix(-1%200%200%20-1%2023%2011.33)%22%2F%3E%3C%2Fsvg%3E") no-repeat center center/contain;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.p-nav__button-cta {
  -ms-grid-row: 7;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: button-cta;
  padding-top: 2rem;
  text-align: center;
}
.p-nav__button-cta > a {
  margin: 0 auto;
}

.is-active .p-nav__menu01 li:nth-of-type(1) {
  -webkit-animation: navlist 0.75s ease-out 1.3s both;
          animation: navlist 0.75s ease-out 1.3s both;
}

.is-active .p-nav__menu02 li:nth-of-type(1) {
  -webkit-animation: navlist 0.75s ease-out 1.4s both;
          animation: navlist 0.75s ease-out 1.4s both;
}

.is-active .p-nav__menu01 li:nth-of-type(2) {
  -webkit-animation: navlist 0.75s ease-out 1.4s both;
          animation: navlist 0.75s ease-out 1.4s both;
}

.is-active .p-nav__menu02 li:nth-of-type(2) {
  -webkit-animation: navlist 0.75s ease-out 1.5s both;
          animation: navlist 0.75s ease-out 1.5s both;
}

.is-active .p-nav__menu01 li:nth-of-type(3) {
  -webkit-animation: navlist 0.75s ease-out 1.5s both;
          animation: navlist 0.75s ease-out 1.5s both;
}

.is-active .p-nav__menu02 li:nth-of-type(3) {
  -webkit-animation: navlist 0.75s ease-out 1.6s both;
          animation: navlist 0.75s ease-out 1.6s both;
}

.is-active .p-nav__menu01 li:nth-of-type(4) {
  -webkit-animation: navlist 0.75s ease-out 1.6s both;
          animation: navlist 0.75s ease-out 1.6s both;
}

.is-active .p-nav__menu02 li:nth-of-type(4) {
  -webkit-animation: navlist 0.75s ease-out 1.7s both;
          animation: navlist 0.75s ease-out 1.7s both;
}

.is-active .p-nav__menu01 li:nth-of-type(5) {
  -webkit-animation: navlist 0.75s ease-out 1.7s both;
          animation: navlist 0.75s ease-out 1.7s both;
}

.is-active .p-nav__menu02 li:nth-of-type(5) {
  -webkit-animation: navlist 0.75s ease-out 1.8s both;
          animation: navlist 0.75s ease-out 1.8s both;
}

.is-active .p-nav__menu01 li:nth-of-type(6) {
  -webkit-animation: navlist 0.75s ease-out 1.8s both;
          animation: navlist 0.75s ease-out 1.8s both;
}

.is-active .p-nav__menu02 li:nth-of-type(6) {
  -webkit-animation: navlist 0.75s ease-out 1.9s both;
          animation: navlist 0.75s ease-out 1.9s both;
}

.is-active .p-nav__menu01 li:nth-of-type(7) {
  -webkit-animation: navlist 0.75s ease-out 1.9s both;
          animation: navlist 0.75s ease-out 1.9s both;
}

.is-active .p-nav__menu02 li:nth-of-type(7) {
  -webkit-animation: navlist 0.75s ease-out 2s both;
          animation: navlist 0.75s ease-out 2s both;
}

.is-active .p-nav__menu01 li:nth-of-type(8) {
  -webkit-animation: navlist 0.75s ease-out 2s both;
          animation: navlist 0.75s ease-out 2s both;
}

.is-active .p-nav__menu02 li:nth-of-type(8) {
  -webkit-animation: navlist 0.75s ease-out 2.1s both;
          animation: navlist 0.75s ease-out 2.1s both;
}

.is-active .p-nav__menu01 li:nth-of-type(9) {
  -webkit-animation: navlist 0.75s ease-out 2.1s both;
          animation: navlist 0.75s ease-out 2.1s both;
}

.is-active .p-nav__menu02 li:nth-of-type(9) {
  -webkit-animation: navlist 0.75s ease-out 2.2s both;
          animation: navlist 0.75s ease-out 2.2s both;
}

.is-active .p-nav__menu01 li:nth-of-type(10) {
  -webkit-animation: navlist 0.75s ease-out 2.2s both;
          animation: navlist 0.75s ease-out 2.2s both;
}

.is-active .p-nav__menu02 li:nth-of-type(10) {
  -webkit-animation: navlist 0.75s ease-out 2.3s both;
          animation: navlist 0.75s ease-out 2.3s both;
}

@-webkit-keyframes navtitle {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}

@keyframes navtitle {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}
@-webkit-keyframes navlist {
  0% {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes navlist {
  0% {
    opacity: 0;
    -webkit-transform: translateY(10px);
            transform: translateY(10px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
.p-proposal {
  padding-top: clamp(4em, 17vw, 7em);
  padding-bottom: clamp(4em, 17vw, 7em);
  overflow: hidden;
  background-color: #F2F5EF;
}
.p-proposal__inner {
  position: relative;
  z-index: 2;
  width: min(90%, 110rem);
  margin: 0 auto;
}
.p-proposal__title {
  margin-bottom: 1em;
  font-size: clamp(3.2rem, 6vw, 6rem);
}
.p-proposal__title > span {
  display: block;
}
.p-proposal__title.is-active > span {
  -webkit-animation: proposaltitle 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.2s both;
          animation: proposaltitle 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.2s both;
}
.p-proposal__title svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(40vw, 24rem);
  height: 16rem;
  opacity: 0;
  -webkit-transform: translate(-50%, -50%) scale(0.1);
          transform: translate(-50%, -50%) scale(0.1);
}
.p-proposal__title svg path {
  -webkit-transform-origin: center center;
          transform-origin: center center;
  transform-box: fill-box;
}
.p-proposal__title.is-active svg {
  -webkit-animation: proposaltitle-svg 1.5s linear 0.3s both;
          animation: proposaltitle-svg 1.5s linear 0.3s both;
}
.p-proposal__button-cta {
  margin: 2em 0 0;
  text-align: center;
}

@-webkit-keyframes proposaltitle {
  0% {
    opacity: 0;
    -webkit-transform: scale(2);
            transform: scale(2);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes proposaltitle {
  0% {
    opacity: 0;
    -webkit-transform: scale(2);
            transform: scale(2);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes proposaltitle-svg {
  0% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(0.3);
            transform: translate(-50%, -50%) scale(0.3);
  }
  50% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(1.4);
            transform: translate(-50%, -50%) scale(1.4);
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(1.7);
            transform: translate(-50%, -50%) scale(1.7);
  }
}
@keyframes proposaltitle-svg {
  0% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(0.3);
            transform: translate(-50%, -50%) scale(0.3);
  }
  50% {
    opacity: 1;
    -webkit-transform: translate(-50%, -50%) scale(1.4);
            transform: translate(-50%, -50%) scale(1.4);
  }
  100% {
    opacity: 0;
    -webkit-transform: translate(-50%, -50%) scale(1.7);
            transform: translate(-50%, -50%) scale(1.7);
  }
}
.p-proposal-subsection {
  padding-top: clamp(1rem, 2vw, 2rem);
  margin-top: clamp(3.6rem, 9vw, 9rem);
}
.p-proposal-subsection__header {
  position: relative;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: auto min(3vw, 1em) auto;
      grid-template-areas: "illust number-tags" "texts texts";
  -ms-grid-columns: min(24vw, 28.1rem) min(3vw, 1em) auto;
  grid-template-columns: min(24vw, 28.1rem) auto;
  gap: min(3vw, 1em);
}
.p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header {
      grid-template-areas: "number-tags illust" "texts texts";
  -ms-grid-columns: auto min(24vw, 28.1rem);
  grid-template-columns: auto min(24vw, 28.1rem);
}
.p-proposal-subsection__illust {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  position: relative;
  grid-area: illust;
  gap: 1rem;
  width: min(24vw, 12rem);
}
.p-proposal-subsection__header > .p-proposal-subsection__illust {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__illust {
  -ms-grid-row: 1;
  -ms-grid-row-span: 1;
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
}
.p-proposal-subsection__illust img {
  width: 100%;
  height: auto;
}
.p-proposal-subsection__texts {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: texts;
  -ms-grid-row-align: center;
      align-self: center;
}
.p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__texts {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
}
.p-proposal-subsection__number-tags {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  grid-area: number-tags;
  gap: 0.5rem;
}
.p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__number-tags {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.p-proposal-subsection__number {
  -ms-flex-item-align: end;
      -ms-grid-row-align: end;
      align-self: end;
  width: 100%;
  padding-bottom: 0.25em;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.25;
  color: #000;
}
.p-proposal-subsection__tag {
  display: inline-block;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  -ms-flex-item-align: start;
      -ms-grid-row-align: start;
      align-self: start;
  padding: 0.3rem 1rem;
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.25;
  color: #fff;
  background-color: #18B9AC;
  border-radius: 1.5rem;
}
.p-proposal-subsection__title {
  padding-top: 0.5em;
  font-size: min(6vw, 3rem);
  font-weight: 700;
  line-height: 1.5;
  color: #000;
}
.is-active .p-proposal-subsection__title {
  -webkit-animation: proposaltitle2 1.5s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.3s both;
          animation: proposaltitle2 1.5s cubic-bezier(0.68, -0.55, 0.265, 1.55) 0.3s both;
}
.p-proposal-subsection__desc {
  margin-top: 1em;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.8;
  color: #000;
  letter-spacing: 0.05em;
}
.is-active .p-proposal-subsection__desc {
  -webkit-animation: proposaldesc 1s cubic-bezier(0.68, -0.55, 0.265, 1.55) 1s both;
          animation: proposaldesc 1s cubic-bezier(0.68, -0.55, 0.265, 1.55) 1s both;
}
.p-proposal-subsection__text-highlight {
  font-weight: 700;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(65%, transparent), color-stop(50%, rgba(24, 185, 171, 0.5)));
  background: linear-gradient(transparent 65%, rgba(24, 185, 171, 0.5) 50%);
}

@-webkit-keyframes proposaltitle2 {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}

@keyframes proposaltitle2 {
  0% {
    clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    clip-path: inset(0 0 0 0);
    opacity: 1;
  }
}
@-webkit-keyframes proposaldesc {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes proposaldesc {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-proposal-details {
  position: relative;
  z-index: 1;
  margin-top: 2.4rem;
  overflow: hidden;
  border-radius: 0.6rem;
  outline: #F2F5EF solid 0.1rem;
  outline-offset: 0;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
}
.p-proposal-details__summary {
  position: relative;
  display: block;
  padding: 1.3rem 5.5rem 1.3rem 1.5rem;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  text-align: left;
  letter-spacing: 0.05em;
  list-style: none;
  background: #7FCE43;
  border: 2px solid #fff;
  -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.16);
          box-shadow: 0 1px 5px rgba(0, 0, 0, 0.16);
}
.p-proposal-details__summary::before, .p-proposal-details__summary::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 4.6rem;
  height: 100%;
  color: #fff;
  text-align: center;
  content: "";
  background-color: #000;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.p-proposal-details__summary::before {
  background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2020.328%2020.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2rem 2rem;
}
[open] .p-proposal-details__summary::before {
  opacity: 0;
}
.p-proposal-details__summary::after {
  background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2220.328%22%20viewBox%3D%220%200%2020.328%2020.328%22%20width%3D%2220.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%20opacity%3D%220%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2rem 2rem;
  opacity: 0;
}
[open] .p-proposal-details__summary::after {
  opacity: 1;
}
.p-proposal-details__summary:focus-visible {
  border-radius: 0.6rem;
  outline: #7FCE43 solid 0.1rem;
  outline-offset: -0.1rem;
}
.p-proposal-details__summary::-webkit-details-marker {
  display: none;
}
.p-proposal-details__body {
  position: relative;
  padding: min(3vw, 2em) min(3.5vw, 3em) min(3.5vw, 3em);
  line-height: 1.6825;
  visibility: hidden;
  background-color: #fff;
  border-radius: 0 0 1rem 1rem;
  opacity: 0;
}
[open] .p-proposal-details__body {
  -webkit-animation: proposalbody 0.5s ease 0.2s both;
          animation: proposalbody 0.5s ease 0.2s both;
}
@-webkit-keyframes proposalbody {
  0% {
    opacity: 0;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
@keyframes proposalbody {
  0% {
    opacity: 0;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
.p-proposal-details__picture {
  margin-top: 1em;
}
.p-proposal-details__picture--col2 {
  display: -ms-grid;
  display: grid;
  gap: 1em;
}
.p-proposal-details img {
  width: min(100%, 60rem);
  height: auto;
  margin: 0 auto;
}
.p-proposal-details__video {
  aspect-ratio: 471/265;
  overflow: hidden;
}
.p-proposal-details__video iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border: none;
}

.p-proposal__parallax-wrapper {
  position: absolute;
  top: 50vh;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 70%;
  overflow: hidden;
  -webkit-transition: -webkit-transform 0.2s linear;
  transition: -webkit-transform 0.2s linear;
  transition: transform 0.2s linear;
  transition: transform 0.2s linear, -webkit-transform 0.2s linear;
  will-change: transform;
}

.p-proposal__bg01,
.p-proposal__bg02,
.p-proposal__bg03,
.p-proposal__bg04,
.p-proposal__bg05 {
  position: absolute;
  height: auto;
  opacity: 0;
  -webkit-transition: -webkit-transform 0.1s ease;
  transition: -webkit-transform 0.1s ease;
  transition: transform 0.1s ease;
  transition: transform 0.1s ease, -webkit-transform 0.1s ease;
  will-change: transform;
}

.p-proposal__bg01 {
  top: 10%;
  left: 70%;
  width: min(40vw, 40rem);
}
.p-proposal__bg01 path {
  fill-opacity: 0.2;
}
.is-active .p-proposal__bg01 {
  -webkit-animation: proposalbg 11s linear 1.5s infinite;
          animation: proposalbg 11s linear 1.5s infinite;
}

.p-proposal__bg02 {
  top: 25%;
  right: 15%;
  width: min(30vw, 30rem);
}
.p-proposal__bg02 path {
  fill-opacity: 0.7;
}
.is-active .p-proposal__bg02 {
  -webkit-animation: proposalbg 12s linear 1s infinite;
          animation: proposalbg 12s linear 1s infinite;
}

.p-proposal__bg03 {
  top: 60%;
  left: 1%;
  width: min(20vw, 30rem);
}
.p-proposal__bg03 path {
  fill-opacity: 0.1;
}
.is-active .p-proposal__bg03 {
  -webkit-animation: proposalbg 9s linear 2.5s infinite;
          animation: proposalbg 9s linear 2.5s infinite;
}

.p-proposal__bg04 {
  top: 76%;
  right: 35%;
  width: min(28vw, 36rem);
}
.p-proposal__bg04 path {
  fill-opacity: 0.7;
}
.is-active .p-proposal__bg04 {
  -webkit-animation: proposalbg 10s linear 3.3s infinite;
          animation: proposalbg 10s linear 3.3s infinite;
}

.p-proposal__bg05 {
  top: 49%;
  left: 18%;
  width: min(36vw, 47rem);
}
.p-proposal__bg05 path {
  fill-opacity: 0.3;
}
.is-active .p-proposal__bg05 {
  -webkit-animation: proposalbg 12s linear 4.3s infinite;
          animation: proposalbg 12s linear 4.3s infinite;
}

@-webkit-keyframes proposalbg {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  30% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  70% {
    opacity: 0;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
}

@keyframes proposalbg {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
  30% {
    opacity: 1;
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  70% {
    opacity: 0;
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(0.5);
            transform: scale(0.5);
  }
}
.p-qa {
  position: relative;
  z-index: 1;
  padding-top: clamp(4em, 17vw, 7em);
  padding-bottom: clamp(4em, 17vw, 7em);
  overflow: hidden;
  background-color: #fff;
}
.p-qa__inner {
  position: relative;
  z-index: 3;
  width: min(90%, 110rem);
  margin: 0 auto;
}
.p-qa__title {
  font-size: 5.5rem;
  line-height: 1.1;
}
.p-qa__bg01 {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 1;
  width: min(100%, 110rem);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.p-qa__bg01 img {
  width: min(90%, 81rem);
  height: auto;
  -webkit-transform: translate(-20vw, -10%);
          transform: translate(-20vw, -10%);
}
.p-qa__bg02 {
  position: absolute;
  top: 35em;
  left: 50%;
  z-index: 2;
  width: min(100%, 110rem);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.p-qa__bg02 img {
  width: min(70%, 76rem);
  height: auto;
  -webkit-transform: translate(40vw, -10%);
          transform: translate(40vw, -10%);
}
.p-qa__notes {
  margin: 1em 0 0;
  font-size: 90%;
  text-align: right;
}

.p-qa-details {
  position: relative;
  z-index: 1;
  margin-top: 2.4rem;
  overflow: hidden;
  border-radius: 0.6rem;
  outline: #F2F5EF solid 0.1rem;
  outline-offset: 0;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
}
.p-qa-details__summary {
  position: relative;
  display: block;
  padding: 1.5rem 5.5rem 1.5rem 5rem;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  text-align: left;
  letter-spacing: 0;
  list-style: none;
  background: #7FCE43;
  border: 2px solid #fff;
  -webkit-box-shadow: 0 1px 5px rgba(0, 0, 0, 0.16);
          box-shadow: 0 1px 5px rgba(0, 0, 0, 0.16);
}
.p-qa-details__summary::before, .p-qa-details__summary::after {
  position: absolute;
  top: 0;
  right: 0;
  width: 4.6rem;
  height: 100%;
  color: #fff;
  text-align: center;
  content: "";
  background-color: #000;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.p-qa-details__summary::before {
  background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2020.328%2020.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2rem 2rem;
}
[open] .p-qa-details__summary::before {
  opacity: 0;
}
.p-qa-details__summary::after {
  background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2220.328%22%20viewBox%3D%220%200%2020.328%2020.328%22%20width%3D%2220.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%20opacity%3D%220%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2rem 2rem;
  opacity: 0;
}
[open] .p-qa-details__summary::after {
  opacity: 1;
}
.p-qa-details__summary:focus-visible {
  border-radius: 0.6rem;
  outline: #7FCE43 solid 0.1rem;
  outline-offset: -0.1rem;
}
.p-qa-details__summary::-webkit-details-marker {
  display: none;
}
.p-qa-details__body {
  position: relative;
  padding: 1.75rem 2.5rem 2rem 5.1rem;
  line-height: 1.6825;
  letter-spacing: 0.05em;
  visibility: hidden;
  background-color: #fff;
  border-radius: 0 0 1rem 1rem;
  opacity: 0;
}
[open] .p-qa-details__body {
  -webkit-animation: faqbody 0.5s ease 0.2s both;
          animation: faqbody 0.5s ease 0.2s both;
}
@-webkit-keyframes faqbody {
  0% {
    opacity: 0;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
@keyframes faqbody {
  0% {
    opacity: 0;
  }
  50% {
    visibility: visible;
  }
  100% {
    visibility: visible;
    opacity: 1;
  }
}
.p-qa-details__ic-q, .p-qa-details__ic-a {
  position: absolute;
  z-index: 2;
  font-size: 2.8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
}
.p-qa-details__ic-q {
  top: 50%;
  left: 1rem;
  -webkit-transform: translateY(-60%);
          transform: translateY(-60%);
}
.p-qa-details__ic-a {
  top: 1.5rem;
  left: 1.25rem;
  color: #000;
}
.p-qa-details + .p-qa-details {
  margin-top: clamp(1.6rem, 2vw, 2.4rem);
}

.p-contact {
  padding-top: clamp(4em, 17vw, 7em);
  padding-bottom: clamp(4em, 17vw, 7em);
  background-color: #F2F5EF;
}
.p-contact__inner {
  width: min(90%, 75rem);
  margin: 0 auto;
}
.p-contact__title {
  font-size: clamp(3.2rem, 4.6vw, 4.6rem);
}

.p-contact-form p,
.p-contact-form p + div {
  margin: 0;
}

.hidden-fields-container {
  visibility: hidden;
}

.wpcf7-not-valid-tip {
  font-size: 80% !important;
}

.wpcf7-select option:first-child {
  color: gray !important;
}

span.wpcf7-spinner {
  display: none;
}

.p-contact-form {
  position: relative;
}
.p-contact-form__button-area {
  width: 100%;
  margin-top: clamp(2.5em, 4vw, 3.5em);
  text-align: center;
}
.p-contact-form__block {
  position: relative;
}
.p-contact-form__block-name p {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr min(2.8vw, 2.8rem) 1fr;
  grid-template-columns: repeat(2, 1fr);
  gap: min(2.8vw, 2.8rem);
}
.p-contact-form .c-button01 {
  width: min(100%, 50rem);
  height: 7.2rem;
  margin: 0 auto;
}
.p-contact-form input[type=text],
.p-contact-form input[type=email],
.p-contact-form input[type=tel],
.p-contact-form textarea {
  width: 100%;
  padding: 1.25em 1em;
  margin-top: 0.25em;
  letter-spacing: 0.015em;
  background: #fff;
  border: #E2E2E2 solid 1px;
  border-radius: 0.6rem;
  outline: none;
  -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.16);
          box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.16);
}
.p-contact-form input[type=text]:focus,
.p-contact-form input[type=email]:focus,
.p-contact-form input[type=tel]:focus,
.p-contact-form textarea:focus {
  background-color: #fff;
  border: #18B9AC solid 1px;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.p-contact-form input[type=text],
.p-contact-form input[type=email],
.p-contact-form input[type=tel] {
  height: 5.5rem;
  font-size: 1.6rem;
}
.p-contact-form input[type=text] + span,
.p-contact-form input[type=email] + span,
.p-contact-form input[type=tel] + span,
.p-contact-form textarea + span {
  display: block;
  margin-top: 0.25em;
  line-height: 1.5;
}
.p-contact-form textarea {
  height: 17rem;
}
.p-contact-form label {
  position: relative;
  display: block;
  margin-top: 2.25em;
}
.p-contact-form .p-contact-form__label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  gap: 0 min(2.5vw, 1em);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: clamp(1.6rem, 1.509rem + 0.39vw, 1.8rem);
  font-weight: 500;
  text-align: left;
}
.p-contact-form .p-contact-form__notice {
  display: inline-block;
  padding: 0.2em 1em 0.1em;
  font-size: 1.1rem;
  font-style: normal;
  font-weight: 500;
  line-height: 1.25;
  color: #fff;
  text-align: center;
  letter-spacing: 0.05em;
  background-color: #18B9AC;
  border-radius: 2px;
}
.p-contact-form textarea::-webkit-input-placeholder, .p-contact-form input[type=text]::-webkit-input-placeholder, .p-contact-form input[type=email]::-webkit-input-placeholder, .p-contact-form input[type=tel]::-webkit-input-placeholder {
  font-size: 90%;
  color: rgba(0, 0, 0, 0.5);
}
.p-contact-form textarea::-moz-placeholder, .p-contact-form input[type=text]::-moz-placeholder, .p-contact-form input[type=email]::-moz-placeholder, .p-contact-form input[type=tel]::-moz-placeholder {
  font-size: 90%;
  color: rgba(0, 0, 0, 0.5);
}
.p-contact-form textarea:-ms-input-placeholder, .p-contact-form input[type=text]:-ms-input-placeholder, .p-contact-form input[type=email]:-ms-input-placeholder, .p-contact-form input[type=tel]:-ms-input-placeholder {
  font-size: 90%;
  color: rgba(0, 0, 0, 0.5);
}
.p-contact-form textarea::-ms-input-placeholder, .p-contact-form input[type=text]::-ms-input-placeholder, .p-contact-form input[type=email]::-ms-input-placeholder, .p-contact-form input[type=tel]::-ms-input-placeholder {
  font-size: 90%;
  color: rgba(0, 0, 0, 0.5);
}
.p-contact-form textarea::placeholder,
.p-contact-form input[type=text]::placeholder,
.p-contact-form input[type=email]::placeholder,
.p-contact-form input[type=tel]::placeholder {
  font-size: 90%;
  color: rgba(0, 0, 0, 0.5);
}
.p-contact-form input[type=checkbox] {
  position: relative;
  position: absolute;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  opacity: 0;
}
.p-contact-form input[type=checkbox] + label, .p-contact-form input[type=checkbox] + span {
  position: relative;
  display: inline-block;
  padding: 0.2rem 2rem 0.2rem 4rem;
  margin-top: 0.25em;
  vertical-align: middle;
  cursor: pointer;
}
.p-contact-form input[type=checkbox] + label::before, .p-contact-form input[type=checkbox] + label::after, .p-contact-form input[type=checkbox] + span::before, .p-contact-form input[type=checkbox] + span::after {
  position: absolute;
  content: "";
  -webkit-transform: translate(0, -15%);
          transform: translate(0, -15%);
}
.p-contact-form input[type=checkbox] + label::before, .p-contact-form input[type=checkbox] + span::before {
  top: 50%;
  left: 0;
  display: block;
  width: 3.2rem;
  height: 3.2rem;
  background: #fff;
  border: #E2E2E2 solid 1px;
  border-radius: 5px;
  -webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1);
          box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1);
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.p-contact-form input[type=checkbox] + label::after, .p-contact-form input[type=checkbox] + span::after {
  top: 50%;
  left: 0.5rem;
  display: none;
  width: 24px;
  height: 16px;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20enable-background%3D%22new%200%200%2023%2017%22%20viewBox%3D%220%200%2023%2017%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m2.1%206.8%207.5%208.5%2011.1-13.2%22%20style%3D%22fill%3Anone%3Bstroke%3A%23ffffff%3Bstroke-width%3A3%3Bstroke-linecap%3Around%3Bstroke-linejoin%3Around%3Bstroke-miterlimit%3A10%22%2F%3E%3C%2Fsvg%3E") no-repeat center center/contain;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.p-contact-form input[type=checkbox] + label + span {
  display: inline-block;
  margin-left: 10px;
  vertical-align: middle;
}
.p-contact-form input[type=checkbox]:checked + label::before, .p-contact-form input[type=checkbox]:checked + span::before {
  background: #7FCE43;
  border: #7FCE43 solid 1px;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.p-contact-form input[type=checkbox]:checked + label::after, .p-contact-form input[type=checkbox]:checked + span::after {
  display: block;
}
.p-contact-form input[type=checkbox]:focus-visible + label::before, .p-contact-form input[type=checkbox]:focus-visible + span::before {
  border: #7FCE43 solid 2px;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.p-contact-form input[type=radio] {
  position: absolute;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  opacity: 0;
}
.p-contact-form input[type=radio] + label {
  position: relative;
  display: inline-block;
  padding: 0.2rem 2rem 0.2rem 4rem;
  margin-top: 0.25em;
  vertical-align: middle;
  cursor: pointer;
}
.p-contact-form input[type=radio] + label::before, .p-contact-form input[type=radio] + label::after {
  position: absolute;
  content: "";
  -webkit-transform: translate(0, -15%);
          transform: translate(0, -15%);
}
.p-contact-form input[type=radio] + label::before {
  top: 50%;
  left: 0;
  display: block;
  width: 3.2rem;
  height: 3.2rem;
  background: #fff;
  border: #EDEDED solid 1px;
  border-radius: 50%;
  -webkit-box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1);
          box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1);
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.p-contact-form input[type=radio] + label::after {
  top: 50%;
  left: 0.75rem;
  width: 1.5rem;
  height: 1.5rem;
  background: #fff;
  border-radius: 50%;
  -webkit-transform: translate(0, -50%);
          transform: translate(0, -50%);
}
.p-contact-form input[type=radio] + label + span {
  display: inline-block;
  margin-left: 10px;
  vertical-align: middle;
}
.p-contact-form input[type=radio]:checked + label::before {
  background: #7FCE43;
}
.p-contact-form input[type=radio]:focus-visible + label::before {
  border: #7FCE43 solid 2px;
  -webkit-box-shadow: none;
          box-shadow: none;
}
.p-contact-form select {
  display: block;
  width: 100%;
  height: 5.5rem;
  padding: 0.5em 40px 0.5em 1em;
  margin-top: 0.25em;
  font-size: 1.6rem;
  color: #333;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: #fff url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2220%22%20width%3D%2228%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m13.594%2020-13.5-19.5h27z%22%20fill%3D%22%237FCE43%22%20fill-rule%3D%22evenodd%22%2F%3E%3C%2Fsvg%3E") no-repeat right 10px center/12px 8px;
  border: #E2E2E2 solid 1px;
  border-radius: 5px;
  outline: none;
  -webkit-box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.16);
          box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.16);
}
.p-contact-form select:invalid,
.p-contact-form select option:first-child {
  color: #999;
}
.p-contact-form select option {
  color: #333;
}
.p-contact-form select:focus {
  background-color: #fff;
  border: #18B9AC solid 1px;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.p-contact-form__block-privacy {
  margin-top: 2.25em;
}
.p-contact-form__block-privacy p {
  font-size: clamp(1.4rem, 1.309rem + 0.39vw, 1.6rem);
  line-height: 2;
  text-align: left;
}
.p-contact-form__block-privacy input {
  margin-top: 1em;
}
.p-contact-form__block-privacy label {
  margin-top: 1em !important;
}

input:focus-visible, textarea:focus-visible, select:focus-visible {
  outline: 1px solid #7FCE43 !important;
  outline-offset: 0 !important;
}

.p-contact-thanks {
  position: relative;
}
.p-contact-thanks-section01 {
  padding-top: min(7.5vw, 5em);
}
.p-contact-thanks__button {
  margin-top: 2.5em;
  text-align: center;
}
.p-contact-thanks__button .c-button02 {
  width: min(90%, 20em);
}

.p-contact-error__text02 {
  margin-top: 2em;
  color: #f00;
}
.p-contact-error__text02 + p {
  margin-top: 0.5em;
}
.p-contact-error__button {
  margin-top: 2.5em;
  text-align: center;
}
.p-contact-error__button .c-button02 {
  width: min(100%, 14em);
}

.wpcf7-response-output {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 2em 0 1em;
  margin: 0 auto;
  font-weight: 500;
  color: #c00;
  text-align: left;
}

.p-thanks .l-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: 100vh; /* ビューポートの高さを確保 */
}
.p-thanks .l-main {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1; /* メイン部分が余白を埋める */
  padding-top: 6rem;
}
.p-thanks-section {
  width: min(90%, 110rem);
  padding: min(10vw, 10rem) 0 min(15vw, 10rem);
  margin: 0 auto;
  font-size: 1.3rem;
  text-align: left;
}
.p-thanks-section__title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 700;
  text-align: center;
}
.p-thanks-section__title + p {
  margin-top: 2em;
}
.p-thanks-section__button-pdf {
  margin-top: 2em;
  text-align: center;
}
.p-thanks-section__button-top {
  margin-top: 4em;
  text-align: center;
}

:where(.c-button01) {
  width: min(84.5vw, 40rem);
  min-height: 6rem;
}

:where(.c-button01) > span {
  font-size: 1.8rem;
}

.c-button01 {
  position: relative;
  z-index: 1;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-right: 1.5em;
  padding-left: 1.5em;
  overflow: hidden;
  color: #fff;
  text-decoration: none !important;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background: transparent;
  background-color: #65bb22;
  border: 2px solid #fff;
  outline: none;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}
.c-button01 > span {
  position: relative;
  z-index: 2;
  padding: 0.5em 0;
  font-weight: 700;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 1.25;
  text-align: center;
  text-indent: 0;
  letter-spacing: 0;
}
.c-button01.is-disabled, .c-button01:disabled {
  pointer-events: none;
  opacity: 0.5;
}
.c-button01 > i {
  position: absolute;
  top: 50%;
  z-index: 2;
  font-size: 1em;
}
.c-button01 .u-ic-arrow-w {
  width: 1.5em;
  height: 1.5em;
}
.c-button01 > i:first-child {
  left: 0;
  -webkit-transform: translate(50%, -50%);
          transform: translate(50%, -50%);
}
.c-button01 > i:last-child {
  right: 0;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.c-button01:focus-visible {
  outline: 2px solid #7FCE43;
  outline-offset: 0;
}

.c-button-cta {
  position: relative;
  display: block;
  width: min(100%, 63.4rem);
  height: 9rem;
  margin: 0 auto;
  overflow: hidden;
  background-color: #000;
  border: 2px solid #fff;
  -webkit-box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
          box-shadow: 0 1px 8px rgba(0, 0, 0, 0.16);
}
.c-button-cta__bg01, .c-button-cta__bg02 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.c-button-cta > div {
  position: relative;
  z-index: 3;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  padding: 0 1.5em 0.2em;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  text-align: center;
  text-decoration: none;
  outline: none;
}
.c-button-cta > div::after {
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 1px;
  content: "";
  background-color: #fff;
  opacity: 0;
}
.c-button-cta > div > span {
  position: relative;
  padding-left: 4.5rem;
  text-align: left;
}
.c-button-cta > div > span i {
  position: absolute;
  top: 50%;
  left: 0;
  width: 4rem;
  height: 4rem;
  -webkit-transform: translate(0%, -45%);
          transform: translate(0%, -45%);
}
.c-button-cta__pen {
  position: absolute;
  bottom: 2%;
  left: 0;
  z-index: 3;
  width: 2.5rem;
  height: 3.2rem;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2265.927%22%20viewBox%3D%220%200%2044.767%2065.927%22%20width%3D%2244.767%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h24.447v61.233h-24.447z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%20fill%3D%22%23fff%22%20transform%3D%22matrix(.93358043%20.35836795%20-.35836795%20.93358043%2021.944%200)%22%3E%3Cpath%20d%3D%22m5.831%2032.98a44.419%2044.419%200%200%200%20-3.775%204.02l-1.311-5.467a4.9%204.9%200%200%201%205.086%201.447%22%20transform%3D%22translate(.576%2024.232)%22%2F%3E%3Cpath%20d%3D%22m13.995%2047.456h.011c.009-.02.016-.044.023-.064a.146.146%200%200%201%20.018-.037l10.379-41.446a.665.665%200%200%200%20.011-.289l-.009-.027a.526.526%200%200%200%20-.035-.117.2.2%200%200%201%20-.023-.043.888.888%200%200%200%20-.057-.085l-.009-.02-2.447-3.2a.932.932%200%200%200%20-.477-.323l-6.222-1.766a.908.908%200%200%200%20-.571.016l-3.774%201.438-.02.009c-.03.012-.057.03-.083.041a.173.173%200%200%200%20-.053.03c-.027.02-.048.044-.073.062a.162.162%200%200%201%20-.039.032.592.592%200%200%200%20-.057.085c-.012.012-.027.018-.032.035a.387.387%200%200%201%20-.027.066.656.656%200%200%200%20-.023.071h-.007l-10.378%2041.435v.018c0%20.016-.012.028-.005.048a.048.048%200%200%200%20-.016.042.3.3%200%200%200%200%20.055.4.4%200%200%200%200%20.046v.016s0%20.005.128%201.245.372%203.732.872%208.71a.782.782%200%200%200%20.309.516%201.05%201.05%200%200%200%20.314.153.9.9%200%200%200%20.319.037%207.8%207.8%200%200%201%202.5.092%208.155%208.155%200%200%201%202.246%201.263.975.975%200%200%200%20.633.165.733.733%200%200%200%20.528-.273c6.1-7.934%206.092-7.924%206.1-7.934l.018-.03a.123.123%200%200%201%20.033-.049c-.005-.014%200-.016%200-.023m-12.155-3.405a3.1%203.1%200%200%201%20-.19-.4c0-.009%200-.009%200-.016l9.912-39.77%201.2%201.573-9.683%2038.971c-.438.245-.633.2-.709.188a1.135%201.135%200%200%201%20-.53-.546m12.4-37.8%204.638%201.312-9.593%2038.662a2.805%202.805%200%200%201%20-2.609.784%203.345%203.345%200%200%201%20-2.022-2.13zm.83-4.787%205.624%201.6%201.741%202.285-2.682%201.026-5.631-1.6-1.741-2.287zm-9.2%2051.952a10.8%2010.8%200%200%200%20-1.056-.416%207.114%207.114%200%200%200%20-2.268-.2c-.349-3.421-.562-5.567-.7-6.915a.91.91%200%200%200%20.144.048%202.382%202.382%200%200%200%201.428-.035%204.835%204.835%200%200%200%202.877%202.455h.007a7.355%207.355%200%200%200%201.814.094z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
  -webkit-transform: translate(60%, 0%);
          transform: translate(60%, 0%);
}

.c-button-cta.is-active > div::after {
  -webkit-animation: ctaline-sp 1s ease 0.1s both;
          animation: ctaline-sp 1s ease 0.1s both;
}
.c-button-cta.is-active > div > span {
  -webkit-animation: ctatext 1s ease-in-out 0.3s both;
          animation: ctatext 1s ease-in-out 0.3s both;
}
.c-button-cta.is-active .c-button-cta__bg01 {
  -webkit-animation: ctabg 7s ease-in-out 0s infinite;
          animation: ctabg 7s ease-in-out 0s infinite;
}
.c-button-cta.is-active .c-button-cta__bg02 {
  -webkit-animation: ctabg 7s ease-in-out 3.5s infinite;
          animation: ctabg 7s ease-in-out 3.5s infinite;
}
.c-button-cta.is-active .c-button-cta__pen {
  -webkit-animation: pen-sp 1s ease 0.1s both;
          animation: pen-sp 1s ease 0.1s both;
}

@-webkit-keyframes ctaline-sp {
  0% {
    width: 0;
    opacity: 0.5;
  }
  100% {
    width: 93%;
    opacity: 1;
  }
}

@keyframes ctaline-sp {
  0% {
    width: 0;
    opacity: 0.5;
  }
  100% {
    width: 93%;
    opacity: 1;
  }
}
@-webkit-keyframes ctaline-pc {
  0% {
    width: 0;
    opacity: 0.5;
  }
  100% {
    width: 95%;
    opacity: 1;
  }
}
@keyframes ctaline-pc {
  0% {
    width: 0;
    opacity: 0.5;
  }
  100% {
    width: 95%;
    opacity: 1;
  }
}
@-webkit-keyframes ctatext {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes ctatext {
  0% {
    clip-path: inset(0 100% 0 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@-webkit-keyframes ctabg {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@keyframes ctabg {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
}
@-webkit-keyframes pen-sp {
  0% {
    left: 0;
  }
  100% {
    left: 88%;
  }
}
@keyframes pen-sp {
  0% {
    left: 0;
  }
  100% {
    left: 88%;
  }
}
@-webkit-keyframes pen-pc {
  0% {
    left: 0;
  }
  100% {
    left: 92%;
  }
}
@keyframes pen-pc {
  0% {
    left: 0;
  }
  100% {
    left: 92%;
  }
}
:where(.c-title01) {
  font-size: clamp(2.6rem, 1.736rem + 3.68vw, 4.5rem);
}

.c-title01 {
  position: relative;
  z-index: 1;
  font-weight: 700;
  line-height: 1.5;
  color: #000;
  text-align: center;
  text-shadow: 0.04em 0.1em 0 rgb(255, 255, 255);
}

.u-visible-sp {
  display: inline-block;
}

.u-visible-pc {
  display: none;
}

.u-visible-s,
.u-visible-sm,
.u-visible-md,
.u-visible-lg,
.u-visible-xl,
.u-visible-xxl {
  display: none;
}

[class^=u-ic-] {
  display: inline-block;
  width: 1.5em;
  height: 1em;
  line-height: 1.25;
  vertical-align: -0.15em;
}

.u-ic-arrow-link {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2230%22%20viewBox%3D%220%200%2030%2030%22%20width%3D%2230%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h30v30h-30z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%20opacity%3D%220%22%3E%3Cpath%20d%3D%22m0%200h30v30h-30z%22%20fill%3D%22%2365bb22%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3Cg%20fill%3D%22none%22%20stroke%3D%22%2365bb22%22%20stroke-linecap%3D%22round%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%223%22%3E%3Cpath%20d%3D%22m12.618%204.5%208.75%209.375-8.75%209.375%22%20transform%3D%22translate(3.154%201.125)%22%2F%3E%3Cpath%20d%3D%22m9.41%200h-9.41%22%20transform%3D%22translate(5.478%2015)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-arrow-w {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2230%22%20viewBox%3D%220%200%2030%2030%22%20width%3D%2230%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h30v30h-30z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%20opacity%3D%220%22%3E%3Cpath%20d%3D%22m0%200h30v30h-30z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3Cg%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%223%22%3E%3Cpath%20d%3D%22m12.618%204.5%208.75%209.375-8.75%209.375%22%20transform%3D%22translate(3.154%201.125)%22%2F%3E%3Cpath%20d%3D%22m9.41%200h-9.41%22%20transform%3D%22translate(5.478%2015)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-arrow-down {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2212%22%20viewBox%3D%220%200%2035%2012%22%20width%3D%2235%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m0%200h35v12h-35z%22%2F%3E%3Cpath%20d%3D%22m6%202%206%205h-12z%22%20fill%3D%22%23fff%22%20transform%3D%22matrix(-1%200%200%20-1%2023%2011.33)%22%2F%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-blank-link {
  vertical-align: -0.25em;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2217%22%20viewBox%3D%220%200%2017%2017%22%20width%3D%2217%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m19.611%2019.611h-13.222v-13.222h6.611v-1.889h-6.611a1.889%201.889%200%200%200%20-1.889%201.889v13.222a1.889%201.889%200%200%200%201.889%201.889h13.222a1.894%201.894%200%200%200%201.889-1.889v-6.611h-1.889zm-4.722-15.111v1.889h3.391l-9.28%209.284%201.327%201.327%209.284-9.284v3.391h1.889v-6.607z%22%20fill%3D%22%233B8901%22%20transform%3D%22translate(-4.5%20-4.5)%22%2F%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-blank-w {
  vertical-align: -0.25em;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2217%22%20viewBox%3D%220%200%2017%2017%22%20width%3D%2217%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m19.611%2019.611h-13.222v-13.222h6.611v-1.889h-6.611a1.889%201.889%200%200%200%20-1.889%201.889v13.222a1.889%201.889%200%200%200%201.889%201.889h13.222a1.894%201.894%200%200%200%201.889-1.889v-6.611h-1.889zm-4.722-15.111v1.889h3.391l-9.28%209.284%201.327%201.327%209.284-9.284v3.391h1.889v-6.607z%22%20fill%3D%22%23ffffff%22%20transform%3D%22translate(-4.5%20-4.5)%22%2F%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-mail-w {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2246%22%20viewBox%3D%220%200%2046%2046%22%20width%3D%2246%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h46v46h-46z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%20opacity%3D%220%22%3E%3Cpath%20d%3D%22m0%200h46v46h-46z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fg%3E%3Cpath%20d%3D%22m32.816%206.053h-26.056a3.266%203.266%200%200%200%20-3.26%203.256v16.284a3.266%203.266%200%200%200%203.26%203.257h26.056a3.265%203.265%200%200%200%203.256-3.256v-16.285a3.265%203.265%200%200%200%20-3.256-3.256m-.272%209.031-11.944%206.498a1.7%201.7%200%200%201%20-1.627%200l-11.943-6.5a1.7%201.7%200%200%201%201.627-2.99l11.128%206.057%2011.128-6.057a1.7%201.7%200%200%201%201.627%202.99%22%20fill%3D%22%23fff%22%20transform%3D%22translate(3.212%205.549)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-mail-link {
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2246%22%20viewBox%3D%220%200%2046%2046%22%20width%3D%2246%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h46v46h-46z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%20opacity%3D%220%22%3E%3Cpath%20d%3D%22m0%200h46v46h-46z%22%20fill%3D%22%2365bb22%22%2F%3E%3C%2Fg%3E%3Cpath%20d%3D%22m32.816%206.053h-26.056a3.266%203.266%200%200%200%20-3.26%203.256v16.284a3.266%203.266%200%200%200%203.26%203.257h26.056a3.265%203.265%200%200%200%203.256-3.256v-16.285a3.265%203.265%200%200%200%20-3.256-3.256m-.272%209.031-11.944%206.498a1.7%201.7%200%200%201%20-1.627%200l-11.943-6.5a1.7%201.7%200%200%201%201.627-2.99l11.128%206.057%2011.128-6.057a1.7%201.7%200%200%201%201.627%202.99%22%20fill%3D%22%2365bb22%22%20transform%3D%22translate(3.212%205.549)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

.u-ic-dl-w {
  width: 1.1em;
  height: 1.1em;
  background: url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20width%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20%3E%3CclipPath%20id%3D%22a%22%3E%3Cpath%20d%3D%22m0%200h24v24h-24z%22%2F%3E%3C%2FclipPath%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cg%20clip-path%3D%22url(%23a)%22%20opacity%3D%220%22%3E%3Cpath%20d%3D%22m0%200h24v24h-24z%22%20fill%3D%22%23fff%22%2F%3E%3C%2Fg%3E%3Cpath%20d%3D%22m20.815%2015.653v5.294h-17.63v-5.294%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%222%22%2F%3E%3C%2Fg%3E%3Cpath%20d%3D%22m18.712%208.064-6.712%206.712-6.712-6.712%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%222%22%2F%3E%3Cg%20clip-path%3D%22url(%23a)%22%3E%3Cpath%20d%3D%22m0%2012.466v-12.466%22%20fill%3D%22none%22%20stroke%3D%22%23fff%22%20stroke-linecap%3D%22round%22%20stroke-miterlimit%3D%2210%22%20stroke-width%3D%222%22%20transform%3D%22translate(12%202.31)%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/contain;
}

@media (hover: hover) and (pointer: fine){
  :where(.l-main a:not([class])) {
    -webkit-transition: color 0.3s ease;
    transition: color 0.3s ease;
  }
  :where(.l-main a:not([class])):hover {
    color: #56b011;
  }
  .l-footer__nav a:hover {
    color: #56b011;
  }
  .p-globalnav__menu01 a {
    -webkit-transition: color 0.2s ease;
    transition: color 0.2s ease;
  }
  .p-globalnav__menu01 a:hover {
    color: #65bb22;
  }
  .p-globalnav__contact-button {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-globalnav__contact-button:hover {
    background-color: #65bb22;
  }
  .p-nav__menu01 a, .p-nav__menu02 a {
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
  }
  .p-nav__menu01 a:hover, .p-nav__menu02 a:hover {
    background-color: #56b011;
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
    -webkit-transform: translate(0%, -1%);
            transform: translate(0%, -1%);
  }
  .p-proposal-details__summary {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-proposal-details__summary:hover {
    background-color: #56b011;
  }
  .p-qa-details__summary {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-qa-details__summary:hover {
    background-color: #56b011;
  }
  .c-button01 {
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }
  .c-button01:hover {
    background-color: #56b011;
  }
  .c-button-cta {
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }
  .c-button-cta:hover {
    background-color: #063b28;
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
    -webkit-transform: translate(0%, -1%);
            transform: translate(0%, -1%);
  }
}

@media (pointer: fine), (hover: hover){
  .l-main a[href^="tel:"] {
    color: #333;
    text-decoration: none;
    pointer-events: none;
  }
}

@media (prefers-reduced-motion: no-preference){
  :where(html:focus-within) {
    scroll-behavior: smooth; /* 何かにフォーカスがある場合のみスムーズスクロール */
  }
}

@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none){
  :where(.l-main a:not([class])) {
    -webkit-transition: color 0.3s ease;
    transition: color 0.3s ease;
  }
  :where(.l-main a:not([class])):hover {
    color: #56b011;
  }
  .l-footer__nav a:hover {
    color: #56b011;
  }
  .p-globalnav__menu01 a {
    -webkit-transition: color 0.2s ease;
    transition: color 0.2s ease;
  }
  .p-globalnav__menu01 a:hover {
    color: #65bb22;
  }
  .p-globalnav__contact-button {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-globalnav__contact-button:hover {
    background-color: #65bb22;
  }
  .p-nav__menu01 a, .p-nav__menu02 a {
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
  }
  .p-nav__menu01 a:hover, .p-nav__menu02 a:hover {
    background-color: #56b011;
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
    -webkit-transform: translate(0%, -1%);
            transform: translate(0%, -1%);
  }
  .p-proposal-details__summary {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-proposal-details__summary:hover {
    background-color: #56b011;
  }
  .p-qa-details__summary {
    -webkit-transition: background-color 0.2s ease;
    transition: background-color 0.2s ease;
  }
  .p-qa-details__summary:hover {
    background-color: #56b011;
  }
  .c-button01 {
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }
  .c-button01:hover {
    background-color: #56b011;
  }
  .c-button-cta {
    -webkit-transition: all 0.2s ease-in-out;
    transition: all 0.2s ease-in-out;
  }
  .c-button-cta:hover {
    background-color: #063b28;
    -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.32);
    -webkit-transform: translate(0%, -1%);
            transform: translate(0%, -1%);
  }
}

@media print, screen and (min-width: 1200px){
  .p-mv {
    height: clamp(76.8rem, 100dvh, 90rem);
  }
}

@media print, screen and (min-width: 375px){
  html {
    font-size: calc(var(--font-size) * 1%);
  }
}

@media print, screen and (min-width: 576px){
  .p-mv__text01 {
    top: 60%;
  }
  .p-proposal-subsection__header {
        grid-template-areas: "illust number-tags" "illust texts";
    gap: 1em min(6.6vw, 4em);
  }
  .p-proposal-subsection__header > .p-nav__illust {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header {
        grid-template-areas: "number-tags illust" "texts illust";
  }
  .p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-nav__illust {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection__illust {
    width: min(100%, 28.1rem);
  }
  .p-proposal-subsection__texts {
    -ms-flex-item-align: start;
        -ms-grid-row-align: start;
        align-self: start;
  }
  .p-proposal-subsection__header > .p-proposal-subsection__illust {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__illust {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection__texts {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__texts {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection__number-tags {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .p-proposal-subsection:nth-child(odd) .p-proposal-subsection__header > .p-proposal-subsection__number-tags {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .p-proposal-subsection__number-tags {
    gap: min(0.4vw, 0.5rem);
    -ms-flex-item-align: end;
        -ms-grid-row-align: end;
        align-self: end;
    padding-bottom: 1em;
    border-bottom: #D5DBCE solid 0.1rem;
  }
  .p-proposal-subsection__number {
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
    width: auto;
    padding: 0 0.75em 0 0;
    font-size: min(2.6vw, 2.6rem);
  }
  .p-proposal-subsection__tag {
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
    padding: 0.3rem min(1vw, 1.5em);
    font-size: min(1.3vw, 1.4rem);
  }
  .p-proposal-details__summary {
    text-align: center;
  }
}

@media print, screen and (min-width: 768px){
  html {
    scroll-padding-top: 100px;
  }
  html,
  body {
    min-width: 768px;
  }
  .l-main {
    padding-top: 0;
    line-height: 2;
  }
  .l-header {
    height: clamp(7rem, 11vh, 8.8rem);
    background-color: rgba(255, 255, 255, 0);
    -webkit-backdrop-filter: none;
            backdrop-filter: none;
  }
  .l-header.is-scroll {
    background-color: rgba(255, 255, 255, 0.95);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
  }
  .l-header__logo {
    top: 50%;
    left: 3.5rem;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .l-header__logo img {
    width: min(25vw, 25rem);
    height: clamp(5rem, 8vh, 6.1rem);
  }
  .l-footer {
    border-top: none;
  }
  .l-footer__inner {
        grid-template-areas: "logo consider" "logo other";
    -ms-grid-columns: ()[2];
    grid-template-columns: repeat(2);
  }
  .l-footer__logo-address {
    grid-area: logo;
    padding-right: min(3vw, 14rem);
  }
  .l-footer__logo-address-inner {
    padding-top: 4.5rem;
    margin: 0 0 0 auto;
  }
  .l-footer__logo {
    width: 23rem;
  }
  .l-footer__nav ul {
    margin-top: 1em;
  }
  .l-footer__nav-title {
    font-size: min(1.7vw, 2rem);
  }
  .l-footer__nav--consider {
    grid-area: consider;
    padding: min(3.5vw, 3.5rem) min(2.4vw, 3.2rem);
    font-size: min(1.4vw, 1.4rem);
  }
  .l-footer__nav--consider .l-footer__nav-inner {
    padding: 0 0 0.1em min(2.4vw, 3.2rem);
    margin: 0;
  }
  .l-footer__nav--other {
    grid-area: other;
    padding: min(3.5vw, 3.5rem) min(2.4vw, 3.2rem);
    font-size: min(1.4vw, 1.4rem);
  }
  .l-footer__logo-address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 2;
    -ms-grid-column: 1;
  }
  .l-footer__nav--consider {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .l-footer__nav--other {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .l-footer__nav--other .l-footer__nav-inner {
    padding: 0 0 0.1em min(2.4vw, 3.2rem);
    margin: 0;
  }
  .p-globalnav-triger {
    display: none;
  }
  .p-globalnav {
    position: absolute;
    top: 50%;
    right: 2rem;
    left: auto;
    display: block !important;
    width: auto;
    height: auto;
    padding: 0;
    pointer-events: all;
    visibility: visible;
    opacity: 1;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  .p-globalnav.is-open {
    -webkit-box-shadow: none;
            box-shadow: none;
  }
  .p-globalnav__inner {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    height: auto;
    padding: 0;
    overflow: visible;
    background-color: #fff;
  }
  .p-globalnav__menu01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    gap: 0 min(5vw, 6rem);
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
    padding-right: min(5vw, 6rem);
    padding-left: min(5vw, 6rem);
    margin: 0;
  }
  .p-globalnav__menu01 > li {
    margin-top: 0;
    font-size: min(1.6vw, 1.6rem);
    white-space: nowrap;
  }
  .p-globalnav__menu01 a > span {
    position: relative;
    display: inline-block;
  }
  .p-globalnav__contact {
    padding: 0;
  }
  .p-globalnav__contact-button {
    width: min(19.1vw, 23rem);
    height: 4rem;
    border: none;
  }
  .p-globalnav__contact-button > span {
    font-size: min(1.6vw, 1.6rem);
  }
  .p-mv {
    height: clamp(65rem, 70vw, 80rem);
  }
  .p-mv__bg-rt {
    width: min(68vw, 110rem);
  }
  .p-mv__bg-lb {
    bottom: 0;
    width: min(69.7vw, 110rem);
  }
  .p-mv__image img {
    top: 50%;
    width: min(70%, 112rem);
    -webkit-transform: translate(-20%, -50%);
            transform: translate(-20%, -50%);
  }
  .p-mv__text01 {
    top: 50%;
    left: 0;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 3rem min(4.5vw, 9rem);
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    -webkit-animation: mvtext0101-pc 2.5s ease-out 0.7s both;
            animation: mvtext0101-pc 2.5s ease-out 0.7s both;
  }
  .p-mv__text01-l {
    font-size: min(3.6vw, 7rem);
    text-align: left;
  }
  .p-mv__text01-l span:nth-child(1) {
    -webkit-animation: mvtext0102 0.5s ease-in 1.3s both;
            animation: mvtext0102 0.5s ease-in 1.3s both;
  }
  .p-mv__text01-l span:nth-child(2) {
    -webkit-animation: mvtext0102 0.5s ease-in 1.8s both;
            animation: mvtext0102 0.5s ease-in 1.8s both;
  }
  .p-mv__text01-s {
    font-size: min(1.7vw, 3rem);
    text-align: left;
    text-indent: 0.05em;
    letter-spacing: 0.6em;
  }
  .p-mv__text02 {
    top: 77%;
    right: 0;
    left: auto;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: 1rem min(12vw, 3.5em) 1.2rem;
    opacity: 0;
    -webkit-animation: mvtext0201pc 7s ease-out 3s infinite;
            animation: mvtext0201pc 7s ease-out 3s infinite;
  }
  .p-mv__text02::before {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    display: inline-block;
    width: 100%;
    height: 100%;
    clip-path: inset(0 100% 0 0);
    content: "";
    background-color: #006B93;
    background-color: #7FCE43;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    -webkit-animation: mvtext0202 7s ease-out 3s infinite;
            animation: mvtext0202 7s ease-out 3s infinite;
  }
  .p-mv__text02-01, .p-mv__text02-02 {
    display: inline-block;
    padding: 0;
    font-size: min(2.5vw, 7rem);
    opacity: 1;
  }
  .p-mv__text02-01::before, .p-mv__text02-02::before {
    display: none;
  }
  .p-mv__text02-01 {
    -webkit-animation: none;
            animation: none;
  }
  .p-mv__text02-02 {
    margin: 0;
    -webkit-animation: none;
            animation: none;
  }
  .p-nav__bg {
    top: 50%;
    width: min(70%, 100rem);
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
  .p-nav__inner {
    -ms-grid-rows: auto 4rem auto 4rem auto;
        grid-template-areas: "title title title" "menu01 illust menu02" "button-cta button-cta button-cta";
    -ms-grid-columns: min(37%, 39rem) 2rem auto 2rem min(37%, 39rem);
    grid-template-columns: min(37%, 39rem) auto min(37%, 39rem);
    gap: 4rem 2rem;
  }
  .p-nav__illust {
    -ms-flex-item-align: center;
        -ms-grid-row-align: center;
        align-self: center;
  }
  .p-nav__illust img {
    width: min(90%, 33.8rem);
  }
  .p-nav__menu01 li + li, .p-nav__menu02 li + li {
    margin-top: min(2.5vw, 3.2rem);
  }
  .p-nav__menu01 a, .p-nav__menu02 a {
    width: min(95%, 34rem);
  }
  .p-nav__menu01 a > span, .p-nav__menu02 a > span {
    font-size: min(1.8vw, 2rem);
  }
  .is-active .p-nav__menu01 li:nth-of-type(1) {
    -webkit-animation: navlist 0.75s ease-out 0.8s both;
            animation: navlist 0.75s ease-out 0.8s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(1) {
    -webkit-animation: navlist 0.75s ease-out 0.9s both;
            animation: navlist 0.75s ease-out 0.9s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(2) {
    -webkit-animation: navlist 0.75s ease-out 0.9s both;
            animation: navlist 0.75s ease-out 0.9s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(2) {
    -webkit-animation: navlist 0.75s ease-out 1s both;
            animation: navlist 0.75s ease-out 1s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(3) {
    -webkit-animation: navlist 0.75s ease-out 1s both;
            animation: navlist 0.75s ease-out 1s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(3) {
    -webkit-animation: navlist 0.75s ease-out 1.1s both;
            animation: navlist 0.75s ease-out 1.1s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(4) {
    -webkit-animation: navlist 0.75s ease-out 1.1s both;
            animation: navlist 0.75s ease-out 1.1s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(4) {
    -webkit-animation: navlist 0.75s ease-out 1.2s both;
            animation: navlist 0.75s ease-out 1.2s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(5) {
    -webkit-animation: navlist 0.75s ease-out 1.2s both;
            animation: navlist 0.75s ease-out 1.2s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(5) {
    -webkit-animation: navlist 0.75s ease-out 1.3s both;
            animation: navlist 0.75s ease-out 1.3s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(6) {
    -webkit-animation: navlist 0.75s ease-out 1.3s both;
            animation: navlist 0.75s ease-out 1.3s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(6) {
    -webkit-animation: navlist 0.75s ease-out 1.4s both;
            animation: navlist 0.75s ease-out 1.4s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(7) {
    -webkit-animation: navlist 0.75s ease-out 1.4s both;
            animation: navlist 0.75s ease-out 1.4s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(7) {
    -webkit-animation: navlist 0.75s ease-out 1.5s both;
            animation: navlist 0.75s ease-out 1.5s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(8) {
    -webkit-animation: navlist 0.75s ease-out 1.5s both;
            animation: navlist 0.75s ease-out 1.5s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(8) {
    -webkit-animation: navlist 0.75s ease-out 1.6s both;
            animation: navlist 0.75s ease-out 1.6s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(9) {
    -webkit-animation: navlist 0.75s ease-out 1.6s both;
            animation: navlist 0.75s ease-out 1.6s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(9) {
    -webkit-animation: navlist 0.75s ease-out 1.7s both;
            animation: navlist 0.75s ease-out 1.7s both;
  }
  .is-active .p-nav__menu01 li:nth-of-type(10) {
    -webkit-animation: navlist 0.75s ease-out 1.7s both;
            animation: navlist 0.75s ease-out 1.7s both;
  }
  .is-active .p-nav__menu02 li:nth-of-type(10) {
    -webkit-animation: navlist 0.75s ease-out 1.8s both;
            animation: navlist 0.75s ease-out 1.8s both;
  }
  .p-proposal__button-cta {
    margin-top: 4em;
  }
  .p-nav__title {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 5;
  }
  .p-nav__illust {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .p-nav__menu01 {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .p-nav__menu02 {
    -ms-grid-row: 3;
    -ms-grid-column: 5;
  }
  .p-nav__button-cta {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 5;
  }
  .p-proposal-subsection__illust {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .p-proposal-subsection__title {
    font-size: min(3.3vw, 4.2rem);
  }
  .p-proposal-subsection__desc {
    margin-top: 1.5em;
    font-size: min(2vw, 1.8rem);
    letter-spacing: 0.1em;
  }
  .p-proposal-details {
    margin-top: min(2.928vw, 4rem);
  }
  .p-proposal-details__summary {
    padding: 1.7rem 7rem 1.7rem 4.5rem;
    font-size: min(2.6vw, 2.8rem);
    letter-spacing: 0.2em;
  }
  .p-proposal-details__summary::before, .p-proposal-details__summary::after {
    width: 6.6rem;
  }
  .p-proposal-details__summary::before {
    background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2020.328%2020.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2.8rem 2.8rem;
  }
  .p-proposal-details__summary::after {
    background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2220.328%22%20viewBox%3D%220%200%2020.328%2020.328%22%20width%3D%2220.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%20opacity%3D%220%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2.8rem 2.8rem;
  }
  .p-proposal-details__body {
    padding: min(4vw, 2em) min(5vw, 3em) min(5vw, 3em);
    line-height: 2.25;
  }
  .p-proposal-details__picture {
    margin-top: 1.5em;
  }
  .p-proposal-details__picture--col2 {
    -ms-grid-columns: 1fr min(4vw, 5rem) 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: min(4vw, 5rem);
  }
  .p-qa__title {
    font-size: 7.2rem;
  }
  .p-qa-details {
    margin-top: min(2.928vw, 4rem);
  }
  .p-qa-details__summary {
    padding: 2rem 7rem 2rem 6.5rem;
    font-size: min(2vw, 2.2rem);
    letter-spacing: 0.05em;
  }
  .p-qa-details__summary::before, .p-qa-details__summary::after {
    width: 6.6rem;
  }
  .p-qa-details__summary::before {
    background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2020.328%2020.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2.8rem 2.8rem;
  }
  .p-qa-details__summary::after {
    background: #000 url("data:image/svg+xml;charset=utf8,%3Csvg%20height%3D%2220.328%22%20viewBox%3D%220%200%2020.328%2020.328%22%20width%3D%2220.328%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22m0%207.818h20.328v4.691h-20.328z%22%2F%3E%3Cpath%20d%3D%22m7.819%200h4.691v20.328h-4.691z%22%20opacity%3D%220%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E") no-repeat center center/2.8rem 2.8rem;
  }
  .p-qa-details__body {
    padding: 3rem 2.5rem 4rem 6.6rem;
    line-height: 1.8;
    letter-spacing: 0.1em;
  }
  .p-qa-details__ic-q, .p-qa-details__ic-a {
    left: min(1.5vw, 1.5rem);
    font-size: 3.8rem;
  }
  .p-qa-details__ic-a {
    top: 2rem;
    left: 2rem;
  }
  .p-contact-form input[type=text],
  .p-contact-form input[type=email],
  .p-contact-form input[type=tel],
  .p-contact-form textarea {
    padding: 1.25em 1em;
    font-size: clamp(1.4rem, 1.309rem + 0.39vw, 1.6rem);
  }
  .p-contact-form .p-contact-form__notice {
    font-size: 1.3rem;
  }
  .p-contact-form select {
    width: min(100%, 36.3rem);
    height: 50px;
    padding-left: 1em;
    background-position: right 13px center;
    background-size: 12px 8px;
    border-radius: 4px;
  }
  .p-contact-thanks-section01 {
    padding-top: min(5vw, 4em);
  }
  .p-thanks .l-main {
    padding-top: clamp(7rem, 11vh, 8.8rem);
  }
  .p-thanks-section {
    font-size: 1.5rem;
    text-align: center;
  }
  :where(.c-button01) > span {
    font-size: 2rem;
  }
  .c-button01 > i:first-child {
    left: min(0.2vw, 0.5rem);
  }
  .c-button01 > i:last-child {
    right: min(0.2vw, 0.5rem);
  }
  .c-button-cta > div {
    font-size: 3rem;
  }
  .c-button-cta > div > span {
    padding-left: 5.1rem;
  }
  .c-button-cta > div > span i {
    width: 4.6rem;
    height: 4.6rem;
  }
  .c-button-cta__pen {
    width: 3rem;
    height: 4rem;
  }
  .c-button-cta.is-active > div::after {
    -webkit-animation: ctaline-pc 1s ease 0.1s both;
            animation: ctaline-pc 1s ease 0.1s both;
  }
  .c-button-cta.is-active .c-button-cta__pen {
    -webkit-animation: pen-pc 1s ease 0.1s both;
            animation: pen-pc 1s ease 0.1s both;
  }
  .u-visible-sp {
    display: none;
  }
  .u-visible-pc {
    display: inline-block;
  }
}

@media print, screen and (min-width: 992px){
  body.is-gnav-open {
    height: auto;
    overflow: visible;
  }
  .l-footer__inner {
        grid-template-areas: "logo consider other";
    -ms-grid-columns: auto min(30vw, 36rem) auto;
    grid-template-columns: auto min(30vw, 36rem) auto;
  }
  .l-footer__logo {
    width: min(27vw, 32rem);
    margin: 0;
  }
  .l-footer__address {
    font-size: min(1.2vw, 1.4rem);
  }
  .l-footer__copyright {
    font-size: min(1.1vw, 1.3rem);
  }
  .l-footer__nav--consider {
    padding-top: min(6.7vw, 7.2rem);
    padding-bottom: min(6.7vw, 7.2rem);
  }
  .l-footer__logo-address {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
  .l-footer__nav--consider {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .l-footer__nav--other {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .l-footer__nav--other {
    padding-top: min(6.7vw, 7.2rem);
    padding-bottom: min(6.7vw, 7.2rem);
  }
  .p-mv {
    height: clamp(76.8rem, 100dvh, 80rem);
  }
}

@media print, screen and (width <= 575px){
  .u-visible-s {
    display: inline-block;
  }
}

@media print, screen and (width >= 1200px) and (width <= 1365px){
  .u-visible-xl {
    display: inline-block;
  }
}

@media print, screen and (width >= 1366px){
  .u-visible-xxl {
    display: inline-block;
  }
}

@media print, screen and (width >= 576px) and (width <= 767.98px){
  .u-visible-sm {
    display: inline-block;
  }
}

@media print, screen and (width >= 768px) and (width <= 991px){
  .u-visible-md {
    display: inline-block;
  }
}

@media print, screen and (width >= 992px) and (width <= 1199px){
  .u-visible-lg {
    display: inline-block;
  }
}