@charset "UTF-8";
/* # CSS変数 / CSS Variables
------------------------------------------------ */
:root {
  /* ## 色 / Colors
  ------------------------------------------------ */
  /* basic-colors */
  --color-background-base: #fffbf5;
  --color-text-base: #3c3829;
  /* color-primary */
  --color-primary-50: #fffbf5;
  --color-primary-100: #fff6f0;
  --color-primary-200: #fbece2;
  --color-primary-300: #f5dece;
  --color-primary-400: #e5cebe;
  --color-primary-500: #d9b8a1;
  --color-primary-600: #c39c80;
  --color-primary-700: #a48066;
  --color-primary-800: #946f54;
  --color-primary-900: #664c39;
  --color-primary-950: #4b3220;
  /* color-accent */
  --color-accent-50: #eff0f8;
  --color-accent-100: #d9dbef;
  --color-accent-200: #b7bbe1;
  --color-accent-300: #98a0d5;
  --color-accent-400: #7c86c9;
  --color-accent-500: #616ebc;
  --color-accent-600: #4b59a4;
  --color-accent-700: #3b4683;
  --color-accent-800: #2b3463;
  --color-accent-900: #171c3b;
  --color-accent-950: #000c46;
  /* color-gray */
  --color-gray-50: #f1f1f1;
  --color-gray-100: #dcdcdc;
  --color-gray-200: #bcbcbc;
  --color-gray-300: #a0a0a0;
  --color-gray-400: #878787;
  --color-gray-500: #707070;
  --color-gray-600: #5a5a5a;
  --color-gray-700: #464646;
  --color-gray-800: #333333;
  --color-gray-900: #1e1e1e;
  --color-gray-950: #111111;
  /* ## サイズ / Size
  ------------------------------------------------ */
  /* min:8px, max:10px */
  --size-small-30: clamp(0.5rem, 0.403rem + 0.278vw, 0.625rem);
  /* min:10px, max:12px */
  --size-small-20: clamp(0.63rem, -0.625rem + 1.833vw, 0.75rem);
  /* min:12px, max:14px */
  --size-small-10: clamp(0.75rem, 0.625rem + 0.333vw, 0.875rem);
  /* min:14px, max:16px */
  --size-regular: clamp(0.875rem, 0.75rem + 0.333vw, 1rem);
  /* min:16px, max:18px */
  --size-large-10: clamp(1rem, 0.875rem + 0.333vw, 1.125rem);
  /* min:18px, max:22px */
  --size-large-20: clamp(1.125rem, 0.875rem + 0.667vw, 1.375rem);
  /* min:22px, max:28px */
  --size-large-30: clamp(1.375rem, 1rem + 1vw, 1.75rem);
  /* min:28px, max:36px */
  --size-large-40: clamp(1.75rem, 1.25rem + 1.333vw, 2.25rem);
  /* min:34px, max:42px */
  --size-large-45: clamp(2.125rem, 1.929rem + 0.87vw, 2.625rem);
  /* min:36px, max:48px */
  --size-large-50: clamp(2.25rem, 1.5rem + 2vw, 3rem);
  /* min:40px, max:56px */
  --size-large-55: clamp(2.5rem, calc(1.528rem + 2.778vw), 3.75rem);
  /* min:48px, max:64px */
  --size-large-60: clamp(3rem, 2rem + 2.667vw, 4rem);
  /* min:64px, max:80px */
  --size-large-70: clamp(2.875rem, 0.75rem + 5.667vw, 5rem);
  /* min:80px, max:100px */
  --size-large-80: clamp(5rem, 3.75rem + 3.333vw, 6.25rem);
  /* min:100px, max:128px */
  --size-large-90: clamp(6.25rem, 4.5rem + 4.667vw, 8rem);
  /* ## スペース / Space
  ------------------------------------------------ */
  /* min:4px, max:6px */
  --space-small-20: clamp(0.25rem, 0.125rem + 0.333vw, 0.375rem);
  /* min:8px, max:12px */
  --space-small-10: clamp(0.5rem, 0.25rem + 0.667vw, 0.75rem);
  /* min:12px, max:16px */
  --space-regular: clamp(0.75rem, 0.5rem + 0.667vw, 1rem);
  /* min:16px, max:24px */
  --space-large-10: clamp(1rem, 0.5rem + 1.333vw, 1.5rem);
  /* min:24px, max:32px */
  --space-large-20: clamp(1.5rem, 1rem + 1.333vw, 2rem);
  /* min:32px, max:48px */
  --space-large-30: clamp(2rem, 1rem + 2.667vw, 3rem);
  /* min:48px, max:64px */
  --space-large-40: clamp(3rem, 2rem + 2.667vw, 4rem);
  /* min:56px, max:80px */
  --space-large-45: clamp(3.5rem, 2.913rem + 2.609vw, 5rem);
  /* min:64px, max:96px */
  --space-large-50: clamp(4rem, 2rem + 5.333vw, 6rem);
  /* min:96px, max:128px */
  --space-large-60: clamp(6rem, 4rem + 5.333vw, 8rem);
  /* min:128px, max:192px */
  --space-large-70: clamp(8rem, 4rem + 10.667vw, 12rem);
  /* min:192px, max:256px */
  --space-large-80: clamp(12rem, 8rem + 10.667vw, 16rem);
  /* min:256px, max:320px */
  --space-large-90: clamp(16rem, 12rem + 10.667vw, 20rem);
  /* min:320px, max:384px */
  --space-large-100: clamp(20rem, 16rem + 10.667vw, 24rem);
  /* ## シャドウ / Shadow
  -----------------------
  ------------------------- */
  --text-shadow-bk: 0 0 2px rgba(0, 0, 0, 0.2);
  --text-shadow-wh: 0 0 2px rgba(255, 255, 255, 0.2);
  --box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px,
    rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  /* ## オーバーレイ / Overlay
  ------------------------------------------------ */
  --overlay-1: rgba(0, 0, 0, 0.2);
  --overlay-2: rgba(0, 0, 0, 0.3);
  --overlay-3: linear-gradient(135deg, color-mix(in srgb, oklch(69.308% 0.17696 52.518) 30%, transparent) 0%, color-mix(in srgb, oklch(74.921% 0.12966 175.695) 30%, transparent) 100%);
}

/* # ベース / Base
------------------------------------------------ */
/* ## 共通 / Common
------------------------------------------------ */
* {
  letter-spacing: 0.05em;
}

body {
  overflow-x: clip;
  color: var(--color-text-base);
  background: url("https://platinum-site.com/oshokujidokoro-an/wp-content/uploads/bg-main.jpg") repeat center/100%;
  font-family: var(--font-family-ja);
}

body .post_content p {
  line-height: 2.4;
  font-size: var(--size-regular);
}

img {
  max-width: 100%;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
}

/* # レイアウト / Layout
------------------------------------------------ */
/* ## 共通 / Common
------------------------------------------------ */
/* ### コンテナ / Container */
.l-container {
  margin-inline: auto;
}
.l-container--xs {
  width: min(90%, 600px);
}
.l-container--sm {
  width: min(90%, 800px);
}
.l-container--md {
  width: min(95%, 1000px);
}
.l-container--lg {
  width: min(95%, 1180px);
}
.l-container--xl {
  width: min(95%, 1400px);
}

/* ### セクション / Section */
.l-section--spacing-sm {
  padding-block: var(--space-large-20);
}
.l-section--spacing-md {
  padding-block: var(--space-large-30);
}
.l-section--spacing-lg {
  padding-block: var(--space-large-40);
}

/* ## 下層ページ / Sub Page
------------------------------------------------ */
.pc #one_col {
  width: min(90%, 1200px);
  margin-block: var(--space-large-60);
}

/* # コンポーネント / Component
----------------------------------------------- */
.c-basic-text {
  margin-bottom: 0;
  line-height: 2.4;
  font-size: var(--size-regular);
}

.c-ttl-1 {
  container: c-ttl-1/inline-size;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-small-20) var(--space-small-20);
  margin-bottom: var(--space-large-30);
}
.c-ttl-1 .c-ttl-1__main {
  display: flex;
  width: 100%;
  margin-bottom: 0 !important;
  line-height: 1.5;
  letter-spacing: 0.075em;
  font-weight: bold;
  font-size: var(--size-large-40);
  justify-content: center;
}
@container (width < 600px) {
  .c-ttl-1 .c-ttl-1__main {
    font-size: var(--size-large-30);
  }
}
.c-ttl-1 .c-ttl-1__deco {
  order: 3;
  flex-shrink: 0;
  width: var(--size-small-20);
  aspect-ratio: 1;
  background: var(--color-primary-700);
  border-radius: 50%;
}
.c-ttl-1::before, .c-ttl-1::after {
  content: "";
  flex-shrink: 0;
  width: var(--size-small-30);
  aspect-ratio: 1;
  background: var(--color-primary-500);
  border-radius: 50%;
}
.c-ttl-1::before {
  order: 2;
}
.c-ttl-1::after {
  order: 4;
}
.c-ttl-1--color-white .c-ttl-1__main {
  color: #fff;
}

.c-ttl-2 {
  display: flex;
  align-items: center;
  gap: var(--space-small-10);
  margin-bottom: var(--space-large-30);
}
.c-ttl-2::before, .c-ttl-2::after {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-primary-700);
  flex-shrink: 0;
}
.c-ttl-2 .c-ttl-2__main {
  flex: 1;
  display: flex;
  align-items: center;
  gap: calc(var(--space-small-10) + 8px);
  font-family: var(--font-family-ja);
  font-size: var(--size-large-20);
  font-weight: 700;
  color: var(--color-text-base);
  letter-spacing: 0.2em;
  white-space: nowrap;
  margin: unset;
}
.c-ttl-2 .c-ttl-2__main::before, .c-ttl-2 .c-ttl-2__main::after {
  content: "";
  flex: 1;
  height: 1px;
  background: var(--color-primary-500);
  opacity: 0.35;
}

.c-ttl-3 {
  container: c-ttl-1/inline-size;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-small-20);
  margin-bottom: var(--space-large-40);
}
.c-ttl-3 .c-ttl-3__main {
  margin-bottom: 0 !important;
  line-height: 1.4;
  letter-spacing: 0.075em;
  font-weight: bold;
  font-size: var(--size-large-40);
  color: var(--text-base);
}
@container (width < 600px) {
  .c-ttl-3 .c-ttl-3__main {
    font-size: var(--size-large-40);
  }
}
.c-ttl-3 .c-ttl-3__sub {
  margin: 0 !important;
  line-height: 1.4;
  color: var(--color-primary-600);
  font-size: var(--size-small-10);
}
.c-ttl-3::before {
  content: "";
  width: var(--size-large-40);
  aspect-ratio: 1;
  background-color: var(--color-secondary-700);
  mask: url("../images/common/title_deco.svg") center/contain no-repeat;
  -webkit-mask: url("../images/common/title_deco.svg") center/contain no-repeat;
}
.c-ttl-3--color-white .c-ttl-3__main,
.c-ttl-3--color-white .c-ttl-3__sub {
  color: var(--color-background-base);
}

.c-catchphrase-1 {
  margin-bottom: unset !important;
}
.c-catchphrase-1 .c-catchphrase-1__inner {
  line-height: 2;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding-bottom: var(--space-small-20);
  box-sizing: border-box;
  background-image: repeating-linear-gradient(90deg, #d9b8a1, #d9b8a1 3px, transparent 3px, transparent 6px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 1px;
  font-weight: bold;
  letter-spacing: 0.1em;
  font-size: var(--size-large-30);
  color: var(--color-primary-900);
}

.c-catchphrase-2 {
  margin-bottom: var(--space-large-10);
}
.c-catchphrase-2 .c-catchphrase-2__inner {
  line-height: 1.7;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  padding: 0.5em 0.4em;
  line-height: 2.8;
  background-image: radial-gradient(circle, var(--color-primary-600) 2px, transparent 2px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 14px 4px;
  font-weight: bold;
  letter-spacing: 0.1em;
  font-size: var(--size-large-20);
  color: var(--color-primary-900);
}

.c-btn-1 {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-small-10);
}
.c-btn-1--center {
  justify-content: center;
}
.c-btn-1 .c-btn-1__link {
  position: relative;
  border-radius: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(100%, 240px);
  height: 60px;
  padding: var(--space-small-20) var(--space-regular);
  box-sizing: border-box;
  background-color: var(--color-accent-800);
  color: #fff;
  font-size: var(--size-regular);
  transition: 0.3s;
}
.c-btn-1 .c-btn-1__link::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 30px;
}
.c-btn-1 .c-btn-1__link:hover {
  text-decoration: none;
  background-color: var(--color-accent-700);
  color: #fff;
}

.c-btn-2 {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-small-10);
}
.c-btn-2--center {
  justify-content: center;
}
.c-btn-2 .c-btn-2__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-small-10);
  height: 60px;
  padding: var(--space-small-20) var(--space-large-10);
  box-sizing: border-box;
  background-color: var(--color-primary-900);
  color: #fff;
  font-size: var(--size-regular);
  transition: 0.3s;
}
.c-btn-2 .c-btn-2__link::after {
  content: "";
  flex: 0 0 1em;
  aspect-ratio: 1;
  background: currentColor;
  opacity: 0.8;
  mask: center/contain no-repeat;
  -webkit-mask: center/contain no-repeat;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='140 0 180 315'%3E%3Cpolygon points='163.916,0 142.084,21.822 276.258,155.996 142.084,290.178 163.916,312 184.916,291.178 318.916,157.178 185.916,24.178'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='140 0 180 315'%3E%3Cpolygon points='163.916,0 142.084,21.822 276.258,155.996 142.084,290.178 163.916,312 184.916,291.178 318.916,157.178 185.916,24.178'/%3E%3C/svg%3E");
}
.c-btn-2 .c-btn-2__link:hover {
  background-color: var(--color-primary-800);
  color: var(--color-background-base);
}

.c-ul-1 {
  display: flex;
  flex-direction: column;
  gap: var(--space-small-10);
  margin: 0 !important;
  padding: 0 !important;
}
.c-ul-1 li {
  display: flex;
  align-items: flex-start;
  gap: 0.8em;
  list-style: none;
  line-height: 1.8;
  font-size: var(--size-regular);
}
.c-ul-1 li::before {
  content: "";
  flex-shrink: 0;
  translate: 0 -50%;
  width: 7px;
  aspect-ratio: 1;
  margin-top: 0.5lh;
  border-radius: 50%;
  background-color: var(--color-primary-700);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-primary-700) 30%, transparent);
}
.c-ul-1--center {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto !important;
}

.c-ul-2 {
  container: c-ul-2/inline-size;
  display: flex;
  flex-direction: column;
  gap: var(--space-small-20);
  margin: 0 !important;
  padding: 0;
}
.c-ul-2 li {
  display: flex;
  align-items: flex-start;
  gap: 0.8em;
  list-style: none;
  line-height: 2.4;
  font-size: var(--size-regular);
}
@container (width < 400px) {
  .c-ul-2 li {
    font-size: var(--size-small-10);
  }
}
.c-ul-2 li::before {
  content: "";
  flex-shrink: 0;
  translate: 0 -50%;
  width: 1.1em;
  aspect-ratio: 1;
  margin-top: 0.5lh;
  -webkit-mask: url("../images/common/title_deco.svg") no-repeat center/contain;
          mask: url("../images/common/title_deco.svg") no-repeat center/contain;
  background-color: var(--color-primary-600);
}
.c-ul-2--center {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto !important;
}

.c-ol-1 {
  container: c-ol-1/inline-size;
  display: flex;
  flex-direction: column;
  gap: var(--space-small-20);
  margin: 0 !important;
  padding: 0 !important;
  counter-reset: num;
}
.c-ol-1 li {
  display: flex;
  align-items: flex-start;
  gap: 0.8em;
  list-style: none;
  line-height: 2.4;
  font-size: var(--size-regular);
  counter-increment: num;
}
.c-ol-1 li::before {
  content: counter(num);
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: var(--size-large-40);
  height: var(--size-large-40);
  margin-top: 0.5lh;
  translate: 0 -50%;
  border-radius: 50%;
  background-color: var(--color-primary-800);
  letter-spacing: 0;
  font-size: var(--size-regular);
  color: var(--color-background-base);
}
@container (width < 600px) {
  .c-ol-1 li::before {
    width: 32px;
    height: 32px;
  }
}
.c-ol-1--center {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto !important;
}

.c-box {
  container: c-box/inline-size;
  background-color: var(--color-gray-50);
  border-radius: 20px;
}
.c-box .c-box__inner {
  padding: var(--space-large-20);
}

.c-inpage-nav {
  container: c-inpage-nav/inline-size;
  margin-bottom: var(--space-large-20);
}
.c-inpage-nav .c-inpage-nav__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
  gap: var(--space-large-10);
  margin: 0 !important;
  padding: 0 !important;
}
@container (width < 600px) {
  .c-inpage-nav .c-inpage-nav__list {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-small-10);
  }
}
.c-inpage-nav .c-inpage-nav__item {
  list-style: none;
}
.c-inpage-nav .c-inpage-nav__link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-small-10);
  height: 60px;
  padding: var(--space-small-20) var(--space-large-10);
  box-sizing: border-box;
  background-color: var(--color-primary-900);
  color: #fff;
  font-size: var(--size-regular);
  transition: 0.3s;
}
@container (width < 600px) {
  .c-inpage-nav .c-inpage-nav__link {
    gap: var(--space-small-20);
    padding: var(--space-small-20) var(--space-regular);
  }
}
.c-inpage-nav .c-inpage-nav__link::after {
  content: "";
  flex: 0 0 1em;
  aspect-ratio: 1;
  background: currentColor;
  opacity: 0.8;
  mask: center/contain no-repeat;
  -webkit-mask: center/contain no-repeat;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 140 315 180'%3E%3Cpolygon points='0,163.916 21.822,142.084 155.996,276.258 290.178,142.084 312,163.916 291.178,184.916 157.178,318.916 24.178,185.916'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 140 315 180'%3E%3Cpolygon points='0,163.916 21.822,142.084 155.996,276.258 290.178,142.084 312,163.916 291.178,184.916 157.178,318.916 24.178,185.916'/%3E%3C/svg%3E");
}
.c-inpage-nav .c-inpage-nav__link:hover {
  background-color: var(--color-primary-800);
  color: var(--color-background-base);
}

.c-page-intro .c-page-intro__heading {
  margin-bottom: var(--space-large-20);
  text-align: center;
  color: var(--color-primary-900);
  font-weight: bold;
  font-size: var(--size-large-30);
}
.c-page-intro .c-page-intro__txt {
  margin-bottom: var(--space-large-20);
  line-height: 2.4;
  text-align: center;
  font-size: var(--size-regular);
}
.c-page-intro .c-page-intro__img {
  width: min(100%, 600px);
  margin: 0 auto;
}
.c-page-intro .c-page-intro__img img {
  width: 100%;
  filter: grayscale(0.3);
}

.c-2col-contents {
  container: c-2col-contents/inline-size;
}
.c-2col-contents:not(:last-child) {
  margin-bottom: var(--space-large-60);
}
.c-2col-contents .c-2col-contents__inner {
  display: flex;
  gap: var(--space-large-10) var(--space-large-20);
}
@container (width >=800px) {
  .c-2col-contents .c-2col-contents__inner {
    justify-content: center;
  }
}
@container (width < 800px) {
  .c-2col-contents .c-2col-contents__inner {
    flex-direction: column;
  }
}
@container (width >=800px) {
  .c-2col-contents .c-2col-contents__col1 {
    width: 38.2%;
  }
}
@container (width >=800px) {
  .c-2col-contents .c-2col-contents__col2 {
    width: 61.8%;
  }
}
.c-2col-contents .c-2col-contents__img img {
  width: 100%;
}
.c-2col-contents .c-2col-contents__caption {
  margin-top: 0.75em;
  line-height: 2.4;
  font-size: var(--size-regular);
}
@container (width >=800px) {
  .c-2col-contents--reverse .c-2col-contents__inner {
    flex-direction: row-reverse;
  }
}
@container (width >=800px) {
  .c-2col-contents--same .c-2col-contents__col1 {
    width: 50%;
  }
}
@container (width >=800px) {
  .c-2col-contents--same .c-2col-contents__col2 {
    width: 50%;
  }
}

.c-simple-message .c-simple-message__catch {
  line-height: 2;
  text-align: center;
  font-size: var(--size-large-40);
}
.c-simple-message .c-simple-message__txt {
  margin-top: var(--space-large-20);
  line-height: 2.4;
  text-align: center;
  font-size: var(--size-large-10);
}

.c-card-contents {
  container: c-card-contents/inline-size;
}
.c-card-contents .c-card-contents__inner {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--space-large-30);
}
.c-card-contents .c-card-contents__item {
  background: var(--color-background-base);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.c-card-contents .c-card-contents__image {
  width: 100%;
  aspect-ratio: 1.618;
  -o-object-fit: cover;
     object-fit: cover;
  background: #e0e0e0;
  display: block;
}
.c-card-contents .c-card-contents__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-card-contents .c-card-contents__info {
  padding: var(--space-large-20);
}
.c-card-contents .c-card-contents__title {
  font-size: var(--size-large-20);
  font-weight: bold;
  color: var(--color-primary-900);
  margin: 0 0 0.5em;
}
.c-card-contents .c-card-contents__caption {
  font-size: var(--size-regular);
  line-height: 2.4;
}

.c-card-contents-2 {
  container: c-card-contents-2/inline-size;
}
.c-card-contents-2 .c-card-contents-2__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-large-50);
}
.c-card-contents-2 .c-card-contents-2__unit {
  display: flex;
  background-color: var(--color-background-base);
}
@container (width < 750px) {
  .c-card-contents-2 .c-card-contents-2__unit {
    flex-direction: column;
  }
}
.c-card-contents-2 .c-card-contents-2__grid {
  flex: 0 0 min(60%, 750px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-small-20);
  box-sizing: border-box;
}
@container (width < 750px) {
  .c-card-contents-2 .c-card-contents-2__grid {
    flex-basis: auto;
  }
}
.c-card-contents-2 .c-card-contents-2__grid-item1 {
  grid-column: span 2;
  aspect-ratio: 2.414;
}
.c-card-contents-2 .c-card-contents-2__grid-item1 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-card-contents-2 .c-card-contents-2__grid-item2 {
  aspect-ratio: 1.414;
}
.c-card-contents-2 .c-card-contents-2__grid-item2 img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-card-contents-2 .c-card-contents-2__grid-item3 {
  display: flex;
  justify-content: center;
  align-items: center;
  background: var(--color-primary-600);
  padding: var(--space-large-20);
  box-sizing: border-box;
  color: #fff;
}
@container (width < 500px) {
  .c-card-contents-2 .c-card-contents-2__grid-item3 {
    padding: var(--space-large-10);
  }
}
.c-card-contents-2 .c-card-contents-2__number {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--space-small-20);
  line-height: 1;
  letter-spacing: 0.05em;
  text-indent: 0.05em;
  font-size: var(--size-large-80);
}
@container (width < 500px) {
  .c-card-contents-2 .c-card-contents-2__number {
    font-size: var(--size-large-60);
  }
}
.c-card-contents-2 .c-card-contents-2__number small {
  letter-spacing: 0.2em;
  text-indent: 0.2em;
  font-size: var(--size-regular);
}
.c-card-contents-2 .c-card-contents-2__info {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--space-large-30);
  box-sizing: border-box;
}
.c-card-contents-2 .c-card-contents-2__title-group {
  display: flex;
  flex-direction: column;
  margin-bottom: var(--space-large-10);
}
.c-card-contents-2 .c-card-contents-2__title-group::after {
  content: "";
  width: 3rem;
  height: 2px;
  margin-top: var(--space-large-10);
  background-color: var(--color-accent-800);
}
.c-card-contents-2 .c-card-contents-2__title {
  margin-bottom: 0;
  line-height: 1.7;
  font-size: var(--size-large-30);
  font-weight: bold;
}
.c-card-contents-2 .c-card-contents-2__sub-title {
  margin-bottom: 0;
  line-height: 1.7;
  font-size: var(--size-small-10);
  color: var(--color-gray-300);
}
.c-card-contents-2 .c-card-contents-2__desc {
  font-size: var(--size-regular);
  line-height: 2.4;
}

.c-panel-1 {
  container: c-panel-1/inline-size;
  width: min(100%, 1280px);
  margin-inline: auto;
}
.c-panel-1 .c-panel-1__img {
  position: relative;
  z-index: 10;
  width: 100%;
  aspect-ratio: 2.618/1;
}
.c-panel-1 .c-panel-1__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-panel-1 .c-panel-1__box {
  position: relative;
  z-index: 20;
  width: 80%;
  margin-top: calc(var(--space-large-20) * -1);
  margin-inline: auto;
  background-color: var(--color-background-base);
  padding: var(--space-large-20) var(--space-large-30);
  box-sizing: border-box;
  box-shadow: var(--box-shadow);
}
@container (max-width: 768px) {
  .c-panel-1 .c-panel-1__box {
    width: 90%;
    margin-top: calc(var(--space-large-20) * -1);
    padding: var(--space-large-20) var(--space-large-30);
  }
}

.c-panel-2 {
  container: c-panel-2/inline-size;
  position: relative;
  width: min(100%, 1280px);
  margin-inline: auto;
}
.c-panel-2 .c-panel-2__img {
  margin-left: 50%;
  translate: -50%;
  z-index: 10;
  width: 100lvw;
  height: 350px;
}
.c-panel-2 .c-panel-2__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.c-panel-2 .c-panel-2__inner {
  display: flex;
  align-items: flex-start;
  gap: var(--space-large-30);
}
@container (width < 600px) {
  .c-panel-2 .c-panel-2__inner {
    flex-direction: column;
    gap: 0;
  }
}
.c-panel-2 .c-panel-2__box {
  position: relative;
  z-index: 20;
  flex: 0 0 auto;
  margin-top: calc(var(--space-large-40) * -1);
  background-color: var(--color-background-base);
  padding: var(--space-large-30) var(--space-large-40);
  box-sizing: border-box;
  box-shadow: var(--box-shadow);
}
.c-panel-2 .c-panel-2__box::before {
  content: "";
  position: absolute;
  z-index: 10;
  bottom: var(--space-large-10);
  left: var(--space-large-10);
  width: 2px;
  height: 100%;
  background-color: var(--color-accent-800);
}
.c-panel-2 .c-panel-2__main-title {
  margin: 0;
  font-size: var(--size-large-40);
  font-weight: bold;
  color: var(--color-text-base);
}
.c-panel-2 .c-panel-2__sub-title {
  margin: 0;
  font-size: var(--size-regular);
  color: var(--color-gray-600);
}
.c-panel-2 .c-panel-2__contents {
  margin-top: var(--space-large-10);
}
.c-panel-2 .c-panel-2__desc {
  margin: 0;
  font-size: var(--size-large-10);
  color: var(--color-gray-600);
}

.c-box-1 {
  container: c-box-1/inline-size;
  padding: var(--space-regular);
  border: 1px solid var(--color-primary-500);
  border-left: 4px solid var(--color-primary-500);
  background-color: #fff;
}

.c-table-contents {
  container: c-table-contents/inline-size;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 20px;
  padding: var(--space-large-40);
  box-shadow: var(--box-shadow);
}
.c-table-contents .c-table-contents__table {
  width: 100%;
  margin-bottom: 0;
}
.c-table-contents .c-table-contents__table tr {
  border-left: 4px solid var(--color-primary-600);
  border-bottom: 1px solid var(--color-primary-200);
}
.c-table-contents .c-table-contents__table th,
.c-table-contents .c-table-contents__table td {
  border: unset;
  background: unset;
}
.c-table-contents .c-table-contents__table th {
  width: 150px;
  color: var(--color-primary-700);
  font-weight: 700;
  font-size: var(--size-regular);
  letter-spacing: 0.08em;
  padding: var(--space-large-10);
  box-sizing: border-box;
  text-align: left;
  vertical-align: top;
}
@container (width < 600px) {
  .c-table-contents .c-table-contents__table th {
    display: block;
    width: 100%;
    padding-bottom: 0;
  }
}
.c-table-contents .c-table-contents__table td {
  color: var(--color-primary-900);
  padding: var(--space-large-10);
  font-size: var(--size-small-10);
}
@container (width < 600px) {
  .c-table-contents .c-table-contents__table td {
    display: block;
    width: 100%;
    padding: 0 var(--space-large-10) var(--space-large-10) var(--space-large-20);
  }
}
.c-table-contents .c-table-contents__table tr:last-child th,
.c-table-contents .c-table-contents__table tr:last-child td {
  border-bottom: none;
}

.c-table-contents-2 {
  container: c-table-contents-2/inline-size;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 20px;
  padding: var(--space-large-40);
  box-shadow: var(--box-shadow);
}
.c-table-contents-2 .c-table-contents-2__table {
  width: 100%;
  border-collapse: collapse;
}
.c-table-contents-2 .c-table-contents-2__table th,
.c-table-contents-2 .c-table-contents-2__table td {
  border: unset;
  background: unset;
}
.c-table-contents-2 .c-table-contents-2__table tbody {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  -moz-column-gap: var(--space-large-40);
       column-gap: var(--space-large-40);
}
@container (width < 600px) {
  .c-table-contents-2 .c-table-contents-2__table tbody {
    grid-template-columns: 1fr;
  }
}
.c-table-contents-2 .c-table-contents-2__table tr {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--space-regular) 0;
  border-bottom: 1px solid var(--color-primary-300);
}
.c-table-contents-2 .c-table-contents-2__table th {
  font-weight: 400;
  font-size: var(--size-regular);
  color: var(--color-text-base);
  letter-spacing: 0.04em;
}
.c-table-contents-2 .c-table-contents-2__table td {
  font-size: var(--size-large-10);
  font-weight: 700;
  color: var(--color-primary-900);
  white-space: nowrap;
  margin-left: var(--space-small-10);
  text-align: right;
  vertical-align: top;
}
.c-table-contents-2 .c-table-contents-2__price-details {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.15em;
  margin-top: var(--space-regular);
}
.c-table-contents-2 .c-table-contents-2__price-detail {
  font-size: var(--size-small-10);
  font-weight: 400;
  color: var(--color-primary-700);
  letter-spacing: 0.03em;
}

/* # プロジェクト / Project
------------------------------------------------ */
.p-index-slider .p-index-slider__item {
  height: 100vh;
}
.p-index-slider .slick-arrow--square {
  top: auto;
  bottom: 0;
  left: auto;
  width: 50px;
  height: 50px;
}
.p-index-slider .slick-arrow--square.slick-prev {
  right: 50px;
}
.p-index-slider .slick-arrow--square.slick-next {
  right: 0;
}
.p-index-slider .slick-arrow--square::before {
  font-size: 16px;
}
.p-index-slider .slick-prev::before {
  content: "\e90f";
}
.p-index-slider .slick-next::before {
  content: "\e910";
}
@media screen and (max-width: 767px) {
  .p-index-slider .slick-arrow--square {
    width: 40px;
    height: 40px;
  }
  .p-index-slider .slick-arrow--square::before {
    font-size: 13px;
  }
  .p-index-slider .slick-arrow--square.slick-prev {
    right: 40px;
  }
}

.p-block03 .slick-arrow--square {
  top: auto;
  bottom: 0;
  transform: none;
  left: auto;
  width: 50px;
  height: 50px;
}
.p-block03 .slick-arrow--square.slick-prev {
  right: 50px;
}
.p-block03 .slick-arrow--square.slick-next {
  right: 0;
}
.p-block03 .slick-arrow--square::before {
  font-size: 16px;
}
.p-block03 .slick-prev::before {
  content: "\e90f";
}
.p-block03 .slick-next::before {
  content: "\e910";
}
@media screen and (max-width: 767px) {
  .p-block03 .slick-arrow--square {
    width: 40px;
    height: 40px;
  }
  .p-block03 .slick-arrow--square::before {
    font-size: 13px;
  }
  .p-block03 .slick-arrow--square.slick-prev {
    right: 40px;
  }
}

.wp-theme-kadan_tcd056 .p-btn {
  position: relative;
  border-radius: 30px;
  background-color: var(--color-accent-800);
}
.wp-theme-kadan_tcd056 .p-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  border: 1px solid rgba(255, 255, 255, 0.75);
  border-radius: 30px;
}
.wp-theme-kadan_tcd056 .p-btn:hover {
  background-color: var(--color-accent-700);
}

/* ### フッター / Footer */
.p-info {
  background: var(--color-accent-950);
}

.p-info__inner {
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.p-info__logo {
  display: inline-block;
  width: 300px;
}

.p-social-nav__item a, .p-social-nav__item a:hover {
  color: inherit;
}

.p-index-slider__item-title {
  text-shadow: var(--text-shadow-bk);
  line-height: 1.4;
}

.p-index-slider__item-desc {
  text-shadow: var(--text-shadow-bk);
}

.p-index-slider__item-img::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--overlay-1);
}

.p-section-header__upper {
  position: relative;
  z-index: 0;
  background-size: cover;
  background-position: center;
}
.p-section-header__upper::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background-color: var(--overlay-2);
}

.p-section-header__title {
  font-weight: 700;
  text-shadow: var(--text-shadow-bk);
}

.p-section-header:has(.p-section-header__title span:empty) {
  display: none;
}

.p-section-header__headline:has(.p-section-header__headline-inner:empty) {
  display: none;
}

.p-block04__item-img img {
  aspect-ratio: 1;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-index-blog__slider .slick-arrow::before {
  color: #fff;
  background: var(--color-accent-800);
  padding: 1rem;
  border-radius: 50%;
  opacity: 1;
}
.p-index-blog__slider:hover .p-index-blog__slider .slick-arrow::before {
  background: var(--color-accent-700);
}

.p-index-blog__slider .slick-prev::before {
  position: absolute;
  top: 0;
  right: 0;
}

.p-index-blog__slider .slick-next::before {
  position: absolute;
  top: 0;
  left: 0;
}

.p-section-header__headline {
  clip-path: url(#flowerClip);
  padding: var(--space-regular);
}

.p-block05__content-title span {
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  padding-bottom: var(--space-small-20);
  background-image: repeating-linear-gradient(90deg, #d9b8a1, #d9b8a1 3px, transparent 3px, transparent 6px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 1px;
  line-height: 2;
  font-size: var(--size-large-20);
}

.p-block05__content-desc {
  word-break: auto-phrase;
}

.p-block05__img img {
  aspect-ratio: 1;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-block04__item-desc {
  word-break: auto-phrase;
}

.p-page-header__upper {
  background-position: center;
  background-attachment: scroll;
}
.p-page-header__upper::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: var(--overlay-1);
}

.p-page-header__headline {
  clip-path: url(#flowerClip);
  padding: var(--space-regular);
}

.p-section-nav__item {
  overflow: hidden;
}

.p-section-nav__item a:hover {
  text-decoration: none !important;
}

/* ## メニュー ページ / Menu Page
------------------------------------------------ */
/*** p-menu ***/
.p-block03 {
  background: unset;
  border: unset;
}

/* ## 私たちについてページ / About Page
------------------------------------------------ */
/*** p-greeting ***/
.p-greeting {
  container: p-greeting/inline-size;
}
.p-greeting .p-greeting__inner {
  display: grid;
  grid-template-columns: 38.2fr 61.8fr;
  gap: 0 max(5%, 1rem);
}
@container (width < 800px) {
  .p-greeting .p-greeting__inner {
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
  }
}
@container (width < 550px) {
  .p-greeting .p-greeting__inner {
    grid-template-columns: none;
  }
}
.p-greeting .p-greeting__img-wrap {
  grid-row: 1/4;
  @container (width < 800px);
}
.p-greeting .p-greeting__img {
  aspect-ratio: 1.618/1;
}
.p-greeting .p-greeting__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-greeting .p-greeting__caption:nth-child(n) {
  margin-top: 0.5rem;
  line-height: 1.2;
}
.p-greeting .p-greeting__message {
  margin-bottom: 0;
  word-break: auto-phrase;
  line-height: 2.4;
}
.p-greeting .p-greeting__caption {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-small-10);
  font-size: var(--size-large-10);
}
.p-greeting .p-greeting__caption-title {
  font-size: var(--size-small-10);
}
.p-greeting .p-greeting__caption-name {
  font-weight: 600;
  font-size: var(--size-large-20);
  color: var(--primary-600);
}

.p-recruit-message {
  margin-bottom: var(--space-large-50);
}
.p-recruit-message .p-recruit-message__inner .p-recruit-message__img {
  width: min(100%, 600px);
  margin: 0 auto;
}
.p-recruit-message .p-recruit-message__inner .p-recruit-message__img img {
  width: 100%;
}

.p-requirements .p-requirements__inner .p-requirements__notes {
  text-align: center;
}
.p-requirements .p-requirements__tab-btns {
  display: flex;
  gap: 4px;
}
.p-requirements .p-requirements__tab-btn {
  flex: 1;
  padding: var(--space-large-10);
  background: var(--color-gray-100);
  border: none;
  border-bottom: 3px solid transparent;
  border-radius: 20px 20px 0 0;
  font-size: var(--size-regular);
  font-weight: 600;
  color: var(--color-gray-600);
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}
.p-requirements .p-requirements__tab-btn.is-active {
  background: var(--color-accent-950);
  border-bottom-color: var(--color-accent-600);
  color: #fff;
}
.p-requirements .requirements-tab {
  background: rgba(255, 255, 255, 0.6);
  border-radius: 0 0 20px 20px;
  padding: var(--space-large-40);
  box-shadow: var(--box-shadow);
}
.p-requirements .requirements-tab .c-table-contents {
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}

.p-form-section {
  padding-block: var(--space-large-40);
}

.p-contact-tel {
  container: p-contact-tel/inline-size;
}
.p-contact-tel .p-contact-tel__box {
  position: relative;
  padding: var(--space-large-30) var(--space-large-10);
  box-sizing: border-box;
  min-width: auto;
  background-color: var(--color-accent-50);
  text-align: center;
  color: var(--color-text-base);
  border-radius: 12px;
}
.p-contact-tel .p-contact-tel__box::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  width: calc(100% - var(--space-large-10));
  height: calc(100% - var(--space-large-10));
  border: 2px solid rgba(255, 255, 255, 0.6);
  border-radius: 8px;
  pointer-events: none;
}
.p-contact-tel .p-contact-tel__message {
  margin-bottom: var(--space-regular);
  font-size: var(--size-regular);
}
.p-contact-tel .p-contact-tel__number-list {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
}
@container (width < 600px) {
  .p-contact-tel .p-contact-tel__number-list {
    flex-direction: column;
  }
}
.p-contact-tel .p-contact-tel__number-item {
  list-style: none;
}
@container (width >=600px) {
  .p-contact-tel .p-contact-tel__number-item {
    padding-inline: var(--space-large-30);
  }
}
@container (width < 600px) {
  .p-contact-tel .p-contact-tel__number-item {
    padding-block: var(--space-regular);
  }
}
@container (width >=600px) {
  .p-contact-tel .p-contact-tel__number-item:not(:last-child) {
    border-right: 1px solid #ccc;
  }
}
@container (width < 600px) {
  .p-contact-tel .p-contact-tel__number-item:not(:last-child) {
    border-bottom: 1px solid #ccc;
  }
}
.p-contact-tel .p-contact-tel__number-link {
  display: flex;
  gap: 0.3em;
  justify-content: center;
  align-items: center;
  margin: 0;
  font-size: var(--size-large-40);
  color: var(--color-accent-700);
  text-decoration: none !important;
  transition: 0.3s;
}
.p-contact-tel .p-contact-tel__number-link:hover {
  color: var(--color-accent-600);
}
.p-contact-tel .p-contact-tel__number-link::before {
  content: "";
  width: 0.9em;
  aspect-ratio: 1;
  translate: 0 8%;
  background: currentColor;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M478.047 400.316c-19.356-18.424-81.443-56.049-97.112-61.134-15.659-5.096-36.341 8.668-43.342 27.382-7.012 18.715-16.85 16.022-16.85 16.022s-37.242-17.472-101.504-93.726-75.167-115.92-75.167-115.92-.984-10.16 18.662-13.898c19.615-3.729 36.693-21.769 34.321-38.071-2.34-16.301-28.904-83.876-43.776-106.06C138.377-7.262 105.153.61 97.593 5.146c-7.571 4.536-86.756 45.692-71.842 135.492 14.934 89.801 57.26 164.294 105.904 222.022 48.644 57.726 114.884 112.087 200.863 142.018 85.958 29.93 139.956-41.136 145.704-47.826 5.749-6.68 19.139-38.091-.175-56.536'/%3E%3C/svg%3E") center/contain no-repeat;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M478.047 400.316c-19.356-18.424-81.443-56.049-97.112-61.134-15.659-5.096-36.341 8.668-43.342 27.382-7.012 18.715-16.85 16.022-16.85 16.022s-37.242-17.472-101.504-93.726-75.167-115.92-75.167-115.92-.984-10.16 18.662-13.898c19.615-3.729 36.693-21.769 34.321-38.071-2.34-16.301-28.904-83.876-43.776-106.06C138.377-7.262 105.153.61 97.593 5.146c-7.571 4.536-86.756 45.692-71.842 135.492 14.934 89.801 57.26 164.294 105.904 222.022 48.644 57.726 114.884 112.087 200.863 142.018 85.958 29.93 139.956-41.136 145.704-47.826 5.749-6.68 19.139-38.091-.175-56.536'/%3E%3C/svg%3E") center/contain no-repeat;
  transition: 0s;
}
.p-contact-tel .p-contact-tel__number-link--sp::before {
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M502.79 100.977c-1.273-2.76-4.918-5.406-7.424-7.262-.054-.081-.121-.161-.174-.235.054.067.094.141.148.207-2.962-2.191-6.7-3.671-11.136-4.14L313.428 71.329c-15.397-1.649-33.126 9.139-39.491 23.96L146.633 392.463c-2.64 6.138-2.882 12.054-1.193 16.985.523 14.197 13.776 25.159 26.761 26.546 2.238.241 4.476.476 6.714.717 12.516 1.334 25.019 2.667 37.522 4.007 33.956 3.618 67.9 7.236 101.843 10.868 17.609 1.876 34.815 5.802 49.917-4.563 16.751-11.464 24.095-30.412 34.305-55.425 38.285-93.816 65.1-160.168 104.993-253.248 2.251-5.28 4.623-10.432 4.502-16.449 0-.007 0 0 0-.007-.109-6.459-3.74-13.119-9.033-19.477zM269.997 398.353c-3.109 6.814-11.712 11.74-19.149 10.982-7.424-.751-10.934-6.895-7.826-13.708 3.096-6.794 11.645-11.726 19.069-10.969 8.423.743 11.989 6.908 7.906 13.695zM365.421 368.316l-172.008-18.352 104.216-243.152 171.994 18.359L365.421 368.316z'/%3E%3Cpath d='M78.478 71.744 65.534 58.102c-25.984 24.61-46.084 56.168-56.926 92.866-10.855 36.73-11.096 74.104-2.68 108.892l18.278-4.449c-7.665-31.692-7.438-65.648 2.452-99.11C36.534 122.86 54.813 94.183 78.478 71.744z'/%3E%3Cpath d='M76.575 171.055c-7.973 27.029-8.16 54.573-1.956 80.215l18.278-4.462c-5.44-22.553-5.28-46.68 1.729-70.426 7.022-23.766 20.007-44.128 36.838-60.068l-12.945-13.669c-19.137 18.131-33.944 41.354-41.944 68.41z'/%3E%3Cpath d='M162.606 196.461c4.154-14.07 11.873-26.07 21.882-35.578l-12.945-13.655c-12.261 11.638-21.842 26.505-26.975 43.9-5.132 17.38-5.186 35.082-1.206 51.498l18.278-4.442c-3.228-13.4-3.188-27.665 1.966-41.723z'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M502.79 100.977c-1.273-2.76-4.918-5.406-7.424-7.262-.054-.081-.121-.161-.174-.235.054.067.094.141.148.207-2.962-2.191-6.7-3.671-11.136-4.14L313.428 71.329c-15.397-1.649-33.126 9.139-39.491 23.96L146.633 392.463c-2.64 6.138-2.882 12.054-1.193 16.985.523 14.197 13.776 25.159 26.761 26.546 2.238.241 4.476.476 6.714.717 12.516 1.334 25.019 2.667 37.522 4.007 33.956 3.618 67.9 7.236 101.843 10.868 17.609 1.876 34.815 5.802 49.917-4.563 16.751-11.464 24.095-30.412 34.305-55.425 38.285-93.816 65.1-160.168 104.993-253.248 2.251-5.28 4.623-10.432 4.502-16.449 0-.007 0 0 0-.007-.109-6.459-3.74-13.119-9.033-19.477zM269.997 398.353c-3.109 6.814-11.712 11.74-19.149 10.982-7.424-.751-10.934-6.895-7.826-13.708 3.096-6.794 11.645-11.726 19.069-10.969 8.423.743 11.989 6.908 7.906 13.695zM365.421 368.316l-172.008-18.352 104.216-243.152 171.994 18.359L365.421 368.316z'/%3E%3Cpath d='M78.478 71.744 65.534 58.102c-25.984 24.61-46.084 56.168-56.926 92.866-10.855 36.73-11.096 74.104-2.68 108.892l18.278-4.449c-7.665-31.692-7.438-65.648 2.452-99.11C36.534 122.86 54.813 94.183 78.478 71.744z'/%3E%3Cpath d='M76.575 171.055c-7.973 27.029-8.16 54.573-1.956 80.215l18.278-4.462c-5.44-22.553-5.28-46.68 1.729-70.426 7.022-23.766 20.007-44.128 36.838-60.068l-12.945-13.669c-19.137 18.131-33.944 41.354-41.944 68.41z'/%3E%3Cpath d='M162.606 196.461c4.154-14.07 11.873-26.07 21.882-35.578l-12.945-13.655c-12.261 11.638-21.842 26.505-26.975 43.9-5.132 17.38-5.186 35.082-1.206 51.498l18.278-4.442c-3.228-13.4-3.188-27.665 1.966-41.723z'/%3E%3C/svg%3E");
}
.p-contact-tel .p-contact-tel__icon {
  width: 1em;
  margin-right: 0.3em;
  fill: currentColor;
}
.p-contact-tel .p-contact-tel__notes {
  margin-bottom: 0;
  font-size: var(--size-small-10);
}

.p-contact-form {
  container-type: inline-size;
}
.p-contact-form .p-contact-form__inner {
  box-sizing: border-box;
}
.p-contact-form .p-contact-form__input-group {
  display: grid;
  grid-template-columns: repeat(2, auto) 1fr;
  gap: 0 var(--space-large-20);
}
.p-contact-form .p-contact-form__input-row {
  display: grid;
  grid-template-columns: subgrid;
  grid-column: span 3;
  row-gap: 0;
  align-items: center;
  padding: var(--space-large-20) 0;
}
@container (width < 600px) {
  .p-contact-form .p-contact-form__input-row {
    grid-template-columns: repeat(2, auto) 1fr;
    gap: var(--space-regular) var(--space-small-10);
  }
}
.p-contact-form .p-contact-form__input-title {
  margin: 0;
  font-size: var(--size-regular);
}
.p-contact-form .p-contact-form__input-label {
  line-height: 2.2em;
  letter-spacing: 0.2em;
  margin: 0;
  padding: 0em 1em;
  border-radius: 3px;
  white-space: nowrap;
  color: #fff;
  font-weight: normal;
  font-size: var(--size-small-20);
}
.p-contact-form .p-contact-form__input-label--required {
  background-color: #ca4260;
}
.p-contact-form .p-contact-form__input-label--optional {
  background-color: var(--color-gray-300);
}
.p-contact-form .p-contact-form__input-content {
  grid-column: 3;
}
@container (width < 600px) {
  .p-contact-form .p-contact-form__input-content {
    grid-column: 1/-1;
  }
}
.p-contact-form .p-contact-form__input-content--multiline {
  grid-row: span 2;
}
.p-contact-form .p-contact-form__input-content:nth-child(n+2 of .p-contact-form .p-contact-form__input-content) {
  margin-top: var(--input-content-gap);
}
.p-contact-form .p-contact-form__input-subtitle {
  display: block;
  margin-bottom: 0;
  font-size: var(--size-small-10);
}
.p-contact-form input,
.p-contact-form select,
.p-contact-form textarea {
  padding: 0.75em;
  box-sizing: border-box;
  font-size: 1rem;
}
.p-contact-form input:is([type=text], [type=email], [type=tel])[size="40"] {
  width: 100%;
}
.p-contact-form select {
  width: -moz-min-content;
  width: min-content;
  field-sizing: content;
}
.p-contact-form textarea {
  width: 100%;
  min-height: 7lh;
  field-sizing: content;
  line-height: 1.7;
  resize: vertical;
}
.p-contact-form input.p-postal-code {
  width: 10em;
}
.p-contact-form .wpcf7-list-item-label {
  line-height: 2.6;
}
.p-contact-form .p-cf7-radio-type-1 {
  container: p-cf7-radio-type-1/inline-size;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-small-10);
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item {
  margin: 0;
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px 12px 15px;
  border: 1px solid var(--color-gray-100);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.6);
  cursor: pointer;
  transition: all 0.3s ease;
  font-weight: 500;
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label::before, .p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label::after {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  box-sizing: border-box;
  transition: all 0.3s ease;
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label::before {
  content: "";
  background-color: var(--color-gray-50);
  border: 2px solid var(--color-gray-200);
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label::after {
  content: "";
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  background-clip: content-box;
  opacity: 0;
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label:hover, .p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item label:has(input:focus) {
  background: var(--color-accent-50);
  border-color: var(--color-accent-400);
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item input[type=radio] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item:has(input[type=radio]:checked) label {
  background: var(--color-accent-100);
  border-color: var(--color-accent-700);
  color: var(--color-accent-900);
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item:has(input[type=radio]:checked) label::before {
  border-color: var(--color-accent-700);
}
.p-contact-form .p-cf7-radio-type-1 .wpcf7-list-item:has(input[type=radio]:checked) label::after {
  background-color: var(--color-accent-700);
  opacity: 1;
}
.p-contact-form .p-cf7-checkbox-type-1 {
  container: p-cf7-checkbox-type-1/inline-size;
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-small-10);
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item {
  margin: 0;
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px 12px 15px;
  border: 1px solid var(--color-gray-50);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.3s ease;
  font-weight: 500;
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label::before, .p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label::after {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  box-sizing: border-box;
  transition: all 0.3s ease;
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label::before {
  content: "";
  background-color: var(--color-gray-50);
  border: 2px solid var(--color-gray-200);
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label::after {
  content: "✓";
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  display: grid;
  place-items: center;
  font-size: 14px;
  font-family: sans-serif;
  color: #fff;
  opacity: 0;
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label:hover, .p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item label:has(input:focus) {
  background: var(--color-accent-100);
  border-color: var(--color-accent-500);
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item input[type=checkbox] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item:has(input[type=checkbox]:checked) label {
  background: var(--color-accent-100);
  border-color: var(--color-accent-700);
  color: var(--color-accent-900);
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item:has(input[type=checkbox]:checked) label::before {
  background: var(--color-accent-700);
  border-color: var(--color-accent-700);
}
.p-contact-form .p-cf7-checkbox-type-1 .wpcf7-list-item:has(input[type=checkbox]:checked) label::after {
  opacity: 1;
}
.p-contact-form .p-contact-form__submit-group {
  display: grid;
  gap: var(--space-large-10);
}
.p-contact-form .p-contact-form__privacy-embed {
  height: 400px;
  padding: var(--space-large-20);
  box-sizing: border-box;
  overflow-y: scroll;
  background: var(--color-gray-50);
}
.p-contact-form .p-contact-form__privacy-embed .p-contact-form__privacy-embed__title {
  margin-bottom: var(--space-large-10);
  text-align: center;
  word-break: keep-all;
  font-size: var(--size-large-30);
}
.p-contact-form .p-contact-form__privacy-embed .p-contact-form__privacy-embed__subtitle {
  margin-bottom: var(--space-small-10);
  font-size: var(--size-large-10);
}
.p-contact-form .p-contact-form__privacy-embed .p-contact-form__privacy-embed__text {
  margin-bottom: var(--space-large-10);
  line-height: 2.4;
  font-size: var(--size-small-10);
}
.p-contact-form .p-contact-form__consent-check {
  text-align: center;
}
.p-contact-form .p-contact-form__submit-btn {
  display: block;
  width: min(100%, 350px);
  margin: 0 auto;
}
.p-contact-form .p-contact-form__submit-btn input[type=submit] {
  width: 100%;
  height: auto;
  margin: 0 auto;
  padding: var(--space-large-10) 0;
  background: var(--color-accent-800);
  border-radius: 50px;
  transition: 0.3s;
  text-align: center;
  letter-spacing: 0.1em;
  font-size: var(--size-large-10);
  color: #fff;
  border: none;
}
.p-contact-form .p-contact-form__submit-btn input[type=submit]:is(:hover, :focus) {
  background: var(--color-accent-700);
  color: #fff;
}

.wpcf7:has(.p-contact-form) {
  border: none;
  border-radius: 20px;
  box-shadow: var(--box-shadow);
  padding: var(--space-large-30);
  background: rgba(255, 255, 255, 0.6);
}
.wpcf7:has(.p-contact-form) .wpcf7-spinner {
  position: absolute;
}
.wpcf7:has(.p-contact-form) .wpcf7-not-valid {
  border-color: #dc3232;
  background-color: #fff8f8;
}
.wpcf7:has(.p-contact-form) .wpcf7-not-valid-tip {
  width: 100%;
  margin-top: 5px;
  padding: 8px;
  box-sizing: border-box;
  text-align: left;
  background-color: #fff8f8;
  border-left: 4px solid #dc3232;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
  color: #dc3232;
  font-size: 14px;
  font-weight: bold;
  animation: errorShake 0.3s ease-in-out;
}
@keyframes errorShake {
  0% {
    translate: 0;
  }
  25% {
    translate: -10px;
  }
  75% {
    translate: 10px;
  }
  100% {
    translate: 0;
  }
}

.p-contact-notification {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 12px;
  z-index: 9999;
  width: -moz-max-content;
  width: max-content;
  max-width: 90%;
  padding: 1.5rem;
  box-sizing: border-box;
  border-radius: 5px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  color: #fff;
  pointer-events: none;
  animation: contact-notification-fade-in-out 2.5s forwards;
}

@keyframes contact-notification-fade-in-out {
  0% {
    opacity: 0;
    transform: translate(-50%, -40%);
  }
  20% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
  80% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
  100% {
    opacity: 0;
    transform: translate(-50%, -60%);
  }
}
.p-contact-notification.p-contact-notification--success {
  background-color: rgba(14, 133, 14, 0.8);
}

.p-contact-notification.p-contact-notification--error {
  background-color: rgba(0, 0, 0, 0.8);
}

.p-contact-notification .p-contact-notification__message {
  margin: 0;
  font-size: 1rem;
}

/* # ユーティリティ / Utility
------------------------------------------------ */
/* ## デバイス別の表示制御 */
@media (width < 960px) {
  .u-pc-only {
    display: none;
  }
}

@media (width >= 960px) {
  .u-tb-only {
    display: none;
  }
}

@media (width >= 560px) {
  .u-sp-only {
    display: none;
  }
}

/* ## 文字列の折り返し制御 */
.u-keep-all {
  word-break: keep-all;
}

.u-auto-phrase {
  word-break: auto-phrase;
}

/* ## コンテンツ間スペーシング */
.u-mb-0 {
  margin-bottom: 0 !important;
}

.u-mb-small-20 {
  margin-bottom: var(--space-small-20) !important;
}

.u-mb-small-10 {
  margin-bottom: var(--space-small-10) !important;
}

.u-mb-regular {
  margin-bottom: var(--space-regular) !important;
}

.u-mb-large-10 {
  margin-bottom: var(--space-large-10) !important;
}

.u-mb-large-20 {
  margin-bottom: var(--space-large-20) !important;
}

.u-mb-large-30 {
  margin-bottom: var(--space-large-30) !important;
}

.u-mb-large-40 {
  margin-bottom: var(--space-large-40) !important;
}

.u-mb-large-45 {
  margin-bottom: var(--space-large-45) !important;
}

.u-mb-large-50 {
  margin-bottom: var(--space-large-50) !important;
}

.u-mb-large-60 {
  margin-bottom: var(--space-large-60) !important;
}

.u-mb-large-70 {
  margin-bottom: var(--space-large-70) !important;
}

.u-mb-large-80 {
  margin-bottom: var(--space-large-80) !important;
}

.u-mb-large-90 {
  margin-bottom: var(--space-large-90) !important;
}

.u-mb-large-100 {
  margin-bottom: var(--space-large-100) !important;
}

/* ## スタイル微調整 */
.u-align-center {
  text-align: center;
}

.u-text-link {
  color: var(--color-accent-700);
}
.u-text-link--external {
  display: inline-flex;
  align-items: center;
  gap: 0.2em;
}
.u-text-link--external::after {
  content: "";
  width: 1em;
  height: 1em;
  background: currentColor;
  mask: center/contain no-repeat;
  -webkit-mask: center/contain no-repeat;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 -960 960 960'%3E%3Cpath d='M212.31-140Q182-140 161-161q-21-21-21-51.31v-535.38Q140-778 161-799q21-21 51.31-21h252.3v60h-252.3q-4.62 0-8.46 3.85-3.85 3.84-3.85 8.46v535.38q0 4.62 3.85 8.46 3.84 3.85 8.46 3.85h535.38q4.62 0 8.46-3.85 3.85-3.84 3.85-8.46v-252.3h60v252.3Q820-182 799-161q-21 21-51.31 21H212.31Zm176.46-206.62-42.15-42.15L717.85-760H560v-60h260v260h-60v-157.85L388.77-346.62Z'/%3E%3C/svg%3E");
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 -960 960 960'%3E%3Cpath d='M212.31-140Q182-140 161-161q-21-21-21-51.31v-535.38Q140-778 161-799q21-21 51.31-21h252.3v60h-252.3q-4.62 0-8.46 3.85-3.85 3.84-3.85 8.46v535.38q0 4.62 3.85 8.46 3.84 3.85 8.46 3.85h535.38q4.62 0 8.46-3.85 3.85-3.84 3.85-8.46v-252.3h60v252.3Q820-182 799-161q-21 21-51.31 21H212.31Zm176.46-206.62-42.15-42.15L717.85-760H560v-60h260v260h-60v-157.85L388.77-346.62Z'/%3E%3C/svg%3E");
}

.u-color-primary-600 {
  color: var(--color-primary-600);
}

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

.u-bold {
  font-weight: bold;
}/*# sourceMappingURL=style.css.map */