@charset "UTF-8";
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

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

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

svg,
img {
  max-width: 100%;
  vertical-align: middle;
}

li {
  list-style: none;
}

h1, h2, h3, h4, h5, h6, th, dt {
  font-weight: inherit;
}

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

img {
  height: auto;
}

.c-paragraph, .c-card-service-other__desc, .c-btn-round2__txt, .cm-modal-team__desc, .cm-modal-team__info dd, .cm-main-links-item__desc, .cm-block-work__body, .cm-block-work__txt, .cm-block-services-item__desc, .cm-block-solution-approach__list, .mw_wp_form_confirm .p-contact__form-value-area, .p-work-single-head__info, .p-services-how-item__desc {
  font-feature-settings: "palt" on;
  font-size: 0.9375rem;
  line-height: 180%;
}

.c-paragraph--heading {
  font-feature-settings: "pwid" on;
  font-family: "FOT-筑紫ゴシック Pro B", sans-serif;
  letter-spacing: -0.03em;
}

.c-paragraph-en, .c-link-scroll, .c-heading-accent, .c-btn-round--contact .c-btn-round__txt, .c-btn-menu, .c-btn-play, .cm-nav-header-link {
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 500;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
@media screen and (min-width: 1024px) {
  .c-paragraph-en, .c-link-scroll, .c-heading-accent, .c-btn-round--contact .c-btn-round__txt, .c-btn-menu, .c-btn-play, .cm-nav-header-link {
    letter-spacing: 0.01em;
  }
}

.c-paragraph-en-sm, .cm-nav-group a, .cm-nav-bottom__link, .cm-nav-bottom__copyright, .l-simple-footer__copyright {
  font-family: "Inter", sans-serif;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 120%;
}

.c-heading-typography {
  font-family: "Inter", sans-serif;
  font-size: 2.25rem;
  font-weight: 300;
  line-height: 115%; /* 41.0.25rem */
  letter-spacing: 0.01em;
}
@media screen and (min-width: 1024px) {
  .c-heading-typography {
    font-size: 2.9375rem;
    letter-spacing: 0.01em;
  }
}

.c-heading-typography-sm, .cm-main-links-item__head {
  font-family: "Inter", sans-serif;
  font-size: 2.25rem;
  font-weight: 300;
  line-height: 120%; /* 43.0.125rem */
  letter-spacing: 0.01em;
}
@media screen and (min-width: 1024px) {
  .c-heading-typography-sm, .cm-main-links-item__head {
    letter-spacing: 0.01em;
  }
}

.c-list-tags, .cm-block-services-item__type {
  display: flex;
  align-items: center;
  align-content: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.c-list-tags li, .cm-block-services-item__type li {
  display: flex;
  height: 1.8125rem;
  padding: 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  border-radius: 0.125rem;
  color: #0E1410;
  background: var(--White, #FFF);
  font-size: 0.6875rem;
  line-height: 120%; /* 13.0.125rem */
}

.c-list-disc li, .cm-block-solution-approach__list li {
  position: relative;
  padding-left: 1rem;
}
.c-list-disc li:before, .cm-block-solution-approach__list li:before {
  content: "";
  display: block;
  width: 0.375rem;
  height: 0.375rem;
  position: absolute;
  left: 0;
  top: 0.65em;
  pointer-events: none;
  background: #38B48B;
  border-radius: 100%;
}

:root {
  --color: #0E1410;
  --color-inverse: #F4F1EE;
  --Dark-Green: #2B3D33;
  --Alceo-Green: #38B48B;
  --Gray: #8F8F8F;
  --Green-Gray: #E1E4DD;
  --Light-Gray: #F4F1EE;
  --White: #FFF;
  --color-accent: #38B48B;
  --header-height: 5.5rem;
  --breackpoint-md: 768px;
}
@media screen and (min-width: 1024px) {
  :root {
    --header-height: 6.25rem;
  }
}

:root {
  --animation-primary: 0.55s cubic-bezier(0.18, 0.06, 0.23, 1);
  --animation-fast: 0.275s cubic-bezier(0.18, 0.06, 0.23, 1);
  --animation-smooth: 0.55s cubic-bezier(0.62, 0.05, 0.01, 0.99);
  --animation-smooth-faster: 0.275s cubic-bezier(0.62, 0.05, 0.01, 0.99);
  --gap: 1.25rem;
  --padding-block-sm: 1.875rem;
  --padding-block: 2.5rem;
  --padding-section: 5rem;
  --padding-section-md: 5rem;
  --padding-head: 7.75rem;
}
@media screen and (min-width: 1024px) {
  :root {
    --gap: 1.25rem;
    --padding-block: 2.5rem;
    --padding-section: 6.25rem;
    --padding-section-md: 7.5rem;
  }
}

:root {
  --border-color: 1px solid var(--color);
  --border-accent: 1px solid var(--color-accent);
  --border-inverse: 1px solid rgba(244, 241, 238, 0.3);
  --border-gray: 1px solid #8F8F8F;
  --border-gray-light: 1px solid rgba(143, 143, 143, 0.3);
}

.is-section-dark {
  color: var(--color);
  --color: #F4F1EE;
}

/*----------------------------------------------------
	フォーム
----------------------------------------------------*/
[hidden] {
  display: none !important;
}

[disabled] {
  pointer-events: none;
}

.sr-only {
  position: absolute;
  clip: rect(1px, 1px, 1px, 1px);
  left: -9999px;
  top: -9999px;
}

input,
select,
label {
  vertical-align: middle;
  color: var(--color);
}

[type=text] {
  line-height: normal;
}

input[type=text],
input[type=email],
input[type=tel],
button {
  appearance: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  color: var(--color);
}

input[type=submit],
button {
  cursor: pointer;
  border: none;
  padding: 0;
  font: inherit;
}

textarea {
  appearance: none;
  resize: none;
  outline: none;
  background: transparent;
  color: var(--color);
}

input[type=text],
input[type=email],
input[type=tel],
textarea {
  width: 100%;
  border-radius: 0.625rem;
  border: var(--border-gray);
  background: var(--White, #FFF);
  padding: 0.75rem 0.9375rem;
  font-family: monospace;
  font-size: max(0.9375rem, 16px);
  line-height: 1.8;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
textarea:focus {
  outline: 3px solid rgba(56, 180, 139, 0.1);
  border: var(--border-accent);
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=tel]::placeholder,
textarea::placeholder {
  font-family: "FOT-筑紫ゴシック Pr5 D", sans-serif, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", sans-serif !important;
  color: var(--Gray, #8F8F8F);
  font-size: 0.9375rem;
}

textarea {
  height: 15rem;
}

/*----------------------------------------------------
	フォント
----------------------------------------------------*/
html {
  font-size: 16px;
}
@media screen and (max-width: 640px) {
  html {
    font-size: 4vw;
  }
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  html {
    font-size: 2.1333333333vw;
  }
}
@media screen and (min-width: 1024px) {
  html {
    font-size: 1.1111111111vw;
  }
}
body {
  font-family: "FOT-筑紫ゴシック Pr5 D", sans-serif, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "メイリオ", "Meiryo", sans-serif;
  font-feature-settings: "pwid" on;
  line-height: 1.5;
  font-weight: 600;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  word-wrap: break-word;
  color: var(--color);
}

.serif {
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "HG明朝E", "ＭＳ 明朝", serif;
}

/*----------------------------------------------------
	レスポンシブ
----------------------------------------------------*/
@media screen and (min-width: 641px) {
  .sp {
    display: none;
  }
}

@media screen and (min-width: 1024px) {
  .sp-tab {
    display: none;
  }
}

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

@media screen and (max-width: 640px) {
  .pc-tab {
    display: none;
  }
}

@media screen and (max-width: 640px) {
  .tab {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .tab {
    display: none;
  }
}

/*----------------------------------------------------
	リンク
----------------------------------------------------*/
a {
  color: var(--color);
  text-decoration: none;
  transition: var(--animation-fast);
}
a svg,
a img {
  transition: var(--animation-fast);
}
@media (hover: hover) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
@media (hover: none) {
  a, button {
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }
}
[data-scroll-target] {
  content: "";
  display: block;
  position: relative;
  pointer-events: none;
  top: calc(-1 * var(--header-height));
}

/*----------------------------------------------------
	コンテナ
----------------------------------------------------*/
.l-container {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .l-container {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .l-container {
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}
@media screen and (min-width: 1024px) {
  .l-container {
    padding-left: 2.7777777778vw;
    padding-right: 2.7777777778vw;
  }
}
/*----------------------------------------------------
	body
----------------------------------------------------*/
html {
  height: 100%;
}

#fontplus-trial-banner {
  display: none !important;
}

body {
  position: relative;
  height: 100%;
  background: var(--Light-Gray, #F4F1EE);
}
body.is-nav-open {
  overflow: hidden;
}

.l-body-wrap {
  width: 100%;
  min-height: 100%;
}
@media screen and (max-width: 1023px) {
  .l-body-wrap {
    overflow: hidden;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.l-body-mask {
  position: fixed;
  display: block;
  width: 100%;
  height: 100vh;
  left: 0;
  top: 0;
  pointer-events: none;
  z-index: 450;
  opacity: 0;
}
.is-page-transition .l-body-mask {
  opacity: 1;
}

.l-body-mask__white {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(-90deg, #F4F1EE 50%, rgba(244, 241, 238, 0) 100%);
  background-size: 200%;
  background-position: 100% 0;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 2;
}
.is-page-transition .l-body-mask__white {
  transition: background-position 1s 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  background-position: -100% 0;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	ヘッダー
----------------------------------------------------*/
.l-header-logo {
  position: fixed;
  left: 1.25rem;
  top: 2.5rem;
  width: 7.0625rem;
  z-index: 400;
  transition: var(--animation-primary);
  transform: translateY(0);
}
.l-header-logo img {
  transform-origin: left top;
  transition: none;
}
.scrollDown .l-header-logo {
  transform: translateY(calc(-1 * var(--header-height)));
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .l-header-logo {
    left: 2.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-header-logo {
    left: 2.5rem;
    width: 8.25rem;
  }
}

body:has(.p-top) .l-header-logo {
  opacity: 0;
}
.l-header-nav {
  position: fixed;
  right: 2.5rem;
  top: 2.5rem;
  z-index: 500;
  transition: var(--animation-primary);
  transform: translateY(0);
}
.scrollDown .l-header-nav {
  transform: translateY(calc(-1 * var(--header-height)));
}
@media screen and (max-width: 1023px) {
  .l-header-nav {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .l-header-nav {
    display: flex;
    align-items: center;
    gap: 5.3125rem;
  }
}

.l-header-menu.c-btn-menu {
  position: fixed;
  top: 2.5rem;
  right: 1.25rem;
  z-index: 500;
  transition: var(--animation-primary);
  transform: translateY(0);
}
.scrollDown .l-header-menu.c-btn-menu {
  transform: translateY(calc(-1 * var(--header-height)));
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .l-header-menu.c-btn-menu {
    right: 2.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .l-header-menu.c-btn-menu {
    display: none;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	l-header-drawer
----------------------------------------------------*/
.l-header-drawer {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  z-index: 450;
  opacity: 0;
  pointer-events: none;
  transition: var(--animation-smooth);
}
.is-nav-open .l-header-drawer {
  transition: var(--animation-smooth);
  opacity: 1;
  pointer-events: auto;
}
@media screen and (min-width: 1024px) {
  .l-header-drawer {
    display: none;
  }
}

.l-header-drawer__wrap {
  padding: 5.125rem 1.25rem 2.375rem;
  display: grid;
  grid-template-areas: "nav link" "bottom bottom";
  grid-template-rows: 1fr auto;
  grid-template-columns: 1fr auto;
  width: 100%;
  height: 100dvh;
  overscroll-behavior: contain;
  background: #2B3D33;
}

.l-header-drawer-nav {
  margin-top: auto;
  grid-area: nav;
}

.l-header-drawer-link {
  grid-area: link;
  align-self: flex-end;
}

.l-header-drawer-bottom {
  grid-area: bottom;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	main
----------------------------------------------------*/
/*----------------------------------------------------
	フッター
----------------------------------------------------*/
.l-footer {
  position: relative;
  padding: 5.125rem 0 2.375rem;
  background: var(--Dark-Green, #2B3D33);
}
@media screen and (min-width: 1024px) {
  .l-footer {
    padding: 3.25rem 0 1.875rem;
  }
}
.l-footer a:hover {
  color: var(--color-accent);
}

.l-footer__bg {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  pointer-events: none;
}
.l-footer__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 1023px) {
  .l-footer__bg {
    display: none;
  }
}

.l-footer__wrap {
  position: relative;
  display: grid;
  grid-template-areas: "head head" "nav link" "bottom bottom";
  grid-template-columns: 1fr auto;
}
@media screen and (min-width: 1024px) {
  .l-footer__wrap {
    grid-template-areas: "head nav link" "bottom bottom bottom";
    grid-template-columns: 1fr 21.5625rem 15rem;
  }
}

.l-footer-head {
  grid-area: head;
}
.l-footer-head__logo {
  width: 16.5rem;
}
@media screen and (min-width: 1024px) {
  .l-footer-head__logo {
    width: 31.125rem;
  }
}

.l-footer-head__desc {
  margin-top: 1.875rem;
  color: var(--Alceo-Green, #38B48B);
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 120%; /* 1.5rem */
  letter-spacing: -0.02em;
}
@media screen and (min-width: 1024px) {
  .l-footer-head__desc {
    margin-top: 2.5rem;
  }
}

.l-footer-nav {
  margin-top: 3.4375rem;
  grid-area: nav;
}
@media screen and (min-width: 1024px) {
  .l-footer-nav {
    margin-top: 0;
  }
}

.l-footer-link {
  grid-area: link;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  height: 100%;
  box-sizing: border-box;
  padding-top: 3.4375rem;
}
@media screen and (min-width: 1024px) {
  .l-footer-link {
    padding-top: 0;
  }
}

.l-footer-link__note {
  display: flex;
  align-items: center;
  gap: 0.3125rem;
  padding-block: 0.375rem;
}
.l-footer-link__note span {
  width: 5.3125rem;
}
.l-footer-link__note span svg {
  fill: currentColor;
}
.l-footer-link__note i {
  width: 0.625rem;
}
.l-footer-link__note i svg {
  stroke: currentColor;
}
.l-footer-link__note svg {
  width: 100%;
  height: auto;
}

.l-footer-bottom {
  grid-area: bottom;
}

/*----------------------------------------------------
	フッター（simple版）
----------------------------------------------------*/
.l-simple-footer__copyright {
  color: var(--Gray, #8F8F8F);
  padding-block: 1.875rem;
}

/*----------------------------------------------------
	p-about
----------------------------------------------------*/
.p-about {
  padding-top: var(--padding-head);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-head__title {
  padding-top: 3.0625rem;
}
@media screen and (min-width: 1024px) {
  .p-about-head__title {
    padding-top: 5.75rem;
    width: 31.875rem;
  }
}

.p-about-head__mv img {
  width: 100%;
  border-radius: 0.625rem;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-lead__wrap {
  display: flex;
  flex-direction: column;
  margin-top: 1.875rem;
}
@media screen and (min-width: 1024px) {
  .p-about-lead__wrap {
    gap: 12rem;
    margin-top: 0;
    flex-direction: row;
  }
}

.p-about-lead__pic img {
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-about-lead__pic {
    padding-left: 5.5rem;
    width: 36.5rem;
  }
}

.p-about-lead__body {
  margin-top: 3.75rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--padding-block-sm);
}
@media screen and (min-width: 1024px) {
  .p-about-lead__body {
    margin-top: 4.625rem;
    padding-right: 5.5rem;
  }
}

.p-about-lead__links {
  padding-top: 1.875rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
@media screen and (min-width: 1024px) {
  .p-about-lead__links {
    width: 23.9375rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-who {
  overflow: hidden;
  padding: var(--padding-section) 0;
  background: var(--Green-Gray, #E1E4DD);
}
.p-about-who-gallery {
  padding-top: 1.875rem;
  position: relative;
}
.p-about-who-gallery .swiper {
  overflow: inherit;
}
.p-about-who-gallery .swiper-wrapper {
  height: auto;
}
.p-about-who-gallery .swiper-slide {
  align-self: flex-end;
}
@media screen and (min-width: 1024px) {
  .p-about-who-gallery {
    padding-top: 2.5rem;
  }
}

.p-about-who-gallery__wrap {
  overflow: hidden;
  width: auto;
  position: relative;
  white-space: nowrap;
  margin-inline: calc(50% - 50vw);
  display: flex;
}

.p-about-who-gallery__items {
  padding-left: 1.25rem;
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 1.25rem;
  will-change: transform;
}
.p-about-who-gallery__items img {
  border-radius: 0.625rem;
  max-width: 16.6875rem;
  max-height: 17.125rem;
  object-fit: cover;
}
@media screen and (min-width: 1024px) {
  .p-about-who-gallery__items {
    padding-left: 2.5rem;
  }
  .p-about-who-gallery__items img {
    max-width: 31.125rem;
    max-height: 31.9375rem;
  }
}

.p-about-who-gallery__ctrl {
  position: absolute;
  right: 0;
  top: -1.5rem;
}
@media screen and (min-width: 1024px) {
  .p-about-who-gallery__ctrl {
    top: -2.5rem;
  }
}

.p-about-who-mission__wrap {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .p-about-who-mission__wrap {
    flex-direction: row;
  }
}

.p-about-who-mission__copy {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
@media screen and (min-width: 1024px) {
  .p-about-who-mission__copy {
    width: 31.25rem;
  }
}

.p-about-who-mission__body {
  margin-top: 3.75rem;
  display: flex;
  flex-direction: column;
  gap: var(--padding-block);
}
@media screen and (min-width: 1024px) {
  .p-about-who-mission__body {
    width: 36.5rem;
    margin-top: 0.25rem;
    margin-left: auto;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-message {
  padding: var(--padding-section) 0 var(--padding-block);
}
.p-about-message__wrap {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .p-about-message__wrap {
    flex-direction: row;
  }
}

@media screen and (min-width: 1024px) {
  .p-about-message__head {
    margin-right: 5.5rem;
  }
}

.p-about-message__pic {
  margin-top: 1.875rem;
  width: 16.6875rem;
}
.p-about-message__pic img {
  border-radius: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .p-about-message__pic {
    margin-top: 0.375rem;
    width: 25.75rem;
  }
}

.p-about-message__body {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-about-message__body {
    margin-top: -0.25rem;
    width: 36.5rem;
    padding-right: 5.5rem;
    margin-left: auto;
  }
}

.p-about-message__sign {
  margin-top: 3.75rem;
}
.p-about-message__sign ._job {
  color: var(--Gray, #8F8F8F);
  font-feature-settings: "pwid" on;
  font-size: 0.6875rem;
  line-height: 180%; /* 19.0.5rem */
}
.p-about-message__sign ._name {
  font-feature-settings: "pwid" on;
  font-size: 1.25rem;
  line-height: 180%; /* 2.25rem */
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-name {
  padding: var(--padding-section) 0;
}
.p-about-name__logo {
  margin-top: 3.75rem;
  text-align: center;
}
.p-about-name__logo img {
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-about-name__logo {
    margin-top: 6.875rem;
  }
  .p-about-name__logo img {
    width: 62.75rem;
  }
}

.p-about-name__wrap {
  margin-top: 5rem;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
@media screen and (min-width: 1024px) {
  .p-about-name__wrap {
    margin-top: 10.125rem;
    flex-direction: row;
    gap: 0;
  }
}

.p-about-name__pic {
  width: 10.6875rem;
}
.p-about-name__pic img {
  border-radius: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .p-about-name__pic {
    width: 20.1875rem;
  }
}

@media screen and (min-width: 1024px) {
  .p-about-name__body {
    margin-top: -1rem;
    width: 36.5rem;
    padding-right: 5.5rem;
    margin-left: auto;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-philosophy {
  padding: var(--padding-section) 0;
  background: var(--Dark-Green, #2B3D33);
}
.p-about-philosophy__list {
  padding-top: var(--padding-block);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-dna {
  padding: var(--padding-section) 0;
}
.p-about-dna__wrap {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
}
@media screen and (min-width: 1024px) {
  .p-about-dna__wrap {
    flex-direction: row;
    gap: 0;
  }
}

.p-about-dna__items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.625rem 1.25rem;
}
@media screen and (min-width: 1024px) {
  .p-about-dna__items {
    margin-top: 0.625rem;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 5rem 1.25rem;
    width: 63.5rem;
    margin-left: auto;
  }
}

.p-about-dna-item {
  padding-top: 1.25rem;
  border-top: var(--border-gray-light);
}
@media screen and (min-width: 1024px) {
  .p-about-dna-item {
    padding-top: 1.875rem;
  }
  .p-about-dna-item:nth-child(1) {
    grid-column: 2;
  }
}

.p-about-dna-item__title {
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 300;
  line-height: 120%; /* 1.5rem */
  letter-spacing: -0.05rem;
}
@media screen and (min-width: 1024px) {
  .p-about-dna-item__title {
    font-weight: 400;
  }
}

.p-about-dna-item__body {
  margin-top: 0.9375rem;
  font-size: 0.6875rem;
  line-height: 160%; /* 17.0.375rem */
  opacity: 0.5;
  font-feature-settings: "palt" on;
}
@media screen and (min-width: 1024px) {
  .p-about-dna-item__body {
    margin-top: 1.5625rem;
    font-size: 0.9375rem;
    line-height: 180%; /* 1.6875rem */
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-about-team {
  display: flex;
  flex-direction: column;
  background: var(--Green-Gray, #E1E4DD);
}
@media screen and (min-width: 1024px) {
  .p-about-team {
    flex-direction: row;
  }
}

.p-about-team__wrap {
  padding: var(--padding-section) 1.25rem 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-about-team__wrap {
    flex: 1;
    padding: var(--padding-section) 0 3.75rem 2.5rem;
  }
}

.p-about-team__body {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-about-team__body {
    margin-top: 4.1875rem;
    padding: 0 6rem 0 5.5rem;
  }
}

.p-about-team__lead {
  display: flex;
  flex-direction: column;
  gap: 0.9375rem;
}
@media screen and (min-width: 1024px) {
  .p-about-team__lead {
    width: 22.75rem;
  }
}

.p-about-team__desc {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-about-team__desc {
    margin-top: 5rem;
  }
}

.p-about-team__more {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-about-team__pic {
    width: 45rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	p-service
----------------------------------------------------*/
.p-service {
  padding-bottom: var(--padding-section);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-service-head__bc {
  position: absolute;
  z-index: 10;
  top: var(--padding-head);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-service-overview {
  padding-top: var(--padding-section);
}
.p-service-overview__head {
  display: flex;
  flex-direction: column;
  gap: var(--padding-block);
}
@media screen and (min-width: 1024px) {
  .p-service-overview__head {
    flex-direction: row;
    justify-content: space-between;
  }
}

@media screen and (min-width: 1024px) {
  .p-service-overview__lead {
    width: 36.5rem;
    margin-inline: auto 5.5rem;
  }
}

.p-service-overview__pic-area {
  margin-top: 2.5rem;
}
@media screen and (min-width: 1024px) {
  .p-service-overview__pic-area {
    margin-top: 3.75rem;
  }
}
@media screen and (max-width: 640px) {
  .p-service-overview__pic-area {
    overflow: auto;
    margin-inline: -5vw;
  }
}

.p-service-overview__pic-wrapper {
  display: flex;
}
@media screen and (max-width: 640px) {
  .p-service-overview__pic-wrapper {
    width: 220vw;
  }
  .p-service-overview__pic-wrapper::before, .p-service-overview__pic-wrapper::after {
    content: "";
    display: block;
    width: 5vw;
  }
}

.p-service-overview__pic {
  flex: 1;
  border-radius: 0.625rem;
  overflow: hidden;
}
.p-service-overview__pic + .p-service-overview__pic {
  margin-left: 1.25rem;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-service-solution__list {
  margin-top: var(--padding-block);
  display: flex;
  flex-direction: column;
  gap: 5rem;
}
@media screen and (min-width: 1024px) {
  .p-service-solution__list--grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-service-case__list {
  padding-top: var(--padding-block);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 1.25rem;
}
@media screen and (min-width: 1024px) {
  .p-service-case__list {
    gap: 3.75rem 1.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-service-links {
  padding: var(--padding-section) 0;
  background: var(--Dark-Green, #2B3D33);
}

.p-service-links__head {
  margin-bottom: 3.125rem;
}

/*----------------------------------------------------
	p-services
----------------------------------------------------*/
.p-services {
  padding-top: var(--padding-head);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-services-head__title {
  padding-top: 3.0625rem;
}
@media screen and (min-width: 1024px) {
  .p-services-head__title {
    padding-top: 5.75rem;
    width: 31.875rem;
  }
}

.p-services-head__mv img {
  width: 100%;
  border-radius: 0.625rem;
}
.p-services-head__lead {
  display: flex;
  flex-direction: column;
  gap: var(--padding-block-sm);
}
@media screen and (min-width: 1024px) {
  .p-services-head__lead {
    width: 31rem;
    margin-inline: auto 5.5rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-services-how {
  position: relative;
  overflow: hidden;
}

.p-services-how__ctrl {
  margin-top: 1.875rem;
  display: flex;
  gap: 0.25rem;
  justify-content: flex-end;
}
.p-services-how__ctrl .c-btn-ctrl {
  transition: var(--animation-primary);
}
.p-services-how__ctrl .swiper-button-disabled {
  opacity: 0.2;
}

.p-services-how__items {
  margin-top: 1.75rem;
}
.p-services-how__items .swiper {
  width: 16.625rem;
  overflow: initial;
  margin-left: 0;
}
.p-services-how__items .swiper-wrapper {
  transition-timing-function: cubic-bezier(0.18, 0.06, 0.23, 1);
}
@media screen and (min-width: 1024px) {
  .p-services-how__items {
    margin-top: 2rem;
    padding-left: 5.375rem;
  }
  .p-services-how__items .swiper {
    width: 25.75rem;
  }
}

.p-services-how-item__pic img {
  border-radius: 0.625rem;
}

.p-services-how-item__content {
  margin-top: 1.875rem;
}

.p-services-how-item__sub {
  color: var(--Alceo-Green, #38B48B);
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.02em;
}

.p-services-how-item__title {
  margin-top: 0.625rem;
  font-size: 1.25rem;
  line-height: 140%; /* 1.75rem */
  letter-spacing: -0.0375rem;
}

.p-services-how-item__desc {
  margin-top: 1.875rem;
  color: var(--Gray, #8F8F8F);
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-services-what {
  position: relative;
  overflow: hidden;
  background: var(--Dark-Green, #2B3D33);
  padding: var(--padding-section) 0;
}
@media screen and (min-width: 1024px) {
  .p-services-what {
    padding-bottom: 2.5rem;
  }
}

.p-services-what__wrap {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
}
@media screen and (min-width: 1024px) {
  .p-services-what__wrap {
    gap: 0;
    flex-direction: row;
  }
}

@media screen and (min-width: 1024px) {
  .p-services-what__head {
    width: 21.5625rem;
  }
}

.p-services-what__pic img {
  width: 35.8125rem;
  max-width: none;
}
@media screen and (max-width: 1023px) {
  .p-services-what__pic {
    margin-inline: calc(50% - 50vw);
    padding: 0 1.25rem;
    overflow: auto;
  }
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .p-services-what__pic img {
    width: 100%;
  }
}
@media screen and (min-width: 1024px) {
  .p-services-what__pic {
    flex: 1;
  }
  .p-services-what__pic img {
    width: 100%;
  }
}

.p-services-what__list {
  margin-top: var(--padding-section);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-services-other {
  padding: var(--padding-section) 0;
}

.p-services-other__wrap {
  display: flex;
  flex-direction: column;
  gap: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-services-other__wrap {
    gap: 0;
    flex-direction: row;
  }
}

@media screen and (min-width: 1024px) {
  .p-services-other__head {
    width: 21.5625rem;
  }
}

.p-services-other__list {
  display: grid;
  gap: 2.5rem;
}
@media screen and (min-width: 1024px) {
  .p-services-other__list {
    margin-top: 0.625rem;
    flex: 1;
    grid-template-columns: 1fr 1fr;
    gap: 5rem 1.25rem;
  }
}

/*----------------------------------------------------
	p-team
----------------------------------------------------*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-team-head {
  padding-top: var(--padding-head);
}
.p-team-head__wrap {
  padding-top: 3.0625rem;
  display: grid;
}
@media screen and (min-width: 1024px) {
  .p-team-head__wrap {
    padding-top: 5.75rem;
    margin-right: 5.5rem;
    grid-template-areas: "title sub" "title desc";
    grid-template-columns: 1fr 31rem;
  }
}

@media screen and (min-width: 1024px) {
  .p-team-head__title {
    grid-area: title;
  }
}

.p-team-head__sub {
  margin-top: 5rem;
}
@media screen and (min-width: 1024px) {
  .p-team-head__sub {
    grid-area: sub;
    margin-top: 0;
  }
}

.p-team-head__desc {
  margin-top: 2.5rem;
}
@media screen and (min-width: 1024px) {
  .p-team-head__desc {
    margin-top: 1.875rem;
    grid-area: desc;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-team-list {
  padding: var(--padding-section) 0;
}
.p-team-list__list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 1.3125rem;
}
@media screen and (min-width: 1024px) {
  .p-team-list__list {
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 6.25rem 1.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	...
----------------------------------------------------*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-top-mv {
  position: relative;
  overflow: hidden;
}
.p-top-mv__logo {
  padding-top: 181px;
  width: 16.6875rem;
}
.p-top-mv__logo img {
  width: 100%;
}
@media screen and (min-width: 1024px) {
  .p-top-mv__logo {
    padding-top: 51px;
    width: 36.375rem;
  }
}

.p-top-mv__wrap {
  margin-top: 4.75rem;
  display: flex;
  flex-direction: column;
  gap: 2.375rem;
}
@media screen and (min-width: 1024px) {
  .p-top-mv__wrap {
    margin-top: 9.125rem;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
  }
}

.p-top-mv-canvas {
  position: relative;
  border-radius: 0.625rem;
  overflow: hidden;
}
.canvas-active .p-top-mv-canvas #canvas {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 100vw;
  height: 100vh;
  will-change: transform;
}
.canvas-fallback .p-top-mv-canvas {
  background: url("../img/kv-bg.png") no-repeat center/cover;
}
.canvas-fallback .p-top-mv-canvas #canvas {
  display: none;
}
.canvas-fallback .p-top-mv-canvas #canvas + button {
  display: none;
}
@media screen and (max-width: 1023px) {
  .p-top-mv-canvas {
    height: 27.875rem;
  }
  .p-top-mv-canvas img {
    height: 100%;
    object-fit: cover;
  }
}
@media screen and (min-width: 1024px) {
  .p-top-mv-canvas {
    height: 33.75rem;
  }
}

.p-top-mv-canvas__ctrl {
  position: absolute;
  right: 1.25rem;
  bottom: 1.25rem;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-top-about {
  padding: var(--padding-section) 0;
  background: var(--Light-Gray, #F4F1EE);
  position: relative;
}
.p-top-about__wrap {
  margin-top: 1.875rem;
  display: flex;
  flex-direction: column;
  gap: 8.625rem;
}
@media screen and (min-width: 1024px) {
  .p-top-about__wrap {
    margin-top: 3rem;
    flex-direction: row;
  }
}

.p-top-about__pic {
  position: relative;
  width: 15.8125rem;
}
.p-top-about__pic figure:nth-child(2) {
  position: absolute;
  width: 9.25rem;
  top: 5.4375rem;
  right: -6.6875rem;
}
@media screen and (min-width: 1024px) {
  .p-top-about__pic {
    width: 25.625rem;
  }
  .p-top-about__pic figure:nth-child(2) {
    width: 15rem;
    top: 8.8125rem;
    right: -10.8125rem;
  }
}

@media screen and (min-width: 1024px) {
  .p-top-about__body {
    width: 31rem;
    margin-top: -0.625rem;
    margin-inline: auto 5.5rem;
  }
}

.p-top-about__lead {
  display: flex;
  flex-direction: column;
  gap: 0.9375rem;
}
.p-top-about__lead .c-paragraph {
  letter-spacing: 0.05em;
}
.p-top-about__txt {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-top-about__txt {
    margin-top: 5rem;
  }
}

.p-top-about__more {
  margin-top: 3.75rem;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-top-service {
  padding: var(--padding-section) 0;
  background: var(--Dark-Green, #2B3D33);
}
.p-top-service__wrap {
  margin-top: 3.75rem;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .p-top-service__wrap {
    margin-top: 2.5rem;
    flex-direction: row;
  }
}

.p-top-service__catch {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.p-top-service__catch p {
  font-family: "FOT-筑紫ゴシック Pro B", sans-serif;
}
@media screen and (min-width: 1024px) {
  .p-top-service__catch {
    flex: 1;
    gap: 0.9375rem;
  }
}

.p-top-service__body {
  margin-top: 3.75rem;
}
@media screen and (min-width: 1024px) {
  .p-top-service__body {
    margin-top: 0;
    width: 31rem;
    margin-right: 5.5rem;
  }
}

.p-top-service__more {
  margin-top: 3.75rem;
}
.p-top-service__list {
  margin-top: 5rem;
}
@media screen and (min-width: 1024px) {
  .p-top-service__list {
    margin-top: 9.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-top-work {
  padding: var(--padding-section) 0 0;
}
.p-top-work__list {
  padding-top: 2.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 1.25rem;
}
@media screen and (min-width: 1024px) {
  .p-top-work__list {
    gap: 3.75rem 1.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-top-client {
  padding: var(--padding-section) 0;
}
.p-top-client__list {
  padding-top: var(--padding-block);
  display: grid;
  justify-content: space-between;
  grid-template-columns: 4.5rem 4.5rem 4.5rem;
  gap: 2.5rem 1.25rem;
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .p-top-client__list {
    grid-template-columns: 4.5rem 4.5rem 4.5rem 4.5rem 4.5rem;
  }
}
@media screen and (min-width: 1024px) {
  .p-top-client__list {
    padding: var(--padding-block) 2.5rem 0;
    grid-template-columns: 7.5rem 7.5rem 7.5rem 7.5rem 7.5rem 7.5rem;
    gap: 3.75rem 3.75rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	p-work
----------------------------------------------------*/
.p-work {
  padding-top: var(--padding-head);
  padding-bottom: 5rem;
}
@media screen and (min-width: 1024px) {
  .p-work {
    padding-bottom: 9.375rem;
  }
}

.p-work-list__list {
  padding-top: 2.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 1.25rem;
}
@media screen and (min-width: 1024px) {
  .p-work-list__list {
    gap: 3.75rem 1.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-work-single {
  padding-bottom: 5rem;
}
@media screen and (min-width: 1024px) {
  .p-work-single {
    padding-bottom: 9.375rem;
  }
}

.p-work-single-head {
  padding-top: var(--padding-head);
  display: flex;
  flex-direction: column;
  gap: var(--padding-block-sm);
}
.p-work-single-head__title {
  padding: 3.5rem 0 3.75rem;
  font-family: "FOT-筑紫ゴシック Pr5 M", sans-serif;
  font-size: 1.6875rem;
  line-height: 160%; /* 43.0.125rem */
  letter-spacing: -0.0675rem;
}
@media screen and (min-width: 1024px) {
  .p-work-single-head__title {
    padding: 5.75rem 0 9.375rem;
    width: 41.9375rem;
    font-size: 2.25rem;
    line-height: 120%; /* 43.0.125rem */
    letter-spacing: -0.09rem;
  }
}

.p-work-single-head__info {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.p-work-single-head__info dl {
  display: flex;
  flex-direction: column;
  gap: 0.1875rem;
}
.p-work-single-head__info dt {
  color: var(--Gray, #8F8F8F);
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
@media screen and (min-width: 1024px) {
  .p-work-single-head__info {
    flex-direction: row;
    justify-content: space-between;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	p-contact
----------------------------------------------------*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-contact__container {
  margin-inline: auto;
  padding-block: 10.5rem 6.25rem;
}
@media screen and (min-width: 1024px) {
  .p-contact__container {
    width: 50rem;
    padding-top: 11.25rem;
  }
}

.p-contact__head {
  padding-bottom: 5rem;
}

.p-contact__title {
  padding-bottom: 1.875rem;
}

.p-contact__form-label-area {
  display: grid;
  grid-template-columns: auto auto 1fr;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
  font-weight: 600;
}

.p-contact__form-label {
  font-size: 1.25rem;
  letter-spacing: -0.0375rem;
}

.p-contact__form-icon {
  display: flex;
  align-items: center;
  padding-inline: 0.625rem;
  font-size: 0.9375rem;
  border-radius: 0.3125rem;
}

.p-contact__form-icon--required {
  color: var(--White, #FFF);
  background-color: var(--Dark-Green, #2B3D33);
}

.p-contact__form-icon--optional {
  background-color: var(--Green-Gray, #E1E4DD);
}

.p-contact__form-caption {
  grid-column: 1/4;
  grid-row: 2/3;
  color: var(--Gray, #8F8F8F);
  font-size: 0.6875rem;
  line-height: 1.2;
}

.p-contact__form-caption--black {
  color: var(--color, #0E1410);
}

.p-contact__form-row + .p-contact__form-row,
.p-contact__conditional-fields + .p-contact__form-row,
.p-contact__conditional-fields-inner .p-contact__form-row {
  padding-top: 3.75rem;
}

.p-contact__form-btn-area {
  padding-top: 3.75rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.p-contact__privacy-policy {
  display: inline-flex;
  align-items: center;
  gap: 0.1875rem;
  margin-right: 0.1875rem;
  color: var(--color-accent);
  transition: var(--animation-fast);
}
.p-contact__privacy-policy::after {
  content: "";
  display: inline-block;
  width: 0.6875rem;
  height: 0.5625rem;
  background-color: currentColor;
  mask: url('data:image/svg+xml;utf8,<svg viewBox="0 0 11 9" fill="none" xmlns="http://www.w3.org/2000/svg"><rect x="0.65" y="3.65" width="6.7" height="4.7" stroke="black" stroke-width="1.3" fill="none"/><path d="M2 1H10V5" stroke="black" stroke-width="1.3" fill="none"/></svg>') no-repeat center/contain;
}
.p-contact__privacy-policy:hover {
  color: inherit;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/* お問い合わせ完了ページ */
.p-contact__complete-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding-block: 10.5rem 6.25rem;
  min-height: calc(100vh - 4.625rem);
}
@media screen and (min-width: 1024px) {
  .p-contact__complete-content {
    padding-top: 11.25rem;
  }
}

.p-contact__complete-title {
  display: block;
  font-family: "Inter", sans-serif;
  font-size: 2.9375rem;
  font-weight: 300;
  line-height: 1.15;
  padding-bottom: 1.875rem;
}

.p-contact__complete-paragraph {
  padding-bottom: 5rem;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/* MW WP Form のためのスタイル */
.mwform-radio-field,
.mwform-checkbox-field {
  border-radius: 0.625rem;
  background-color: var(--White, #FFF);
}
.mwform-radio-field label,
.mwform-checkbox-field label {
  position: relative;
  cursor: pointer;
  border-radius: inherit;
}
.mwform-radio-field label input,
.mwform-checkbox-field label input {
  appearance: none;
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
}
.mwform-radio-field label input + span,
.mwform-checkbox-field label input + span {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.75rem 0.9375rem;
  border-radius: inherit;
  border: var(--border-gray-light);
  font-size: 0.9375rem;
  line-height: 1.8;
  transition: var(--animation-fast);
}
.mwform-radio-field label input + span::before,
.mwform-checkbox-field label input + span::before {
  content: "";
  width: 1.25rem;
  height: 1.25rem;
  border: var(--border-gray);
  background-color: var(--White, #FFF);
}
.mwform-radio-field label input + span::after,
.mwform-checkbox-field label input + span::after {
  opacity: 0;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin-block: auto;
}
.mwform-radio-field label input[type=checkbox] + span::before,
.mwform-checkbox-field label input[type=checkbox] + span::before {
  border-radius: 0.3125rem;
}
.mwform-radio-field label input[type=checkbox] + span::after,
.mwform-checkbox-field label input[type=checkbox] + span::after {
  left: 1.3125rem;
  width: 0.625rem;
  height: 0.3125rem;
  border-bottom: 0.09375rem solid var(--White, #FFF);
  border-left: 0.09375rem solid var(--White, #FFF);
  transform: rotate(-45deg) translateY(-22%);
}
.mwform-radio-field label input[type=radio] + span::before,
.mwform-checkbox-field label input[type=radio] + span::before {
  border-radius: 50%;
}
.mwform-radio-field label input[type=radio] + span::after,
.mwform-checkbox-field label input[type=radio] + span::after {
  left: 1.1875rem;
  width: 0.75rem;
  height: 0.75rem;
  background-color: var(--color-accent);
  border-radius: 50%;
}
.mwform-radio-field label input:checked + span,
.mwform-checkbox-field label input:checked + span {
  border-color: var(--color-accent);
  background-color: rgba(56, 180, 139, 0.1);
}
.mwform-radio-field label input:checked + span::before,
.mwform-checkbox-field label input:checked + span::before {
  border-color: var(--color-accent);
}
.mwform-radio-field label input:checked + span::after,
.mwform-checkbox-field label input:checked + span::after {
  opacity: 1;
}
.mwform-radio-field label input[type=checkbox]:checked + span::before,
.mwform-checkbox-field label input[type=checkbox]:checked + span::before {
  background-color: var(--color-accent);
}

.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0 !important;
}

/* 個別のエラー */
.formparts__alert {
  color: #B43838;
  font-size: 0.6875rem;
  line-height: 1.2;
  padding-bottom: 0.625rem;
}

.p-contact__form-row:has(.p-contact__selection-group) .formparts__alert {
  padding-bottom: 1.25rem;
}

.formparts__alert ~ .p-contact__form-value-area input[type=text],
.formparts__alert ~ .p-contact__form-value-area input[type=email],
.formparts__alert ~ .p-contact__form-value-area input[type=tel],
.formparts__alert ~ .p-contact__form-value-area textarea {
  border-color: #B43838;
}
.formparts__alert ~ .p-contact__form-value-area input[type=text]:focus,
.formparts__alert ~ .p-contact__form-value-area input[type=email]:focus,
.formparts__alert ~ .p-contact__form-value-area input[type=tel]:focus,
.formparts__alert ~ .p-contact__form-value-area textarea:focus {
  outline: 3px solid rgba(180, 56, 56, 0.1);
  border-color: #B43838;
}

/* 全体にかかるエラーメッセージ */
.p-contact__form-error-message {
  display: none;
  color: #B43838;
  font-size: 0.6875rem;
  line-height: 1.2;
  text-align: center;
}

.mw_wp_form_input .is-for-confirm {
  display: none;
}
.mw_wp_form_input .p-contact__selection-group .p-contact__form-value-area {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
@media screen and (min-width: 1024px) {
  .mw_wp_form_input .p-contact__selection-group .p-contact__form-value-area {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
.mw_wp_form_input .p-contact__selection-group .p-contact__form-value-area + .mw_wp_form_input .p-contact__selection-group .p-contact__form-value-area {
  margin-top: 1.875rem;
  border-top: var(--border-gray-light);
  padding-top: 1.875rem;
}
.mw_wp_form_input:has(.formparts__alert) .p-contact__form-error-message {
  display: block;
  margin-bottom: 1.25rem;
}

.mw_wp_form_confirm .is-for-input {
  display: none;
}
.mw_wp_form_confirm .p-contact__form-row + .p-contact__form-row,
.mw_wp_form_confirm .p-contact__conditional-fields + .p-contact__form-row,
.mw_wp_form_confirm .p-contact__conditional-fields-inner .p-contact__form-row {
  margin-top: 1.875rem;
  border-top: var(--border-gray-light);
  padding-top: 1.875rem;
}
.mw_wp_form_confirm .p-contact__form-icon {
  display: none;
}
.mw_wp_form_confirm .p-contact__form-btn-area {
  padding-top: 5rem;
  gap: 1.875rem;
}

/*----------------------------------------------------
	p-service
----------------------------------------------------*/
.p-404 {
  padding-top: 5rem;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.p-404__content {
  padding-block: 6.25rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.p-404__title {
  font-family: "Inter", sans-serif;
  padding-bottom: 1.875rem;
}

.p-404__title-main {
  display: block;
  font-size: 2.9375rem;
  font-weight: 300;
  line-height: 120%;
  padding-bottom: 0.3125rem;
}
@media screen and (min-width: 1024px) {
  .p-404__title-main {
    font-size: 3.9375rem;
    font-weight: 200;
  }
}

.p-404__title-sub {
  display: block;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 120%;
}
@media screen and (min-width: 1024px) {
  .p-404__title-sub {
    font-size: 1.6875rem;
    font-weight: 300;
  }
}

.p-404__paragraph {
  padding-bottom: 5rem;
}

/*----------------------------------------------------
	cm-block
----------------------------------------------------*/
.cm-block-work {
  display: flex;
  flex-direction: column;
  gap: var(--padding-section);
}
.cm-block-work__head {
  display: flex;
  flex-direction: column;
  gap: var(--padding-block);
}
@media screen and (min-width: 1024px) {
  .cm-block-work__head {
    flex-direction: row;
    justify-content: space-between;
  }
}

.cm-block-work__body {
  display: flex;
  flex-direction: column;
  gap: var(--padding-block-sm);
}
@media screen and (min-width: 1024px) {
  .cm-block-work__body {
    width: 31rem;
    margin-inline: auto 5.5rem;
  }
}

.cm-block-work__gallery {
  display: grid;
  gap: 1.25rem;
}
.cm-block-work__gallery img {
  border-radius: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-work__gallery {
    grid-template-columns: 1fr 1fr;
    direction: rtl;
  }
}

.cm-block-work__txt {
  display: flex;
  flex-direction: column;
  gap: var(--padding-block-sm);
}
@media screen and (min-width: 1024px) {
  .cm-block-work__txt {
    width: 31rem;
    margin-inline: auto 5.5rem;
  }
}

.cm-block-work__picture img {
  border-radius: 0.625rem;
}
@media screen and (max-width: 1023px) {
  .cm-block-work__gallery + .cm-block-work__picture {
    margin-top: -2.5rem;
  }
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-block-services {
  display: flex;
  flex-direction: column;
  gap: 5rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-services {
    gap: 0;
  }
}

.cm-block-services-item {
  padding-top: 0.625rem;
  border-top: var(--border-inverse);
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item {
    padding-top: 2.5rem;
    padding-bottom: 3.75rem;
    overflow: hidden;
    display: grid;
    grid-template-areas: "no content pic";
    grid-template-columns: 21.5625rem 1fr 14.9375rem;
  }
  .cm-block-services-item:last-child {
    height: auto;
    cursor: inherit;
  }
}

.cm-block-services-item__no {
  color: var(--Light-Gray, #F4F1EE);
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 120%; /* 1.5rem */
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__no {
    grid-area: no;
  }
}

.cm-block-services-item__pic {
  margin-top: 1.25rem;
  width: 10.6875rem;
}
.cm-block-services-item__pic img {
  border-radius: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__pic {
    margin-top: 0;
    width: 14.9375rem;
    grid-area: pic;
    margin-left: auto;
  }
}

.cm-block-services-item__content {
  margin-top: 1.875rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__content {
    grid-area: content;
    margin-top: 0;
  }
}

.cm-block-services-item__en {
  display: inline-flex;
  gap: 1.25rem;
  font-family: "Inter", sans-serif;
  font-size: 1.6875rem;
  font-weight: 300;
  line-height: 120%; /* 32.0.25rem */
  letter-spacing: -0.03em;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__en {
    letter-spacing: 0;
  }
}

.cm-block-services-item__sub {
  padding-bottom: 0.8em;
  align-self: flex-end;
  color: var(--Light-Gray, #F4F1EE);
  font-family: "Inter", sans-serif;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 120%; /* 13.0.125rem */
  opacity: 0.5;
  white-space: nowrap;
}
.cm-block-services-item__sub._ja {
  font-family: "FOT-筑紫ゴシック Pr5 D", sans-serif;
  font-weight: 600;
  line-height: 120%; /* 13.0.125rem */
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__sub {
    padding-bottom: 1em;
  }
}

.cm-block-services-item__ja {
  margin-top: 0.3125rem;
  font-size: 0.6875rem;
  line-height: 120%; /* 13.0.125rem */
}

.cm-block-services-item__desc {
  margin-top: 1.875rem;
  opacity: 0.5;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__desc {
    width: 25.75rem;
  }
}

.cm-block-services-item__type {
  margin-top: 1.25rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-item__type {
    width: 25.75rem;
  }
}

.cm-block-services-item__more {
  margin-top: 3.75rem;
}

@media screen and (min-width: 1024px) {
  .cm-block-services--about .cm-block-services-item {
    padding-bottom: 5rem;
    padding-right: 10.8125rem;
    grid-template-areas: "no content desc";
    grid-template-columns: 10.8125rem 1fr 25.6875rem;
  }
}
@media screen and (min-width: 1024px) {
  .cm-block-services--about .cm-block-services-item__ja {
    margin-top: 0.625rem;
  }
}
@media screen and (min-width: 1024px) {
  .cm-block-services--about .cm-block-services-item__desc {
    margin-top: 0;
    grid-area: desc;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-block-services-list__pictures {
  display: none;
  position: fixed;
  top: 0;
  transition: opacity var(--animation-smooth);
  transition-duration: 0.75s;
  pointer-events: none;
  will-change: opacity;
  z-index: 1;
  width: 20.1875rem;
}
.cm-block-services-list__pictures img {
  position: absolute;
  top: 0;
  border-radius: 0.625rem;
  opacity: 0;
  transition: opacity var(--animation-smooth-faster);
  pointer-events: none;
  will-change: opacity;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list__pictures {
    display: block;
  }
}

@media screen and (min-width: 1024px) {
  .cm-block-services-list-item:hover:has(.cm-block-services-list-item__link:not(.is-current)) + .cm-block-services-list-item:not(:last-child) .cm-block-services-list-item__link {
    border-color: transparent;
  }
}

.cm-block-services-list-item__link {
  position: relative;
  display: flex;
  align-items: center;
  padding: 1.25rem 0;
  will-change: background;
  transition: var(--animation-primary);
  border-top: var(--border-inverse);
}
.cm-block-services-list-item:last-child .cm-block-services-list-item__link {
  border-bottom: var(--border-inverse);
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__link {
    padding: 0.75rem 0;
  }
}
@media (hover: none) {
  .cm-block-services-list-item__link:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .cm-block-services-list-item__link:hover, a:hover .cm-block-services-list-item__link {
    background: var(--Alceo-Green, #38B48B);
    border-color: transparent;
  }
  .cm-block-services-list-item__link:hover .cm-block-services-list-item__title, a:hover .cm-block-services-list-item__link .cm-block-services-list-item__title {
    opacity: 1;
    left: 3.125rem;
  }
  .cm-block-services-list-item__link:hover .cm-block-services-list-item__en, a:hover .cm-block-services-list-item__link .cm-block-services-list-item__en {
    left: 3.125rem;
    opacity: 0;
  }
  .cm-block-services-list-item__link:hover .cm-block-services-list-item__arrow1, a:hover .cm-block-services-list-item__link .cm-block-services-list-item__arrow1 {
    transform: translateX(3.375rem);
    opacity: 1;
    transition-delay: 0.075s;
  }
  .cm-block-services-list-item__link:hover .cm-block-services-list-item__pic, a:hover .cm-block-services-list-item__link .cm-block-services-list-item__pic {
    opacity: 1;
    transition-duration: 0.55s;
    z-index: 5;
  }
}
.cm-block-services-list-item__link.is-current {
  pointer-events: none;
  cursor: default;
}
.cm-block-services-list-item__link.is-current > div {
  opacity: 0.2;
}

.cm-block-services-list-item__head {
  position: relative;
  transition: var(--animation-primary);
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__head {
    flex: 1;
  }
}

.cm-block-services-list-item__en {
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 300;
  line-height: 120%; /* 1.5rem */
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__en {
    position: relative;
    left: 0;
    font-size: 2.25rem;
    will-change: left, opacity;
    transition: var(--animation-primary);
  }
}

.cm-block-services-list-item__title {
  font-size: 0.782rem;
  line-height: 180%; /* 22.32.625rem */
  letter-spacing: -0.02em;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__title {
    position: absolute;
    left: -1.9375rem;
    top: -0.2em;
    font-size: 1.875rem;
    color: var(--Dark-Green, #2B3D33);
    opacity: 0;
    will-change: left, opacity;
    transition: var(--animation-primary);
  }
}

.cm-block-services-list-item__pic {
  display: none;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__pic {
    display: block;
    width: 20.1875rem;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 0;
    transition: opacity var(--animation-smooth);
    transition-duration: 0.75s;
    pointer-events: none;
    will-change: opacity;
    z-index: 1;
  }
  .cm-block-services-list-item__pic img {
    border-radius: 0.625rem;
  }
}

.cm-block-services-list-item__arrow1,
.cm-block-services-list-item__arrow2 {
  position: absolute;
  width: 0.6875rem;
  line-height: 0;
  pointer-events: none;
  transition: var(--animation-primary);
}
.cm-block-services-list-item__arrow1 svg,
.cm-block-services-list-item__arrow2 svg {
  width: 100%;
  height: auto;
  stroke: var(--color);
}

.cm-block-services-list-item__arrow1 {
  left: -1.9375rem;
  opacity: 0;
}
.cm-block-services-list-item__arrow1 svg {
  stroke: var(--Dark-Green, #2B3D33);
}
@media screen and (max-width: 1023px) {
  .cm-block-services-list-item__arrow1 {
    display: none;
  }
}

.cm-block-services-list-item__arrow2 {
  right: 0;
}
@media screen and (min-width: 1024px) {
  .cm-block-services-list-item__arrow2 {
    display: none;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-block-solution {
  padding-top: 2.5rem;
  border-top: var(--border-gray);
}

.cm-block-solution__head {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.cm-block-solution__en {
  font-family: "Inter", sans-serif;
  font-size: 1.6875rem;
  font-weight: 300;
  line-height: 120%;
  letter-spacing: 0.03em;
}
.cm-block-solution__title {
  font-size: 0.9375rem;
  line-height: 180%;
  font-feature-settings: "palt";
}
.cm-block-solution__wrap {
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution__wrap {
    margin-top: 2.25rem;
    padding-right: 5.5rem;
    display: grid;
    grid-template-areas: "pic desc" "pic approach";
    grid-template-columns: 31.0625rem 1fr;
    gap: 6.25rem 12.125rem;
  }
}

.cm-block-solution__texts {
  display: flex;
  flex-direction: column;
  padding-top: 1.25rem;
}
.cm-block-solution__texts .cm-block-solution__desc {
  padding-bottom: 3.75rem;
}
.cm-block-solution__texts .cm-block-solution-approach {
  margin-top: auto;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution__texts {
    padding-top: 2.25rem;
  }
  .cm-block-solution__texts .cm-block-solution__desc {
    padding-bottom: 6.25rem;
  }
}

.cm-block-solution__pic img {
  border-radius: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution__pic {
    grid-area: pic;
  }
}

@media screen and (min-width: 1024px) {
  .cm-block-solution__desc {
    grid-area: desc;
  }
}

.cm-block-solution-approach {
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution-approach {
    grid-area: approach;
    margin-top: 0;
  }
}

.cm-block-solution-approach__list {
  padding-top: 1.875rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.625rem;
  border-top: var(--border-gray-light);
}
@media screen and (min-width: 1024px) {
  .cm-block-solution-approach__list {
    padding-top: 1.25rem;
  }
}

.cm-block-solution-approach__items {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}

.cm-block-solution-approach-item {
  position: relative;
  display: flex;
  padding-top: 0.75rem;
  border-top: var(--border-gray-light);
}
.cm-block-solution-approach-item__no {
  width: 2.9375rem;
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: -0.01em;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution-approach-item__no {
    width: 5.4375rem;
  }
}

.cm-block-solution-approach-item__body {
  width: 16.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
@media screen and (min-width: 1024px) {
  .cm-block-solution-approach-item__body {
    flex: 1;
    padding-right: 5rem;
  }
}

.cm-block-solution-approach-item__body dt {
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%;
  letter-spacing: -0.01em;
}

.cm-block-solution-approach-item__body dd {
  flex: 1;
}

.cm-block-solution-approach-item__title {
  position: absolute;
  right: 0;
  flex: 1;
  text-align: right;
  font-size: 0.9375rem;
  line-height: 180%;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	cm-main
----------------------------------------------------*/
.cm-main-links {
  padding: var(--padding-section) 0;
  background: var(--Green-Gray, #E1E4DD);
}
body:has(.p-about) .cm-main-links {
  background: transparent;
}

.cm-main-links__wrap {
  display: grid;
  gap: var(--padding-block-sm);
}
@media screen and (min-width: 1024px) {
  .cm-main-links__wrap {
    grid-template-columns: 10.75rem 25.75rem 1fr;
    gap: 0;
  }
}

@media screen and (min-width: 1024px) {
  .cm-main-links-head {
    margin-top: -0.3125rem;
  }
}

.cm-main-links-figure {
  width: 10.6875rem;
  position: relative;
}
.cm-main-links-figure img {
  border-radius: 0.625rem;
  width: 100%;
}
@media screen and (max-width: 1023px) {
  .cm-main-links-figure figure:nth-child(2) {
    display: none;
  }
}
@media screen and (min-width: 1024px) {
  .cm-main-links-figure {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 32.4375rem;
    border-radius: 0.625rem;
    overflow: hidden;
  }
  .cm-main-links-figure figure {
    width: 100%;
    position: absolute;
    transform: scale(1);
    transition: var(--animation-primary);
    transition-duration: 0.7s;
    opacity: 0;
    will-change: opacity, transform;
  }
  .cm-main-links-figure figure.is-current {
    transform: scale(1.02);
    transition-duration: 1.2s;
    opacity: 1;
  }
}

.cm-main-links-body {
  display: flex;
  flex-direction: column;
  gap: 5rem;
}
@media screen and (min-width: 1024px) {
  .cm-main-links-body {
    margin: -0.625rem 5.5rem 0 12rem;
    gap: 6.25rem;
  }
}

.cm-main-links-item__desc {
  margin-top: 1.25rem;
}
.cm-main-links-item__more {
  margin-top: 3.75rem;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	cm-modal
----------------------------------------------------*/
.cm-modal[aria-hidden=true] {
  pointer-events: none;
  display: none;
}
.loadedLower .cm-modal[aria-hidden=true] {
  display: block;
}

.cm-modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  height: 100vh;
  background: rgba(41, 41, 41, 0.97);
  z-index: 1000;
}

.cm-modal__wrap {
  overscroll-behavior: none;
}
.cm-modal__container {
  position: relative;
  height: 100vh;
  z-index: 20;
  overflow-y: auto;
}
/**************************\
  Demo Animation Style
\**************************/
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(0%);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0);
    opacity: 0;
  }
  to {
    transform: translateY(0%);
    opacity: 1;
  }
}
.cm-modal[aria-hidden=false] .cm-modal__overlay {
  opacity: 0;
  animation: mmfadeIn 0.3s 0.2s cubic-bezier(0, 0, 0.2, 1) forwards;
}

.cm-modal[aria-hidden=true] .cm-modal__overlay {
  animation: mmfadeOut 0.3s 0.2s cubic-bezier(0, 0, 0.2, 1) forwards;
}
.is-page-transition .cm-modal[aria-hidden=true] .cm-modal__overlay, .is-page-transition-once .cm-modal[aria-hidden=true] .cm-modal__overlay {
  animation-delay: 0s;
  animation-duration: 0s;
}

.cm-modal .cm-modal__container,
.cm-modal .cm-modal__overlay {
  will-change: transform;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-modal-team {
  padding: 2.5rem 1.25rem 0;
  background: #2B3D33;
  height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team {
    height: 100vh;
    padding: min(2.5rem, 0.2133333333 * 100vh) 2.5rem 0;
  }
}

.cm-modal-team__wrap {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__wrap {
    padding: 0 0 min(3.125rem, 0.0555555556 * 100vh);
    gap: min(12rem, 0.2133333333 * 100vh);
    flex-direction: row;
  }
}

.cm-modal-team__pic {
  border-radius: 0.625rem;
  width: 14.5625rem;
  overflow: hidden;
}
.cm-modal-team__pic img {
  margin-block: -2px;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__pic {
    width: min(36.5625rem, 0.6444444444 * 100vh);
  }
}

.cm-modal-team__content {
  position: relative;
}
@media screen and (max-width: 1023px) {
  .cm-modal-team__content:before, .cm-modal-team__content:after {
    content: "";
    display: block;
    width: 100%;
    height: 5.9375rem;
    position: absolute;
    left: 0;
    pointer-events: none;
    flex-shrink: 0;
    transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  }
  .cm-modal-team__content:before {
    top: 0;
    background: linear-gradient(0, rgba(43, 61, 51, 0) 0%, #2B3D33 100%);
  }
  .cm-modal-team__content:after {
    bottom: 0;
    background: linear-gradient(180deg, rgba(43, 61, 51, 0) 0%, #2B3D33 100%);
  }
  .cm-modal-team__content:has(.is-top):before {
    opacity: 0;
  }
  .cm-modal-team__content:has(.is-bottom):after {
    opacity: 0;
  }
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__content {
    flex: 1;
  }
}

.cm-modal-team__inner {
  display: flex;
  flex-direction: column;
  padding: 2.5rem 0 1.25rem;
}
@media screen and (max-width: 1023px) {
  .cm-modal-team__inner {
    height: calc(100dvh - 20.75rem - 4.875rem);
    overflow: auto;
  }
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__inner {
    padding: 3.75rem min(5.375rem, 0.0955555556 * 100vh) 0.125rem 0;
    height: 100%;
  }
}

.cm-modal-team__role {
  color: var(--Gray, #8F8F8F);
  font-family: "Inter", sans-serif;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 120%; /* 13.0.125rem */
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__role {
    font-size: 0.9375rem;
    font-weight: 400;
    line-height: 160%; /* 1.5rem */
    letter-spacing: -0.028125rem;
  }
}

.cm-modal-team__name {
  margin-top: 0.3125rem;
  font-family: "Inter", sans-serif;
  font-size: 1.6875rem;
  font-weight: 300;
  line-height: 120%; /* 32.0.25rem */
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__name {
    font-size: 2.25rem;
  }
}

.cm-modal-team__desc {
  margin-top: 1.875rem;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__desc {
    margin-top: 2.5rem;
  }
}

.cm-modal-team__info {
  margin-top: 2.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.cm-modal-team__info dt {
  color: var(--Gray, #8F8F8F);
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__info {
    margin-top: auto;
    padding-right: min(5.375rem, 0.0955555556 * 100vh);
  }
}

.cm-modal-team__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 4.875rem;
  border-top: var(--border-inverse);
  color: var(--Light-Gray, #F4F1EE);
}
.cm-modal-team__foot button {
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
@media screen and (min-width: 1024px) {
  .cm-modal-team__foot {
    height: 5.25rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	cm-nav
----------------------------------------------------*/
.cm-nav-main {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.375rem;
}
.cm-nav-main-link {
  position: relative;
  font-family: "Inter", sans-serif;
  font-size: 2.25rem;
  font-weight: 300;
  line-height: 120%; /* 43.0.125rem */
  letter-spacing: 0.01em;
}
.cm-nav-main-link:after {
  content: attr(data-text) "";
  position: absolute;
  left: 0;
  top: 0;
  transform-origin: 50% 50% 0.5em;
  backface-visibility: hidden;
  transform: rotate3d(1, 0, 0, 90deg);
  transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  opacity: 0;
  will-change: transform, opacity;
}
@media screen and (min-width: 1024px) {
  .cm-nav-main-link {
    letter-spacing: 0.01em;
  }
}

.cm-nav-main-link__txt {
  display: inline-block;
  transform-origin: 50% 50% 0.5em;
  backface-visibility: hidden;
  transform: rotate3d(1, 0, 0, 0);
  will-change: transform, opacity;
  transition: transform 0.3s cubic-bezier(0.5, 1, 0.89, 1), opacity 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-nav-group {
  display: flex;
  flex-direction: column;
  padding-bottom: 0.25rem;
}
.cm-nav-group a {
  color: var(--Light-Gray, #F4F1EE);
}
.cm-nav-group a:hover {
  --color: #38B48B;
}
@media screen and (min-width: 1024px) {
  .cm-nav-group {
    padding-bottom: 0.375rem;
  }
}

.cm-nav-bottom {
  margin-top: 2.125rem;
  padding-top: 1.875rem;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  border-top: var(--border-inverse);
}
@media screen and (min-width: 1024px) {
  .cm-nav-bottom {
    margin-top: 3.5rem;
    flex-direction: row-reverse;
  }
}

.cm-nav-bottom__link {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem 1.25rem;
}
.cm-nav-bottom__link a {
  color: var(--Light-Gray, #F4F1EE);
}
@media screen and (min-width: 1024px) {
  .cm-nav-bottom__link {
    gap: 0 3.125rem;
  }
}
.cm-nav-bottom__link li._ja {
  font-family: "FOT-筑紫ゴシック Pr5 D", sans-serif;
  font-weight: 600;
}

.cm-nav-bottom__copyright {
  color: var(--Gray, #8F8F8F);
  white-space: nowrap;
}
@media screen and (min-width: 1024px) {
  .cm-nav-bottom__copyright {
    color: var(--Light-Gray, #F4F1EE);
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-nav-header {
  position: relative;
}
.cm-nav-header__list {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.cm-nav-header__dot {
  display: block;
  width: 0.25rem;
  height: 0.25rem;
  position: absolute;
  bottom: -0.125rem;
  pointer-events: none;
  border-radius: 100%;
  background: var(--color-accent);
  transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
}

.cm-nav-header-link {
  position: relative;
  display: inline-block;
  padding: 0.625rem 0.625rem;
}
.cm-nav-header-link:before {
  content: "";
}
.cm-nav-header-link:hover {
  color: var(--color-accent);
}
.cm-nav-header-link.is-current:before {
  opacity: 1;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.cm-nav-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  font-family: "Inter", sans-serif;
  font-size: 0.6875rem;
  font-weight: 500;
  line-height: 160%; /* 17.0.375rem */
  letter-spacing: -0.020625rem;
}
.cm-nav-breadcrumb li:not(:first-child) {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.cm-nav-breadcrumb li:not(:first-child):before {
  content: "";
  display: block;
  width: 0.25rem;
  height: 0.25rem;
  position: absolute;
  left: -0.75rem;
  pointer-events: none;
  border-radius: 100%;
  background: var(--color-accent);
}
.cm-nav-breadcrumb a {
  color: var(--Gray, #8F8F8F);
}
.cm-nav-breadcrumb a:hover {
  color: var(--color);
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	cm-service
----------------------------------------------------*/
.cm-service-mv {
  padding-top: var(--padding-head);
  height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  background: var(--Dark-Green, #2B3D33);
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
@media screen and (max-width: 640px) {
  .cm-service-mv {
    padding-left: 5vw;
    padding-right: 5vw;
  }
}
@media screen and (min-width: 641px) and (max-width: 1023px) {
  .cm-service-mv {
    padding-left: 5.3333333333vw;
    padding-right: 5.3333333333vw;
  }
}
@media screen and (min-width: 1024px) {
  .cm-service-mv {
    padding-left: 2.7777777778vw;
    padding-right: 2.7777777778vw;
  }
}
.cm-service-mv__main {
  padding: 6.4vh 0 2.6666666667vh;
  position: relative;
}
.cm-service-mv__main .swiper {
  margin-inline: auto;
  display: flex;
  overflow: initial;
}
.cm-service-mv__main .swiper-wrapper.swiper-wrapper {
  transition-timing-function: cubic-bezier(0.62, 0.05, 0.01, 0.99);
}
@media screen and (min-width: 1024px) {
  .cm-service-mv__main {
    padding: 4vh 0 0;
  }
  .cm-service-mv__main .swiper {
    width: 103.3333333333vh;
  }
}

/*:::::::::::::::::::::::::::*/
.cm-service-mv-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4.375rem;
}
.swiper-slide:not(.swiper-slide-active) .cm-service-mv-item {
  opacity: 0.2;
}
@media screen and (min-width: 1024px) {
  .cm-service-mv-item {
    width: 103.3333333333vh;
    margin-inline: auto;
    gap: 4.6666666667vh;
  }
}

.cm-service-mv-item__pic {
  border-radius: 0.625rem;
  width: 28vh;
}
@media screen and (min-width: 1024px) {
  .cm-service-mv-item__pic {
    width: 36.1111111111vh;
  }
}

.cm-service-mv-item__head {
  display: flex;
  flex-direction: column;
  gap: 0.5333333333vh;
}
@media screen and (max-width: 1023px) {
  .cm-service-mv-item__head {
    width: 100%;
    gap: 0.4444444444vh;
  }
}

.cm-service-mv-item__en {
  font-family: "Inter", sans-serif;
  font-size: 3.6vh;
  font-weight: 200;
  line-height: 120%; /* 32.0.25rem */
}
@media screen and (min-width: 1024px) {
  .cm-service-mv-item__en {
    font-size: 7vh;
  }
}

.cm-service-mv-item__title {
  font-size: 1.4666666667vh;
  line-height: 120%; /* 13.0.125rem */
  font-feature-settings: "palt";
  transition: var(--animation-smooth-faster);
}
.swiper:not(.swiper-initialized) .cm-service-mv-item__title {
  opacity: 0;
}
@media screen and (min-width: 1024px) {
  .cm-service-mv-item__title {
    font-size: 1.6666666667vh;
  }
}

/*:::::::::::::::::::::::::::*/
.cm-service-mv__ctrl a,
.cm-service-mv__ctrl button {
  position: absolute;
  top: 10.25rem;
  z-index: 10;
}
.cm-service-mv__ctrl a:nth-child(1),
.cm-service-mv__ctrl button:nth-child(1) {
  left: 0;
}
.cm-service-mv__ctrl a:nth-child(2),
.cm-service-mv__ctrl button:nth-child(2) {
  right: 0;
}
.cm-service-mv__ctrl button.swiper-button-disabled {
  opacity: 0.3;
}
@media screen and (min-width: 1024px) {
  .cm-service-mv__ctrl a,
  .cm-service-mv__ctrl button {
    top: 25.3333333333vh;
  }
}

.cm-service-mv__foot {
  padding: 1.625rem 0 1.75rem;
  display: flex;
  justify-content: space-between;
  align-self: center;
  width: 100%;
  border-top: var(--border-inverse);
}
@media screen and (min-width: 1024px) {
  .cm-service-mv__foot {
    margin-top: auto;
    padding: 4.4444444444vh 0;
  }
}

.cm-service-mv__indicator {
  display: flex;
  align-items: center;
  gap: 1.9375rem;
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.01em;
}
.cm-service-mv__indicator span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cm-service-mv__indicator span:not(:first-child) {
  position: relative;
  opacity: 0.3;
}
.cm-service-mv__indicator span:not(:first-child):before {
  content: "";
  display: block;
  width: 0.625rem;
  height: 0;
  position: absolute;
  left: -1.25rem;
  pointer-events: none;
  border-top: var(--border-color);
  border-color: #F4F1EE;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	c-btn
----------------------------------------------------*/
.c-btn-arrow {
  display: inline-flex;
  align-items: center;
  width: 12.0625rem;
  padding: 0 0 0.875rem;
  position: relative;
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
.c-btn-arrow:after {
  content: "";
  display: block;
  width: 100%;
  height: 0;
  position: absolute;
  left: 0;
  bottom: 0;
  pointer-events: none;
  border-bottom: var(--border-accent);
}
@media (hover: none) {
  .c-btn-arrow:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-arrow:hover .c-btn-arrow__txt, a:hover .c-btn-arrow .c-btn-arrow__txt {
    padding-left: 1.9375rem;
  }
  .c-btn-arrow:hover .c-btn-arrow__arrow1, a:hover .c-btn-arrow .c-btn-arrow__arrow1 {
    transform: translateX(1.9375rem);
    opacity: 1;
    transition-delay: 0.05s;
  }
  .c-btn-arrow:hover .c-btn-arrow__arrow2, a:hover .c-btn-arrow .c-btn-arrow__arrow2 {
    transform: translateX(1.9375rem);
    opacity: 0;
  }
}
@media screen and (min-width: 1024px) {
  .c-btn-arrow {
    width: 15rem;
  }
}

.c-btn-arrow__txt {
  will-change: padding;
  transition: var(--animation-smooth);
}

.c-btn-arrow__arrow1,
.c-btn-arrow__arrow2 {
  position: absolute;
  width: 0.6875rem;
  line-height: 0;
  pointer-events: none;
  will-change: transform, opacity;
  transition: var(--animation-smooth);
}
.c-btn-arrow__arrow1 svg,
.c-btn-arrow__arrow2 svg {
  width: 100%;
  height: auto;
  stroke: var(--color);
}

.c-btn-arrow__arrow1 {
  left: -1.9375rem;
  opacity: 0;
}

.c-btn-arrow__arrow2 {
  right: 0;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-round {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  border: var(--border-color);
  border-color: var(--color);
  transition: var(--animation-fast);
  font-size: 0.6875rem;
  line-height: 1.2;
  padding: 0.75rem 2.5rem;
}
@media (hover: none) {
  .c-btn-round:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-round:hover:hover, a:hover .c-btn-round:hover {
    color: var(--color-inverse);
    background: var(--color);
  }
  .is-section-dark .c-btn-round:hover:hover, .is-section-dark a:hover .c-btn-round:hover {
    color: #0E1410;
  }
}

.c-btn-round__txt {
  position: relative;
}

.c-btn-round--contact {
  padding: 0.5rem 3rem;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-round2 {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 25rem;
  padding: 0.9375rem;
  border-radius: 9999px;
  transition: var(--animation-fast);
  color: var(--color-inverse);
  background-color: var(--Dark-Green, #2B3D33);
}
@media (hover: none) {
  .c-btn-round2:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-round2:hover, a:hover .c-btn-round2 {
    background-color: var(--color);
  }
}
@media screen and (max-width: 640px) {
  .c-btn-round2 {
    width: 100%;
  }
}

.c-btn-round2__txt {
  position: relative;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-menu {
  display: inline-flex;
  width: 4.6875rem;
  height: 1.75rem;
  padding: 0 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  border-radius: 5rem;
  border: var(--border-color);
}
.is-section-dark .c-btn-menu, .is-nav-open .c-btn-menu {
  color: var(--color-inverse);
  border-color: var(--color-inverse);
}

.c-btn-menu__txt {
  position: relative;
}
.is-nav-open .c-btn-menu__txt {
  opacity: 0;
}

.c-btn-menu__close {
  position: absolute;
  opacity: 0;
}
.is-nav-open .c-btn-menu__close {
  opacity: 1;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-circle-arrow {
  display: inline-flex;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  flex-shrink: 0;
  border-radius: 5rem;
  border: var(--border-color);
}
.is-section-dark .c-btn-circle-arrow {
  border: var(--border-inverse);
}
@media (hover: none) {
  .c-btn-circle-arrow:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-circle-arrow:hover .c-btn-circle-arrow__arrow1 svg, a:hover .c-btn-circle-arrow .c-btn-circle-arrow__arrow1 svg {
    left: 0;
    opacity: 1;
    transition-delay: 0.1s;
  }
  .c-btn-circle-arrow:hover .c-btn-circle-arrow__arrow2 svg, a:hover .c-btn-circle-arrow .c-btn-circle-arrow__arrow2 svg {
    left: 0.9375rem;
    opacity: 0;
  }
}
@media screen and (min-width: 1024px) {
  .c-btn-circle-arrow {
    width: 4.125rem;
    height: 4.125rem;
  }
}

.c-btn-circle-arrow--back .c-btn-circle-arrow__arrow1 svg {
  left: auto;
  right: -0.9375rem;
}
.c-btn-circle-arrow--back .c-btn-circle-arrow__arrow2 {
  position: absolute;
}
.c-btn-circle-arrow--back .c-btn-circle-arrow__arrow2 svg {
  left: auto;
  right: 0;
}
@media (hover: none) {
  .c-btn-circle-arrow--back:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-circle-arrow--back:hover .c-btn-circle-arrow__arrow1 svg, a:hover .c-btn-circle-arrow--back .c-btn-circle-arrow__arrow1 svg {
    left: auto;
    right: 0;
  }
  .c-btn-circle-arrow--back:hover .c-btn-circle-arrow__arrow2 svg, a:hover .c-btn-circle-arrow--back .c-btn-circle-arrow__arrow2 svg {
    left: auto;
    right: 0.9375rem;
  }
}

.c-btn-circle-arrow__arrow1,
.c-btn-circle-arrow__arrow2 {
  width: 0.625rem;
  line-height: 0;
}
.c-btn-circle-arrow__arrow1 svg,
.c-btn-circle-arrow__arrow2 svg {
  position: relative;
  width: 100%;
  height: auto;
  stroke: var(--color);
  will-change: transform, opacity;
  transition: var(--animation-smooth);
}

.c-btn-circle-arrow__arrow1 svg {
  left: -0.9375rem;
  opacity: 0;
}

.c-btn-circle-arrow__arrow2 {
  position: absolute;
}
.c-btn-circle-arrow__arrow2 svg {
  left: 0;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-ctrl {
  display: inline-flex;
  width: 3.0625rem;
  height: 1.75rem;
  padding: 0 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  flex-shrink: 0;
  border-radius: 5rem;
  border: var(--border-color);
}
@media (hover: none) {
  .c-btn-ctrl:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-ctrl:hover .c-btn-ctrl__arrow1 svg, a:hover .c-btn-ctrl .c-btn-ctrl__arrow1 svg {
    left: 0;
    opacity: 1;
    transition-delay: 0.1s;
  }
  .c-btn-ctrl:hover .c-btn-ctrl__arrow2 svg, a:hover .c-btn-ctrl .c-btn-ctrl__arrow2 svg {
    left: 0.9375rem;
    opacity: 0;
  }
}
@media screen and (min-width: 1024px) {
  .c-btn-ctrl {
    width: 4.625rem;
    height: 2.5rem;
  }
}

.c-btn-ctrl--back .c-btn-ctrl__arrow1 svg {
  left: auto;
  right: -0.9375rem;
}
.c-btn-ctrl--back .c-btn-ctrl__arrow2 {
  position: absolute;
}
.c-btn-ctrl--back .c-btn-ctrl__arrow2 svg {
  left: auto;
  right: 0;
}
@media (hover: none) {
  .c-btn-ctrl--back:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-ctrl--back:hover .c-btn-ctrl__arrow1 svg, a:hover .c-btn-ctrl--back .c-btn-ctrl__arrow1 svg {
    left: auto;
    right: 0;
  }
  .c-btn-ctrl--back:hover .c-btn-ctrl__arrow2 svg, a:hover .c-btn-ctrl--back .c-btn-ctrl__arrow2 svg {
    left: auto;
    right: 0.9375rem;
  }
}

.c-btn-ctrl__arrow1,
.c-btn-ctrl__arrow2 {
  width: 0.625rem;
  line-height: 0;
}
.c-btn-ctrl__arrow1 svg,
.c-btn-ctrl__arrow2 svg {
  position: relative;
  width: 100%;
  height: auto;
  stroke: var(--color);
  will-change: transform, opacity;
  transition: var(--animation-smooth);
}

.c-btn-ctrl__arrow1 svg {
  left: -0.9375rem;
  opacity: 0;
}

.c-btn-ctrl__arrow2 {
  position: absolute;
}
.c-btn-ctrl__arrow2 svg {
  left: 0;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-play {
  display: inline-flex;
  width: 4.6875rem;
  height: 1.75rem;
  padding: 0 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  border-radius: 5rem;
  background: var(--Light-Gray, #F4F1EE);
}
@media screen and (min-width: 1024px) {
  .c-btn-play {
    width: 5.625rem;
    height: 2.5rem;
  }
}

.c-btn-play__ico {
  position: relative;
  width: 0.625rem;
  line-height: 0;
}
.c-btn-play__ico svg:nth-child(2) {
  position: absolute;
  left: 0.125rem;
  opacity: 0;
}
.c-btn-play[aria-pressed=true] .c-btn-play__ico svg:nth-child(1) {
  opacity: 1;
}
.c-btn-play[aria-pressed=true] .c-btn-play__ico svg:nth-child(2) {
  opacity: 0;
}
.c-btn-play[aria-pressed=false] .c-btn-play__ico svg:nth-child(1) {
  opacity: 0;
}
.c-btn-play[aria-pressed=false] .c-btn-play__ico svg:nth-child(2) {
  opacity: 1;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-btn-square {
  display: inline-flex;
  padding: 0.375rem 0.625rem;
  justify-content: center;
  align-items: center;
  gap: 0.375rem;
  flex-shrink: 0;
  border-radius: 0.125rem;
  background: var(--White, #FFF);
  position: relative;
  font-family: "Inter", sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 160%; /* 19.0.125rem */
  letter-spacing: -0.0075rem;
}
@media (hover: none) {
  .c-btn-square:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-btn-square:hover .c-btn-square__txt, a:hover .c-btn-square .c-btn-square__txt {
    left: 0.9375rem;
  }
  .c-btn-square:hover .c-btn-square__arrow1, a:hover .c-btn-square .c-btn-square__arrow1 {
    opacity: 1;
    transform: translateX(0.9375rem);
  }
  .c-btn-square:hover .c-btn-square__arrow2, a:hover .c-btn-square .c-btn-square__arrow2 {
    transform: translateX(0.9375rem);
    opacity: 0;
  }
}

.c-btn-square--external .c-btn-square__arrow1 svg,
.c-btn-square--external .c-btn-square__arrow2 svg {
  transform: rotate(-45deg);
}

.c-btn-square__txt {
  position: relative;
  left: 0;
  will-change: left;
  transition: var(--animation-smooth);
}

.c-btn-square__arrow1,
.c-btn-square__arrow2 {
  width: 0.5rem;
  will-change: transform, opacity;
  transition: var(--animation-smooth);
  line-height: 0;
  pointer-events: none;
}
.c-btn-square__arrow1 svg,
.c-btn-square__arrow2 svg {
  width: 100%;
  height: auto;
  stroke: var(--color-accent);
}

.c-btn-square__arrow1 {
  position: absolute;
  left: -0.3125rem;
  opacity: 0;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	c-card
----------------------------------------------------*/
.c-card-work--col2 {
  grid-column: span 2;
}

.c-card-work__link {
  display: flex;
  flex-direction: column;
  gap: 1.375rem;
}

.c-card-work__pic {
  border-radius: 0.625rem;
  overflow: hidden;
  transition: var(--animation-smooth);
  will-change: transform;
  border-radius: 10px;
  background-color: #c4c4c4;
}
.c-card-work__pic img {
  transition: var(--animation-smooth);
  height: auto;
}
.c-card-work__meta {
  display: flex;
  align-items: center;
  gap: 0.8125rem;
  color: var(--Alceo-Green, #38B48B);
  font-size: 0.6875rem;
  line-height: 110%; /* 12.0.0625rem */
  letter-spacing: -0.006875rem;
}
@media screen and (min-width: 1024px) {
  .c-card-work__meta {
    gap: 1.25rem;
    font-size: 0.9375rem;
    line-height: 160%; /* 1.5rem */
    letter-spacing: -0.009375rem;
  }
}

.c-card-work__client {
  white-space: nowrap;
}

.c-card-work__service {
  position: relative;
  flex: 1;
}
.c-card-work__service:before {
  content: "";
  display: block;
  width: 0;
  top: calc(50% - 0.28125rem);
  height: 0.5625rem;
  position: absolute;
  left: -0.375rem;
  pointer-events: none;
  border-left: var(--border-accent);
}
@media screen and (min-width: 1024px) {
  .c-card-work__service:before {
    top: calc(50% - 0.34375rem);
    left: -0.625rem;
    height: 0.6875rem;
  }
}

.c-card-work-title {
  margin-top: 0.875rem;
  display: flex;
  align-items: center;
  position: relative;
  font-size: 0.9375rem;
  line-height: 120%; /* 1.125rem */
  letter-spacing: -0.028125rem;
}
@media screen and (min-width: 1024px) {
  .c-card-work-title {
    font-size: 1.25rem;
    letter-spacing: -0.0375rem;
  }
}

.c-card-work-title__arrow {
  position: absolute;
  left: -1.25rem;
  width: 0.6875rem;
  line-height: 0;
  pointer-events: none;
  transition: var(--animation-smooth);
  opacity: 0;
  will-change: transform, opacity;
}
.c-card-work-title__arrow svg {
  width: 100%;
  height: auto;
  stroke: var(--color);
}

.c-card-work-title__txt {
  transition: var(--animation-smooth);
  will-change: padding;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-card-service-other__link {
  padding: 1.25rem 0 0;
  border-top: var(--border-gray-light);
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
  position: relative;
}
@media screen and (min-width: 1024px) {
  .c-card-service-other__link:before {
    content: "";
    display: block;
    width: 0;
    height: 100%;
    position: absolute;
    right: 0;
    top: 0;
    pointer-events: none;
    border-top: var(--border-accent);
    transition: var(--animation-smooth);
    will-change: width, left;
  }
}

.c-card-service-other__head {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.3125rem;
  transition: var(--animation-smooth);
  will-change: padding;
}

.c-card-service-other__arrow1,
.c-card-service-other__arrow2 {
  position: absolute;
  top: 0.5625rem;
  width: 0.6875rem;
  line-height: 0;
  pointer-events: none;
  transition: var(--animation-smooth);
  will-change: transform, opacity;
}
.c-card-service-other__arrow1 svg,
.c-card-service-other__arrow2 svg {
  width: 100%;
  height: auto;
  stroke: var(--color);
}

.c-card-service-other__arrow1 {
  left: -1.9375rem;
  opacity: 0;
}
@media screen and (max-width: 1023px) {
  .c-card-service-other__arrow1 {
    display: none;
  }
}

.c-card-service-other__arrow2 {
  right: 0;
}
.c-card-service-other__arrow2 svg {
  stroke: var(--color-accent);
}
@media screen and (min-width: 1024px) {
  .c-card-service-other__arrow2 {
    display: none;
  }
}

.c-card-service-other__en {
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 120%;
  letter-spacing: -0.02em;
}

.c-card-service-other__ja {
  font-size: 0.6875rem;
  line-height: 120%;
}

.c-card-service-other__desc {
  opacity: 0.5;
}
@media screen and (min-width: 1024px) {
  .c-card-service-other__desc {
    width: 25.75rem;
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-card-team__link {
  display: flex;
  flex-direction: column;
  text-align: left;
  gap: 1.25rem;
}

.c-card-team__pic {
  border-radius: 0.625rem;
  overflow: hidden;
  transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  will-change: transform;
}
.c-card-team__pic img {
  transition: 0.3s cubic-bezier(0.5, 1, 0.89, 1);
  margin-block: -1px;
}
button:hover .c-card-team__pic {
  transform: scale(0.95);
}
button:hover .c-card-team__pic img {
  transform: scale(1.052);
}

.c-card-team__job {
  color: var(--Gray, #8F8F8F);
  /* EN/S */
  font-family: "Inter", sans-serif;
  font-size: 0.6875rem;
  font-weight: 400;
  line-height: 120%; /* 13.0.125rem */
}
@media screen and (min-width: 1024px) {
  .c-card-team__job {
    font-size: 0.9375rem;
    font-style: normal;
    line-height: 160%; /* 1.5rem */
    letter-spacing: -0.028125rem;
  }
}

.c-card-team__name {
  font-family: "Inter", sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 160%; /* 1.5rem */
  letter-spacing: -0.028125rem;
}
.c-card-team__job + .c-card-team__name {
  margin-top: -0.9375rem;
}
@media screen and (min-width: 1024px) {
  .c-card-team__name {
    font-size: 1.25rem;
    letter-spacing: -0.05rem;
  }
  .c-card-team__job + .c-card-team__name {
    margin-top: -1.25rem;
  }
}

.c-card-team__hidden-content {
  position: relative;
}

.c-card-team__hidden-desc,
.c-card-team__hidden-target,
.c-card-team__hidden-values,
.c-card-team__hidden-favorite {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  white-space: nowrap;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	c-heading
----------------------------------------------------*/
.c-heading-circle {
  position: relative;
  padding-left: 1.5rem;
  font-family: "Inter", sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 120%;
  letter-spacing: -0.05rem;
}
.c-heading-circle:before {
  content: "";
  display: block;
  width: 0.75rem;
  height: 0.75rem;
  position: absolute;
  left: 0;
  top: 0.28em;
  pointer-events: none;
  background: var(--Alceo-Green, #38B48B);
  border-radius: 100%;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-heading-accent {
  color: var(--color-accent);
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	c-link
----------------------------------------------------*/
.c-link-scroll {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 1.25rem;
  font-weight: 400;
}
@media (hover: none) {
  .c-link-scroll:active {
    transform: scale(0.965);
  }
}
@media (hover: hover) {
  .c-link-scroll:hover .c-link-scroll__arrow1, a:hover .c-link-scroll .c-link-scroll__arrow1 {
    transform: translateY(0);
    opacity: 1;
    transition-delay: 0.175s;
  }
  .c-link-scroll:hover .c-link-scroll__arrow2, a:hover .c-link-scroll .c-link-scroll__arrow2 {
    transform: translateY(1rem);
    opacity: 0;
  }
}
@media screen and (min-width: 1024px) {
  .c-link-scroll {
    gap: 2.1875rem;
  }
}

.c-link-scroll__txt {
  position: relative;
  will-change: left;
  left: 0;
  transition: var(--animation-smooth);
}

.c-link-scroll__arrow1,
.c-link-scroll__arrow2 {
  will-change: transform, opacity;
  transition: var(--animation-smooth);
  line-height: 0;
  pointer-events: none;
}
.c-link-scroll__arrow1 i,
.c-link-scroll__arrow2 i {
  width: 0.625rem;
  line-height: 0;
}
.c-link-scroll__arrow1 svg,
.c-link-scroll__arrow2 svg {
  stroke: var(--color);
}

.c-link-scroll__arrow1 {
  position: absolute;
  opacity: 0;
}
@media screen and (min-width: 1024px) {
  .c-link-scroll__arrow1 {
    right: 0;
    transform: translateY(-1rem);
  }
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-link-external {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 0.3125rem;
}
.c-link-external i {
  width: 0.5rem;
  line-height: 0;
}
.c-link-external i svg {
  width: 100%;
  height: auto;
  stroke: var(--color);
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	...
----------------------------------------------------*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	c-paragraph
----------------------------------------------------*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-paragraph-lg {
  font-size: 1.25rem;
  line-height: 160%; /* 2rem */
  letter-spacing: 0.05em;
}
@media screen and (min-width: 1024px) {
  .c-paragraph-lg {
    font-size: 1.6875rem;
    letter-spacing: 0.05em;
  }
}

.c-paragraph-lg--about {
  font-feature-settings: "palt" on;
}

.c-paragraph-lg--team {
  letter-spacing: -0.035em;
}
.c-paragraph-lg--team span {
  letter-spacing: -0.13em;
}
.c-paragraph-lg--team ._f {
  letter-spacing: -0.13em;
}
.c-paragraph-lg--team ._s {
  letter-spacing: -0.08em;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*----------------------------------------------------
	汎用クラス
----------------------------------------------------*/
.bold,
.strong {
  font-weight: bold;
}

.u-bold {
  font-weight: bold;
  font-family: "FOT-筑紫ゴシック Pro B", sans-serif;
}

.u-hide {
  display: none;
}

.u-breakLine {
  display: inline-block;
}

.u-center {
  text-align: center;
}

.jsLazyLoad {
  opacity: 0;
}
.jsLazyLoad.loaded {
  opacity: 1;
}

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

.u-only-pc {
  display: none !important;
}
@media screen and (min-width: 641px) {
  .u-only-pc {
    display: block !important;
  }
}

.u-color-accent {
  color: var(--color-accent);
}

.u-template {
  display: flex;
  flex-direction: column;
  gap: 5rem;
  padding-bottom: 6.25rem;
}
.u-template > div {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.u-gap {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--gap);
}

.is-disabled {
  opacity: 0.7;
  pointer-events: none;
}

.u-budoux {
  word-break: keep-all;
  overflow-wrap: anywhere;
}

.mt-gap {
  margin-top: var(--gap);
}

.mt-block-sm {
  margin-top: var(--padding-block-sm);
}

.mt-block {
  margin-top: var(--padding-block);
}

.mt-section {
  margin-top: var(--padding-section);
}

.mt-section-md {
  margin-top: var(--padding-section-md);
}

/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
[data-delay="0.1"] {
  transition-delay: 0.1s;
}

[data-delay="0.2"] {
  transition-delay: 0.2s;
}

[data-delay="0.3"] {
  transition-delay: 0.3s;
}

[data-delay="0.4"] {
  transition-delay: 0.4s;
}

[data-delay="0.5"] {
  transition-delay: 0.5s;
}

[data-delay="0.6"] {
  transition-delay: 0.6s;
}

[data-delay="0.7"] {
  transition-delay: 0.7s;
}

[data-delay="0.8"] {
  transition-delay: 0.8s;
}

[data-delay="0.9"] {
  transition-delay: 0.9s;
}

[data-delay="1"] {
  transition-delay: 1s;
}

[data-delay="1.1"] {
  transition-delay: 1.1s;
}

[data-delay="1.2"] {
  transition-delay: 1.2s;
}

[data-delay="1.3"] {
  transition-delay: 1.3s;
}

[data-delay="1.4"] {
  transition-delay: 1.4s;
}

[data-delay="1.5"] {
  transition-delay: 1.5s;
}

[data-delay="1.6"] {
  transition-delay: 1.6s;
}

[data-delay="1.7"] {
  transition-delay: 1.7s;
}

[data-delay="1.8"] {
  transition-delay: 1.8s;
}

[data-delay="1.9"] {
  transition-delay: 1.9s;
}

[data-delay="2"] {
  transition-delay: 2s;
}

[data-delay="2.1"] {
  transition-delay: 2.1s;
}

[data-delay="2.2"] {
  transition-delay: 2.2s;
}

[data-delay="2.3"] {
  transition-delay: 2.3s;
}

[data-delay="2.4"] {
  transition-delay: 2.4s;
}

[data-delay="2.5"] {
  transition-delay: 2.5s;
}

[data-delay="2.6"] {
  transition-delay: 2.6s;
}

[data-delay="2.7"] {
  transition-delay: 2.7s;
}

[data-delay="2.8"] {
  transition-delay: 2.8s;
}

[data-delay="2.9"] {
  transition-delay: 2.9s;
}

[data-delay="3"] {
  transition-delay: 3s;
}

.__loop {
  animation: loopLeft linear 30s infinite;
  will-change: transform;
  display: flex;
}
.__loop img {
  width: auto;
  max-width: none;
  height: 18.75rem;
}
@media screen and (min-width: 1024px) {
  .__loop {
    animation: loopLeft linear 50s infinite;
  }
  .__loop img {
    height: 32.875rem;
  }
}

@keyframes loopLeft {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    transform: translate3d(-100%, 0, 0);
  }
}
@keyframes loopRight {
  from {
    transform: translate3d(-100%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
/*::::::::::::::::::::::::::::::::::::::::::::::::::*/
