@charset "UTF-8";
/**
 * SCSS変数ファイル
 * theme.jsonで定義した値をSCSSでも使用できるようにする
 * WordPressのCSS変数から値を読み込む
 *
 * @package Yatsu
 * @version 1.0.0
 */
/* Eric Meyer's Reset CSS 2.0 - http://meyerweb.com/eric/tools/css/reset/ */
/* v2.0 | 20110126 */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

/**
 * ベーススタイル
 *
 * HTML、body、その他の基本要素のスタイルを定義
 *
 * @package yatsu
 * @since 1.0.0
 */
html {
  font-size: 16px;
  line-height: 1.6;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: var(--wp--custom--font-weight--regular);
  line-height: 1.6;
  color: var(--wp--preset--color--text-dark);
  background-color: var(--wp--preset--color--white);
  margin: 0 auto;
  padding: 0;
  min-height: 100vh;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

main {
  margin: 0 auto;
}

.section.is-cloud-line {
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/cloud.svg");
  background-size: 70px auto;
  background-repeat: repeat-x;
  background-position: center bottom;
}
@media (max-width: 1000px) {
  .section.is-cloud-line {
    padding-bottom: var(--wp--preset--spacing--40);
  }
}
@media (max-width: 1000px) {
  .section.is-cloud-line + .section .section__inner {
    padding-top: var(--wp--preset--spacing--40);
  }
}
.section.is-bg-curve {
  position: relative;
  overflow: visible;
  background-color: transparent;
  padding-top: var(--wp--preset--spacing--92);
  overflow: hidden;
}
@media (max-width: 1000px) {
  .section.is-bg-curve {
    padding-top: var(--wp--preset--spacing--56);
  }
}
.section.is-bg-curve::before {
  content: "";
  position: absolute;
  top: -1000px;
  left: 50%;
  transform: translateX(-50%);
  width: 150vw;
  height: 1146px;
  background-color: var(--wp--preset--color--white);
  border-radius: 0 0 50% 50%;
  z-index: 0;
  pointer-events: none;
}
@media (max-width: 1000px) {
  .section.is-bg-curve::before {
    top: -300px;
    width: 200vw;
    height: 400px;
  }
}
.section.is-bg-curve .section__inner {
  position: relative;
  z-index: 1;
}
.section:has(+ .section.is-bg-curve) .section__inner {
  padding-bottom: var(--wp--preset--spacing--20);
}
.section .section__inner {
  width: 75vw;
  gap: var(--wp--preset--spacing--48);
  padding: var(--wp--preset--spacing--120) 0;
  max-width: 1600px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1000px) {
  .section .section__inner {
    width: 100%;
    gap: var(--wp--preset--spacing--32);
    padding: var(--wp--preset--spacing--56) calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}
.section:last-child .section__inner {
  padding-bottom: 300px;
}
@media (max-width: 1000px) {
  .section:last-child .section__inner {
    padding-bottom: 350px;
  }
}
.section[data-color="2"].is-background {
  background-color: var(--wp--preset--color--sub-color-2);
}
.section[data-color="1"].is-background {
  background-color: var(--wp--preset--color--sub-color-1);
}
.section[data-color="3"].is-background {
  background-color: var(--wp--preset--color--sub-color-1);
}
.section[data-color="5"].is-background {
  background-color: var(--wp--preset--color--index-color-runner-text);
}
.section[data-color="5"].is-bg-curve::before {
  background-color: var(--wp--preset--color--sub-color-1);
}

.container {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}

.content-block-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--48);
}

.table-wrapper {
  display: flex;
  flex-direction: column;
}

.archive-header {
  width: 75vw;
  max-width: 1600px;
  margin: 0 auto;
  padding: var(--wp--preset--spacing--48) 0;
}
@media (max-width: 1000px) {
  .archive-header {
    width: 100%;
    padding: var(--wp--preset--spacing--32) calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}

.archive-title {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: 700;
  font-size: var(--wp--preset--font-size--4-xl);
  color: var(--wp--preset--color--text-dark);
  margin: 0 0 var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .archive-title {
    font-size: var(--wp--preset--font-size--3-xl);
  }
}

.archive-description {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  color: var(--wp--preset--color--text-dark);
  margin-top: var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .archive-description {
    font-size: var(--wp--preset--font-size--s);
  }
}

.posts {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .posts {
    width: 100%;
    gap: var(--wp--preset--spacing--24);
  }
}

.no-posts {
  width: 75vw;
  max-width: 1600px;
  margin: 0 auto;
  padding: var(--wp--preset--spacing--48) 0;
  text-align: center;
}
@media (max-width: 1000px) {
  .no-posts {
    width: 100%;
    padding: var(--wp--preset--spacing--32) calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}
.no-posts h1 {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: 700;
  font-size: var(--wp--preset--font-size--3-xl);
  color: var(--wp--preset--color--text-dark);
  margin: 0 0 var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .no-posts h1 {
    font-size: var(--wp--preset--font-size--2-xl);
  }
}
.no-posts p {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  color: var(--wp--preset--color--text-dark);
  margin: 0 0 var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .no-posts p {
    font-size: var(--wp--preset--font-size--s);
  }
}

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

br[data-responsive=sp] {
  display: none;
}
@media (max-width: 1000px) {
  br[data-responsive=sp] {
    display: block;
  }
}
br[data-responsive=pc] {
  display: block;
}
@media (max-width: 1000px) {
  br[data-responsive=pc] {
    display: none;
  }
}

.single-post__content p {
  font-weight: var(--wp--custom--font-weight--medium);
  margin-bottom: var(--wp--preset--spacing--24);
  line-height: 24px;
  color: var(--wp--preset--color--text-dark);
  font-size: var(--wp--preset--font-size--l);
}
@media (max-width: 1000px) {
  .single-post__content p {
    font-size: var(--wp--preset--font-size--m);
  }
}
.single-post__content a {
  color: var(--wp--preset--color--site-color-2);
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
  transition: opacity 0.2s ease;
  font-weight: var(--wp--custom--font-weight--black);
}
.single-post__content a:hover {
  text-decoration: none;
}
.single-post__content .img {
  margin-bottom: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .single-post__content .img {
    margin-bottom: var(--wp--preset--spacing--16);
  }
}
.single-post__content .img img {
  border-radius: 24px;
}
@media (max-width: 1000px) {
  .single-post__content .img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

/**
 * TOPページ専用スタイル
 *
 * フロントページ（TOPページ）専用のスタイルを定義
 *
 * @package yatsu
 * @since 1.0.0
 */
.index-diary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: calc(var(--wp--preset--spacing--64) / 1600px * 100vw);
  align-items: start;
}
@media (max-width: 1000px) {
  .index-diary-grid {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--24);
  }
}

.index-diary-grid__item.is-offset {
  margin-top: var(--wp--preset--spacing--80);
}
@media (max-width: 1000px) {
  .index-diary-grid__item.is-offset {
    margin-top: 0;
  }
}

.index-diary__button {
  display: flex;
  justify-content: center;
}

.index-info-section__decoration {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  object-fit: contain;
  display: block;
}
.index-info-section__decoration--balloons {
  top: 0;
  left: -143px;
  width: 143px;
  height: auto;
  transform: translateY(100%);
  z-index: 1;
}
.index-info-section__decoration--balloons.is-animated {
  animation: balloon-rise 5s ease-out forwards, balloon-sway 3s ease-in-out 5s infinite;
}
@media (max-width: 1000px) {
  .index-info-section__decoration--balloons {
    top: inherit;
    bottom: 420px;
    left: calc(34px / 1000px * 100vw);
    width: 85px;
  }
  .index-info-section__decoration--balloons.is-animated {
    animation: none;
  }
}

@keyframes balloon-rise {
  0% {
    transform: translateY(100%) translateX(0);
  }
  100% {
    transform: translateY(0) translateX(0);
  }
}
@keyframes balloon-sway {
  0%, 100% {
    transform: translateY(0) translateX(0);
  }
  25% {
    transform: translateY(0) translateX(3px);
  }
  75% {
    transform: translateY(0) translateX(-3px);
  }
}
.index-info-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: var(--wp--preset--color--white);
  border-radius: 40px;
  padding: var(--wp--preset--spacing--40);
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .index-info-card {
    max-width: 100%;
    width: 100%;
    margin-top: var(--wp--preset--spacing--80);
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--24);
  }
}

.index-info-card__illustration {
  position: absolute;
  z-index: -1;
  pointer-events: none;
  object-fit: contain;
  display: block;
}
.index-info-card__illustration--rabbit {
  bottom: 7px;
  left: -91px;
  aspect-ratio: 116/187;
  width: 116px;
  height: 187px;
}
@media (max-width: 1000px) {
  .index-info-card__illustration--rabbit {
    bottom: inherit;
    width: 100px;
    top: -130px;
    left: 0;
  }
}
.index-info-card__illustration--chick {
  bottom: 10px;
  right: -83px;
  aspect-ratio: 109/142;
  width: 109px;
  height: 142px;
}
@media (max-width: 1000px) {
  .index-info-card__illustration--chick {
    bottom: inherit;
    width: 100px;
    top: -110px;
    right: 0;
  }
}

.index-info-card__hand {
  position: absolute;
  z-index: 2;
  pointer-events: none;
}
@media (max-width: 1000px) {
  .index-info-card__hand {
    display: none;
  }
}
.index-info-card__hand--rabbit {
  bottom: 43px;
  left: -23px;
  width: 45px;
  height: 17px;
}
.index-info-card__hand--chick {
  bottom: 51px;
  right: -40px;
  width: 53px;
  height: 30px;
}
.index-info-card__hand-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.index-info-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  padding: 0;
  margin-top: 44px;
}
@media (max-width: 1000px) {
  .index-info-list {
    margin-top: var(--wp--preset--spacing--24);
  }
}

.index-info-list__item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: var(--wp--preset--spacing--16) 0;
  border-bottom: 1px dashed var(--wp--preset--color--table-border);
  text-decoration: none;
  transition: opacity 0.3s ease;
}
@media (max-width: 1000px) {
  .index-info-list__item {
    flex-direction: column;
    gap: var(--wp--preset--spacing--8);
  }
}
.index-info-list__item:hover {
  opacity: 0.7;
}

.index-info-list__date {
  flex-shrink: 0;
  color: var(--wp--preset--color--site-color-1) !important;
  white-space: nowrap;
  width: auto !important;
}

.index-info-list__title {
  flex: 1;
  color: var(--wp--preset--color--text-dark) !important;
  text-decoration: none !important;
  width: auto !important;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.index-info__button {
  display: flex;
  justify-content: center;
  margin-top: 44px;
}
@media (max-width: 1000px) {
  .index-info__button {
    width: 100%;
  }
}

.index-kids-club {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: var(--wp--preset--spacing--40);
  margin: var(--wp--preset--spacing--32) auto 0;
  max-width: 1000px;
  width: 100%;
}
@media (max-width: 1000px) {
  .index-kids-club {
    flex-direction: column;
    align-items: center;
    margin-top: 0;
    gap: var(--wp--preset--spacing--24);
  }
}

.index-kids-club__decoration {
  position: absolute;
  z-index: -1;
  pointer-events: none;
  object-fit: contain;
  display: block;
}
.index-kids-club__decoration--egg {
  bottom: 0;
  left: calc(50% - 257.5px - 60px);
  width: 120px;
  height: auto;
}
@media (max-width: 1000px) {
  .index-kids-club__decoration--egg {
    display: none;
  }
}

.index-kids-club__illustration {
  position: absolute;
  z-index: 1;
  pointer-events: none;
  object-fit: contain;
  display: block;
  width: 257px;
  height: auto;
  bottom: -47px;
  right: 40px;
}
@media (max-width: 1000px) {
  .index-kids-club__illustration {
    width: 183px;
    position: relative;
    margin-left: auto;
    bottom: -16px;
  }
}

.index-kids-club-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: var(--wp--preset--color--white);
  border-radius: 40px;
  padding: var(--wp--preset--spacing--40);
  margin-right: auto;
  flex-shrink: 0;
  max-width: 600px;
  width: 100%;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .index-kids-club-card {
    max-width: 100%;
    gap: var(--wp--preset--spacing--24);
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--16);
  }
}

.index-kids-club-card__image {
  border-radius: 24px;
  overflow: hidden;
  background-color: var(--wp--preset--color--table-border);
}
.index-kids-club-card__image-element .image__element {
  display: block;
  object-fit: cover;
}

.index-diary-section .section__inner {
  gap: var(--wp--preset--spacing--64);
  padding-top: var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .index-diary-section .section__inner {
    gap: var(--wp--preset--spacing--32);
  }
}

.index-children-section .section__inner {
  padding-top: var(--wp--preset--spacing--80);
  padding-bottom: var(--wp--preset--spacing--80);
}
@media (max-width: 1000px) {
  .index-children-section .section__inner {
    padding-top: var(--wp--preset--spacing--40);
    padding-bottom: 0 !important;
  }
}

.index-children {
  display: flex;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--40);
  justify-content: center;
  position: relative;
  z-index: 1;
  margin-bottom: -220px;
}
@media (max-width: 1000px) {
  .index-children {
    flex-direction: column;
    gap: var(--wp--preset--spacing--24);
    margin-bottom: -180px;
  }
}

.index-children__left {
  flex-shrink: 0;
  margin-top: 120px;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.index-children__left.is-animated {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 1000px) {
  .index-children__left {
    width: 100%;
    margin-top: 0;
    order: 1;
  }
}

.index-children__image-container {
  position: relative;
  width: 374px;
  height: 457px;
  flex-shrink: 0;
  aspect-ratio: 374/457;
}
@media (max-width: 1000px) {
  .index-children__image-container {
    width: 100%;
    max-width: 374px;
    left: 50%;
    transform: translateX(-50%);
    height: auto;
  }
}

.index-children__decoration {
  position: absolute;
  pointer-events: none;
  object-fit: contain;
}
.index-children__decoration--illust {
  top: 0;
  right: 0;
  bottom: 29.26%;
  left: 81.07%;
  width: auto;
  height: auto;
  max-width: 18.93%;
  max-height: 70.74%;
}
@media (max-width: 1000px) {
  .index-children__decoration--illust {
    max-width: 20%;
    max-height: 60%;
  }
}
.index-children__decoration--butterfly {
  top: 6.66%;
  right: 58.15%;
  bottom: 82.28%;
  left: 0;
  width: auto;
  height: auto;
  max-width: 41.85%;
  max-height: 11.06%;
  z-index: 2;
}
@media (max-width: 1000px) {
  .index-children__decoration--butterfly {
    max-width: 35%;
    max-height: 10%;
  }
}

.index-children__image {
  position: absolute;
  top: 23.03%;
  right: 11.2%;
  bottom: 0;
  left: 3.6%;
  width: auto;
  height: auto;
  max-width: 85.2%;
  max-height: 76.97%;
  object-fit: cover;
  display: block;
}

.index-children__right {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
  flex: 1;
  max-width: 630px;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}
.index-children__right.is-animated {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width: 1000px) {
  .index-children__right {
    width: 100%;
    max-width: none;
    gap: var(--wp--preset--spacing--24);
  }
}

.index-children__header {
  background-color: var(--wp--preset--color--site-color-1);
  padding: var(--wp--preset--spacing--12) var(--wp--preset--spacing--40);
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1000px) {
  .index-children__header {
    padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
    min-height: 44px;
    font-size: var(--wp--preset--font-size--xl);
  }
}

.index-children__header-text {
  color: var(--wp--preset--color--white) !important;
  font-size: var(--wp--preset--font-size--2-xl) !important;
  text-align: center;
  line-height: 1;
}
@media (max-width: 1000px) {
  .index-children__header-text {
    font-size: var(--wp--preset--font-size--l) !important;
  }
}

.index-children__content {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
}

.index-children__subtitle {
  width: 100%;
}

.index-children__subtitle-text {
  color: var(--wp--preset--color--site-color-1) !important;
  font-size: var(--wp--preset--font-size--3-xl) !important;
  line-height: 1.5 !important;
}
@media (max-width: 1000px) {
  .index-children__subtitle-text {
    text-align: center;
    font-size: var(--wp--preset--font-size--xl) !important;
  }
}

.index-children__body {
  width: 100%;
}

.index-children__decorations {
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
  gap: var(--wp--preset--spacing--40);
  padding-right: var(--wp--preset--spacing--8);
  pointer-events: none;
}
@media (max-width: 1000px) {
  .index-children__decorations {
    display: none;
  }
}

.index-children__decoration-bottom {
  flex-shrink: 0;
  pointer-events: none;
  object-fit: contain;
}
.index-children__decoration-bottom--left {
  width: 81px;
  height: auto;
}
.index-children__decoration-bottom--right {
  width: 81px;
  height: auto;
}

.index-banner-section {
  position: relative;
}
.index-banner-section .section__inner {
  padding-bottom: var(--wp--preset--spacing--80);
  position: relative;
  gap: 72px;
}
@media (max-width: 1000px) {
  .index-banner-section .section__inner {
    padding-bottom: var(--wp--preset--spacing--40);
  }
}

.index-banner-section__decoration {
  position: absolute;
  z-index: 0;
  pointer-events: none;
  object-fit: contain;
  display: block;
}
.index-banner-section__decoration--butterfly {
  top: -80px;
  left: calc(100% - 267px);
  width: 267px;
  height: auto;
  transition: left 4s linear;
}
.index-banner-section__decoration--butterfly.is-animated {
  left: 0;
}
@media (max-width: 1000px) {
  .index-banner-section__decoration--butterfly {
    top: -32px;
    left: calc(100% - 220px);
    width: 220px;
    transition: left 4s linear;
  }
  .index-banner-section__decoration--butterfly.is-animated {
    left: 0;
  }
}
.index-banner-section__decoration--dots {
  top: 462px;
  left: calc(-140px / 1600px * 100vw);
  width: 253px;
  height: auto;
}
@media (max-width: 1000px) {
  .index-banner-section__decoration--dots {
    display: none;
  }
}
.index-banner-section__decoration--balloons {
  top: 269px;
  right: calc(-80px / 1600px * 100vw);
  width: 188px;
  height: auto;
}
@media (max-width: 1000px) {
  .index-banner-section__decoration--balloons {
    display: none;
  }
}

.index-banner-wrapper {
  position: relative;
  z-index: 1;
  max-width: 824px;
  margin: 0 auto;
  padding-top: var(--wp--preset--spacing--80);
}
@media (max-width: 1000px) {
  .index-banner-wrapper {
    padding-top: var(--wp--preset--spacing--48);
  }
}

.index-banner-grid {
  display: grid;
  grid-template-columns: repeat(2, 400px);
  gap: var(--wp--preset--spacing--24);
  width: 100%;
  justify-content: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 1000px) {
  .index-banner-grid {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--24);
  }
}

.index-banner-grid__item {
  width: 400px;
}
.index-banner-grid__item:nth-child(3) {
  grid-column: 1/-1;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .index-banner-grid__item {
    width: 100%;
  }
}

.index-banner-card {
  display: block;
  overflow: hidden;
  transition: opacity 0.3s ease;
  aspect-ratio: 400/180;
}
.index-banner-card:hover {
  opacity: 0.8;
}

.index-banner-card__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.index-banner-buttons {
  display: grid;
  grid-template-columns: repeat(2, 300px);
  gap: var(--wp--preset--spacing--24);
  width: 624px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  justify-content: center;
}
@media (max-width: 1000px) {
  .index-banner-buttons {
    width: 100%;
    grid-template-columns: 1fr;
  }
}

.index-banner-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 300px;
  height: 80px;
  border-radius: 20px;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.index-banner-button:hover {
  opacity: 0.8;
}
.index-banner-button--black {
  background-color: var(--wp--preset--color--black);
}
.index-banner-button--instagram {
  background-color: var(--wp--preset--color--index-color-instagram);
}
.index-banner-button--green {
  background-color: var(--wp--preset--color--site-color-2);
}
@media (max-width: 1000px) {
  .index-banner-button {
    width: 100%;
    height: 90px;
    padding: var(--wp--preset--spacing--12) var(--wp--preset--spacing--16);
  }
}

.index-banner-button__text {
  color: var(--wp--preset--color--white) !important;
  text-align: center;
  font-size: var(--wp--preset--font-size--3-xl) !important;
  font-weight: var(--wp--custom--font-weight--black);
  line-height: 1.2;
}
@media (max-width: 1000px) {
  .index-banner-button__text {
    font-size: var(--wp--preset--font-size--l);
  }
}

.index-banner-button__text-small {
  font-size: 18px !important;
}

.index-rich-link-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--wp--preset--spacing--24);
  max-width: 1200px;
  margin: 0 auto;
  z-index: 1;
}
@media (max-width: 1000px) {
  .index-rich-link-grid {
    grid-template-columns: repeat(1, 1fr);
  }
}

.index-rich-link-grid__item {
  width: 100%;
}

.index-rich-link {
  width: 100%;
}

.index-bottom-section {
  height: 500px;
}
@media (max-width: 1000px) {
  .index-bottom-section {
    height: 340px;
  }
}

.single-post {
  width: 100%;
}
.single-post__header {
  margin-bottom: var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .single-post__header {
    margin-bottom: var(--wp--preset--spacing--24);
  }
}
.single-post__title {
  margin-bottom: var(--wp--preset--spacing--24);
  text-align: left !important;
  justify-content: flex-start !important;
  padding-bottom: var(--wp--preset--spacing--16);
  border-bottom: 1px solid currentColor;
}
@media (max-width: 1000px) {
  .single-post__title {
    margin-bottom: var(--wp--preset--spacing--16);
    padding-bottom: var(--wp--preset--spacing--12);
  }
}
.single-post h1.heading.single-post__title {
  text-align: left !important;
  justify-content: flex-start !important;
  padding-bottom: var(--wp--preset--spacing--16);
  border-bottom: 1px solid currentColor;
}
@media (max-width: 1000px) {
  .single-post h1.heading.single-post__title {
    padding-bottom: var(--wp--preset--spacing--12);
  }
}
.single-post__meta {
  display: flex;
  align-items: center;
  gap: var(--wp--preset--spacing--16);
  margin-top: var(--wp--preset--spacing--24);
  margin-bottom: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .single-post__meta {
    margin-top: var(--wp--preset--spacing--16);
    margin-bottom: var(--wp--preset--spacing--16);
  }
}
.single-post__date {
  flex-shrink: 0;
}
.single-post__content {
  width: 100%;
  margin-bottom: var(--wp--preset--spacing--48);
}
@media (max-width: 1000px) {
  .single-post__content {
    margin-bottom: var(--wp--preset--spacing--32);
  }
}
.single-post__footer {
  margin-top: var(--wp--preset--spacing--48);
  padding-top: var(--wp--preset--spacing--48);
  border-top: 1px solid color-mix(in srgb, var(--wp--preset--color--black) 10%, transparent);
}
@media (max-width: 1000px) {
  .single-post__footer {
    margin-top: var(--wp--preset--spacing--32);
    padding-top: var(--wp--preset--spacing--32);
  }
}

.index-recruitment-card-wrapper {
  position: fixed;
  bottom: var(--wp--preset--spacing--24);
  right: var(--wp--preset--spacing--32);
  z-index: 9998;
  width: 300px;
}
@media (max-width: 1000px) {
  .index-recruitment-card-wrapper {
    bottom: var(--wp--preset--spacing--16);
    right: var(--wp--preset--spacing--16);
    width: 160px;
  }
}

.index-recruitment-card {
  width: 100%;
}

.logo {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0 10px;
  box-sizing: border-box;
  text-decoration: none;
  flex-shrink: 0;
}
@media (max-width: 1000px) {
  .logo {
    padding: 0 6px;
  }
}
.logo__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.logo__contact {
  width: 100%;
}
.logo__contact-text {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--xs);
  color: var(--wp--preset--color--site-color-1);
  text-align: center;
  margin: 0;
  line-height: 1;
}
@media (max-width: 1000px) {
  .logo__contact-text {
    display: none;
  }
}

/**
 * メニューボタンコンポーネントのスタイル
 *
 * うさぎのキャラクターと「めにゅー」テキストを表示するメニューボタン
 * PC版とSP版のレスポンシブ対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.menu-button {
  position: relative;
  display: inline-block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  outline: none;
  transition: transform 0.2s ease;
  z-index: 10001;
}
.menu-button:hover {
  transform: scale(1.05);
}
.menu-button:focus-visible {
  outline: 2px solid var(--wp--preset--color--site-color-1);
  outline-offset: 4px;
}
.menu-button--interactive:active {
  transform: scale(0.95);
}

.menu-button__container {
  position: relative;
  width: 179px;
  height: 192px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media (max-width: 1000px) {
  .menu-button__container {
    width: 90px;
    height: 96px;
  }
}

.menu-button__background {
  position: absolute;
  top: 17px;
  left: 49px;
  width: 130px;
  height: 130px;
  background-color: var(--wp--preset--color--site-color-1);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
@media (max-width: 1000px) {
  .menu-button__background {
    top: 8px;
    left: 24px;
    width: 65px;
    height: 65px;
  }
}

.menu-button__handle {
  position: absolute;
  top: 140px;
  left: 109px;
  width: 19px;
  height: 45px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/bg.svg");
}
@media (max-width: 1000px) {
  .menu-button__handle {
    top: 70px;
    left: 54px;
    width: 9px;
    height: 22px;
  }
}

.menu-button__figure {
  position: absolute;
  top: 2px;
  left: -1px;
  width: 70px;
  height: 112px;
}
@media (max-width: 1000px) {
  .menu-button__figure {
    top: 1px;
    left: 0px;
    width: 35px;
    height: 56px;
  }
}

.menu-button__figure--1 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: rotate(0deg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/figure_01.svg");
  display: block;
}
@media (max-width: 1000px) {
  .menu-button__figure--1 {
    display: block;
  }
}

.menu-button__figure--2 {
  position: absolute;
  top: 78px;
  left: 43px;
  width: 20px;
  height: 8px;
  z-index: 4;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/figure_02.svg");
}
@media (max-width: 1000px) {
  .menu-button__figure--2 {
    top: 39px;
    left: 21px;
    width: 10px;
    height: 4px;
    display: block;
  }
}

.menu-button__lines {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 61px;
  height: 34px;
  margin-top: -20px;
  z-index: 5;
}
@media (max-width: 1000px) {
  .menu-button__lines {
    width: 31px;
    height: 17px;
    margin-top: -10px;
  }
}

.menu-button__line {
  position: absolute;
  left: 50%;
  background-color: var(--wp--preset--color--white);
  border-radius: 100px;
  width: 61px;
  height: 6px;
  transform-origin: center;
  transform: translateX(-50%);
  transition: transform 0.3s ease-in-out, opacity 0.2s ease-in-out, top 0.3s ease-in-out;
}
.menu-button__line--1 {
  top: 0;
}
.menu-button__line--2 {
  top: 14px;
  transform: translate(-50%, 0);
}
.menu-button__line--3 {
  top: 28px;
  transform: translate(-50%, 0);
}
@media (max-width: 1000px) {
  .menu-button__line {
    width: 31px;
    height: 3px;
  }
  .menu-button__line--2 {
    top: 7px;
    transform: translate(-50%, 0);
  }
  .menu-button__line--3 {
    top: 14px;
    transform: translate(-50%, 0);
  }
}

.menu-button[aria-expanded=true] .menu-button__line {
  top: 50%;
  left: 50%;
  transform-origin: center center;
}
.menu-button[aria-expanded=true] .menu-button__line--1 {
  transform: translate(-50%, -50%) rotate(30deg);
}
.menu-button[aria-expanded=true] .menu-button__line--2 {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0);
  transition: opacity 0.15s ease-in-out, transform 0.15s ease-in-out;
}
.menu-button[aria-expanded=true] .menu-button__line--3 {
  transform: translate(-50%, -50%) rotate(-30deg);
}
@media (max-width: 1000px) {
  .menu-button[aria-expanded=true] .menu-button__line--1 {
    transform: translate(-50%, -50%) rotate(30deg);
  }
  .menu-button[aria-expanded=true] .menu-button__line--2 {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0);
    transition: opacity 0.15s ease-in-out, transform 0.15s ease-in-out;
  }
  .menu-button[aria-expanded=true] .menu-button__line--3 {
    transform: translate(-50%, -50%) rotate(-30deg);
  }
}
.menu-button[aria-expanded=true] .menu-button__text-content--open {
  opacity: 0;
  visibility: hidden;
}
.menu-button[aria-expanded=true] .menu-button__text-content--close {
  opacity: 1;
  visibility: visible;
}

.menu-button__text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 6;
  text-spacing-trim: normal;
  margin-top: 12px;
}
@media (max-width: 1000px) {
  .menu-button__text {
    margin-top: 6px;
  }
}

.menu-button__text-content {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: 16px;
  line-height: 1.5;
  color: var(--wp--preset--color--white);
  text-align: center;
  white-space: nowrap;
}
@media (max-width: 1000px) {
  .menu-button__text-content {
    font-size: 8px;
    line-height: 1.2;
  }
}

/**
 * ドロワーメニューコンポーネントのスタイル
 *
 * 参考サイト: https://parktowerharumi.com/
 * モバイルメニューをドロワー形式で表示
 *
 * @package yatsu
 * @since 1.0.0
 */
.drawer-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 9999;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0s 0.3s, opacity 0.3s ease;
}
.drawer-menu--open {
  visibility: visible;
  opacity: 1;
  transition: visibility 0s 0s, opacity 0.3s ease;
}
.drawer-menu--open .drawer-menu__panel {
  opacity: 1;
}
.drawer-menu--open .drawer-menu__overlay {
  opacity: 1;
}
.drawer-menu__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: color-mix(in srgb, var(--wp--preset--color--black) 50%, transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
}
.drawer-menu--open .drawer-menu__overlay {
  opacity: 1;
  transition: opacity 0.3s ease;
}
.drawer-menu__panel {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  height: 100dvh;
  background-color: color-mix(in srgb, var(--wp--preset--color--white) 96%, transparent);
  opacity: 0;
  transition: opacity 0.3s ease;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}
.drawer-menu__close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}
.drawer-menu__content {
  flex: 1;
  padding: 90px 0;
  overflow-y: auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  min-height: 0;
}
@media (max-width: 1000px) {
  .drawer-menu__content {
    padding: 0;
  }
}
.drawer-menu__list {
  list-style: none;
  margin: auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  width: 224px;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .drawer-menu__list {
    gap: var(--wp--preset--spacing--24);
  }
}
.drawer-menu__item {
  margin: 0;
  padding: 0;
  width: 100%;
}
.drawer-menu__link {
  display: block;
  color: var(--wp--preset--color--site-color-1);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--5-xl);
  font-weight: 700;
  text-decoration: none;
  text-align: center;
  transition: background-color 0.2s ease, color 0.2s ease;
}
@media (max-width: 1000px) {
  .drawer-menu__link {
    font-size: var(--wp--preset--font-size--l);
  }
}
.drawer-menu .paragraph.drawer-menu__link, .drawer-menu .paragraph.paragraph--link.drawer-menu__link {
  color: var(--wp--preset--color--site-color-1) !important;
  font-size: var(--wp--preset--font-size--5-xl) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  text-align: center;
  line-height: 1.3;
}
@media (max-width: 1000px) {
  .drawer-menu .paragraph.drawer-menu__link, .drawer-menu .paragraph.paragraph--link.drawer-menu__link {
    font-size: var(--wp--preset--font-size--l) !important;
  }
}
.drawer-menu .sub-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  background-color: color-mix(in srgb, var(--wp--preset--color--black) 2%, transparent);
}
.drawer-menu .sub-menu .drawer-menu__item {
  border-bottom: 1px solid color-mix(in srgb, var(--wp--preset--color--black) 3%, transparent);
}
.drawer-menu .sub-menu .drawer-menu__link {
  padding-left: var(--wp--preset--spacing--40);
  font-size: var(--wp--preset--font-size--s);
}

body.drawer-menu-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
}

/**
 * テキストコンポーネントのスタイル
 *
 * 本文、本文BOLD、リンク、注釈の4つのバリエーションを持つテキストコンポーネント
 * PC/SPで異なるフォントサイズとレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.text__content {
  margin: 0;
  color: var(--wp--preset--color--text-dark);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  line-height: 1.5;
}
.text--body .text__content {
  font-weight: var(--wp--custom--font-weight--medium);
  font-size: var(--wp--preset--font-size--l);
  line-height: 1.33;
}
@media (max-width: 1000px) {
  .text--body .text__content {
    font-size: var(--wp--preset--font-size--m);
  }
}
.text--body-bold .text__content {
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--xl);
  line-height: 1.33;
}
@media (max-width: 1000px) {
  .text--body-bold .text__content {
    font-size: var(--wp--preset--font-size--m);
  }
}
.text--link .text__content {
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  line-height: 1.33;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
  color: var(--wp--preset--color--text-dark);
  transition: opacity 0.2s ease;
}
.text--link .text__content:hover {
  opacity: 0.7;
}
@media (max-width: 1000px) {
  .text--link .text__content {
    font-size: var(--wp--preset--font-size--m);
  }
}
.text--caption .text__content {
  font-weight: var(--wp--custom--font-weight--regular);
  font-size: var(--wp--preset--font-size--s);
  line-height: 1.14;
  color: var(--wp--preset--color--text-dark);
}
@media (max-width: 1000px) {
  .text--caption .text__content {
    font-size: var(--wp--preset--font-size--xs);
    line-height: 1.33;
  }
}
@media (min-width: 768px) {
  .text--caption .text__content {
    width: 364px;
    height: 16px;
  }
}
@media (max-width: 1000px) {
  .text--caption .text__content {
    width: 100%;
  }
}

/**
 * 見出しコンポーネントのスタイル
 *
 * H2、H3、H4などの見出しコンポーネント
 * 左右にイラストを配置したH2とシンプルなH3に対応
 * PC版とSP版のレスポンシブ対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.heading {
  display: flex;
  width: 100%;
  margin: 0 auto;
  justify-content: center;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  color: var(--heading-color, var(--wp--preset--color--black));
  text-align: center;
}

h1.heading {
  font-size: var(--wp--preset--font-size--8-xl);
  line-height: 1;
  font-weight: var(--wp--custom--font-weight--black);
  color: var(--heading-color, var(--wp--preset--color--black));
  text-align: center;
  justify-content: center;
}
@media (max-width: 1000px) {
  h1.heading {
    font-size: var(--wp--preset--font-size--5-xl);
  }
}

h2.heading {
  font-size: var(--wp--preset--font-size--7-xl);
  line-height: 1.1;
  gap: var(--wp--preset--spacing--48);
  min-height: 85px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 1000px) {
  h2.heading {
    min-height: 63px;
    font-size: var(--wp--preset--font-size--3-xl);
    line-height: 1.23;
    gap: 10px;
  }
}
h2.heading:before, h2.heading:after {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  width: 80px;
  height: 83px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
@media (max-width: 1000px) {
  h2.heading:before, h2.heading:after {
    width: 60px;
    height: 63px;
  }
}
h2.heading::before {
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/h2-bg--left.svg");
}
h2.heading::after {
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/h2-bg--right.svg");
}

h3.heading {
  font-weight: 700;
  font-size: var(--wp--preset--font-size--5-xl);
  line-height: 1.15;
  text-align: left;
  justify-content: flex-start;
}
@media (max-width: 1000px) {
  h3.heading {
    font-size: var(--wp--preset--font-size--xl);
  }
}
h3.heading--center {
  text-align: center;
  justify-content: center;
}

h4.heading {
  position: relative;
  font-weight: 700;
  font-size: var(--wp--preset--font-size--3-xl);
  line-height: 1;
  text-align: left;
  padding-left: var(--wp--preset--spacing--8);
  border-left: 8px solid var(--heading-border-color, var(--wp--preset--color--site-color-2));
  justify-content: flex-start;
}
@media (max-width: 1000px) {
  h4.heading {
    font-size: var(--wp--preset--font-size--l);
  }
}

h5.heading {
  font-weight: 700;
  font-size: var(--wp--preset--font-size--l);
  line-height: 1.25;
  text-align: left;
  justify-content: flex-start;
}
@media (max-width: 1000px) {
  h5.heading {
    font-size: var(--wp--preset--font-size--m);
    line-height: 1.3;
  }
}

h6.heading {
  font-weight: 700;
  font-size: var(--wp--preset--font-size--2-xl);
  line-height: 1.3;
}
@media (max-width: 1000px) {
  h6.heading {
    font-size: var(--wp--preset--font-size--xl);
    line-height: 1.35;
  }
}

.section[data-color="1"] .heading {
  --heading-color: var(--wp--preset--color--site-color-1);
  --heading-border-color: var(--wp--preset--color--site-color-1);
}

.section[data-color="2"] .heading {
  --heading-color: var(--wp--preset--color--site-color-2);
  --heading-border-color: var(--wp--preset--color--site-color-2);
}

.section[data-color="3"] .heading {
  --heading-color: var(--wp--preset--color--site-color-3);
  --heading-border-color: var(--wp--preset--color--site-color-3);
}

.section[data-color="4"] .heading {
  --heading-color: var(--wp--preset--color--site-color-4);
  --heading-border-color: var(--wp--preset--color--site-color-4);
}

.section[data-color="5"] .heading {
  --heading-color: var(--wp--preset--color--site-color-1);
  --heading-border-color: var(--wp--preset--color--site-color-1);
}

.section[data-color=white] .heading {
  --heading-color: var(--wp--preset--color--white);
}

.section[data-color=black] .heading {
  --heading-color: var(--wp--preset--color--black);
}

.section[data-color=dark] .heading {
  --heading-color: var(--wp--preset--color--text-dark);
}

.heading--no-image {
  gap: 0 !important;
  min-height: 0 !important;
}
.heading--no-image:before, .heading--no-image:after {
  display: none !important;
}

h2.heading.heading--post-title {
  font-weight: 700;
  font-size: var(--wp--preset--font-size--3-xl);
  line-height: 1.5;
  text-align: left;
  justify-content: flex-start;
  gap: 0;
  min-height: 0;
  padding-bottom: var(--wp--preset--spacing--8);
  border-bottom: 1px solid currentColor;
}
@media (max-width: 1000px) {
  h2.heading.heading--post-title {
    font-size: var(--wp--preset--font-size--l);
  }
}
h2.heading.heading--post-title:before, h2.heading.heading--post-title:after {
  display: none !important;
}

.heading--border-pink {
  --heading-border-color: var(--wp--preset--color--site-color-1);
}

.heading--border-green {
  --heading-border-color: var(--wp--preset--color--site-color-2);
}

/**
 * コンテンツブロックコンポーネントのスタイル
 *
 * 見出しと本文を組み合わせたコンテンツブロックのスタイル定義
 * 画像は任意で追加可能。PC版（画像左・右）、SP版、画像なしの4つのレイアウトに対応
 *
 * @package Yatsu
 * @version 1.0.0
 */
.content-block {
  width: 100%;
  display: flex;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .content-block {
    gap: var(--wp--preset--spacing--20);
    flex-direction: column;
  }
}
.content-block__image {
  flex-shrink: 0;
  overflow: hidden;
  border-radius: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block__image {
    width: 100%;
  }
}
.content-block__image--max-384 {
  max-width: 384px;
}
@media (max-width: 1000px) {
  .content-block__image--max-384 {
    max-width: initial;
  }
}
.content-block__image-element {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.content-block__text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block__text {
    gap: var(--wp--preset--spacing--16);
  }
}
.content-block__title {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: 700;
  color: var(--wp--preset--color--site-color-2);
  margin: 0;
  line-height: 32px;
}
.content-block--left .content-block__image {
  order: 1;
}
.content-block--left .content-block__text {
  order: 2;
}
.content-block--right .content-block__image {
  order: 2;
}
@media (max-width: 1000px) {
  .content-block--right .content-block__image {
    order: 1;
  }
}
.content-block--right .content-block__text {
  order: 1;
}
.content-block--sp {
  flex-direction: column;
}
.content-block--sp .content-block__image {
  order: 1;
  width: 335px;
  height: 210px;
  align-self: flex-start;
}
.content-block--sp .content-block__text {
  order: 2;
}
.content-block--no-image .content-block__image {
  display: none;
}
.content-block--no-image .content-block__text {
  order: 1;
  width: 100%;
  margin: 0 auto;
}
.content-block--has-bottom-border {
  padding-bottom: var(--wp--preset--spacing--40);
  border-bottom: 1px dashed var(--wp--preset--color--table-border);
}
@media (max-width: 1000px) {
  .content-block--has-bottom-border {
    border-bottom: none;
    padding-bottom: 0;
  }
}
.content-block--center {
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.content-block--center .content-block__image {
  order: 1;
}
.content-block--center .content-block__text {
  order: 2;
  width: 100%;
  align-items: center;
}
.content-block--center h3.heading,
.content-block--center h4.heading,
.content-block--center h5.heading {
  text-align: center;
  justify-content: center;
}
.content-block--simple {
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .content-block--simple {
    gap: var(--wp--preset--spacing--8);
  }
}
.content-block--simple .content-block__simple-image {
  width: 100%;
  margin-top: var(--wp--preset--spacing--16);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1000px) {
  .content-block--simple .content-block__simple-image {
    margin-top: var(--wp--preset--spacing--12);
  }
}
.content-block--simple .content-block__simple-image-element {
  width: var(--image-width, 100%);
  height: var(--image-height, auto);
  object-fit: contain;
}
@media (max-width: 1000px) {
  .content-block--simple .content-block__simple-image-element {
    width: 100%;
    height: auto;
    aspect-ratio: var(--image-aspect-ratio);
  }
}
.content-block--vertical {
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block--vertical {
    gap: var(--wp--preset--spacing--16);
  }
}
.content-block--vertical .content-block__image {
  order: 1;
  width: 100%;
}
.content-block--vertical .content-block__text {
  order: 2;
  width: 100%;
}
.content-block--list {
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block--list {
    gap: var(--wp--preset--spacing--16);
  }
}
.content-block--list .content-block__title {
  margin-bottom: 0;
}
.content-block--list .content-block__list {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .content-block--list .content-block__list {
    gap: var(--wp--preset--spacing--12);
  }
}
.content-block--list .content-block__list-item {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .content-block--list .content-block__list-item {
    gap: var(--wp--preset--spacing--8);
  }
}
.content-block--list .content-block__list-heading {
  margin-bottom: 0;
  color: var(--wp--preset--color--site-color-2);
  justify-content: flex-start;
  text-align: left;
}
.content-block--list .content-block__list-content {
  margin: 0;
}
.content-block--list .content-block__list-link {
  color: var(--wp--preset--color--site-color-2);
  text-decoration: underline;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--medium);
  font-size: var(--wp--preset--font-size--l);
  line-height: 24px;
}
@media (max-width: 1000px) {
  .content-block--list .content-block__list-link {
    font-size: var(--wp--preset--font-size--m);
    line-height: 24px;
  }
}
.content-block--list .content-block__list-link:hover {
  text-decoration: none;
}
.content-block--container {
  align-items: flex-start;
}
.content-block--container .content-block__image {
  order: 1;
  flex-shrink: 0;
}
.content-block--container .content-block__text {
  order: 2;
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block--container .content-block__text {
    gap: var(--wp--preset--spacing--16);
  }
}
.content-block--container .content-block__containers {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .content-block--container .content-block__containers {
    gap: var(--wp--preset--spacing--16);
  }
}
.content-block--container .content-block__container {
  display: flex;
  flex-direction: column;
}
.content-block--container .content-block__container-content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
}

/**
 * プロフィール（画像＋テキスト）コンポーネント スタイル
 */
.profile {
  display: flex;
  align-items: center;
  gap: var(--wp--preset--spacing--64);
}
@media (max-width: 1000px) {
  .profile {
    padding-top: var(--wp--preset--spacing--24);
    gap: var(--wp--preset--spacing--16);
    flex-direction: column;
  }
}
.profile__text {
  white-space: nowrap;
  text-align: right;
}
@media (max-width: 1000px) {
  .profile__text {
    order: 1;
    text-align: center;
  }
}
.profile__image {
  width: 200px;
  height: 200px;
  flex: 0 0 auto;
  border-radius: 50%;
  overflow: hidden;
}
.profile__image-el {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.profile--reverse {
  flex-direction: row-reverse;
}
.profile--reverse .profile__text {
  text-align: right;
}

.profile--align-right {
  width: 100%;
  justify-content: flex-end;
}
.profile--align-right .profile__text {
  text-align: right;
}

/**
 * パラグラフコンポーネントのスタイル
 *
 * 本文、本文BOLD、リンク、注釈の4つのバリエーションを持つパラグラフコンポーネント
 * PC/SPで異なるフォントサイズとレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.paragraph {
  margin: 0;
  color: var(--wp--preset--color--text-dark);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  line-height: 24px;
}
.paragraph--body {
  font-weight: var(--wp--custom--font-weight--medium);
  font-size: var(--wp--preset--font-size--l);
}
@media (max-width: 1000px) {
  .paragraph--body {
    font-size: var(--wp--preset--font-size--m);
  }
}
.paragraph--body-bold {
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
}
@media (max-width: 1000px) {
  .paragraph--body-bold {
    font-size: var(--wp--preset--font-size--m);
  }
}
.paragraph--center {
  text-align: center;
}
.paragraph--link {
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-position: from-font;
  color: var(--wp--preset--color--site-color-2);
  transition: opacity 0.2s ease;
}
@media (max-width: 1000px) {
  .paragraph--link {
    font-size: var(--wp--preset--font-size--m);
  }
}
.paragraph--link:hover {
  text-decoration: none;
}
.paragraph--tel-link {
  font-size: var(--wp--preset--font-size--l);
  text-decoration: none;
}
@media (max-width: 1000px) {
  .paragraph--tel-link {
    font-size: var(--wp--preset--font-size--m);
  }
}
@media (min-width: 1001px) {
  .paragraph--tel-link {
    font-weight: var(--wp--custom--font-weight--medium);
    color: var(--wp--preset--color--text-dark);
  }
}
.paragraph--caption {
  font-weight: var(--wp--custom--font-weight--regular);
  font-size: var(--wp--preset--font-size--s);
  line-height: 16px;
  color: var(--wp--preset--color--text-dark);
}
@media (max-width: 1000px) {
  .paragraph--caption {
    font-size: var(--wp--preset--font-size--xs);
    line-height: normal;
  }
}

@media (hover: hover) {
  a:where([href^="tel:"]) {
    pointer-events: none;
    cursor: default;
  }
}
/**
 * テーブルコンポーネントのスタイル
 *
 * ラベルと値を表示するテーブル行のスタイル定義
 * Normal、Short、枠ありの3つのスタイルバリエーション
 * PC/SPで異なるレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.table {
  display: flex;
  align-items: center;
  width: 100%;
  padding: var(--wp--preset--spacing--8) 0;
}
.table-wrapper {
  display: flex;
  flex-direction: column;
}
h2 + .table-wrapper__inner, h3 + .table-wrapper__inner, h5 + .table-wrapper__inner, h6 + .table-wrapper__inner {
  margin-top: var(--wp--preset--spacing--24);
}
h4 + .table-wrapper__inner {
  margin-top: var(--wp--preset--spacing--8);
}
h4 + .table-wrapper__inner:has(.table--bordered) {
  margin-top: var(--wp--preset--spacing--24);
}
.table-wrapper__inner--has-rowspan {
  display: grid;
  grid-template-columns: 182px repeat(var(--table-columns, 3), 1fr);
}
@media (max-width: 1000px) {
  .table-wrapper__inner--has-rowspan {
    grid-template-columns: 1fr;
  }
}
.table-wrapper__inner--has-rowspan[data-columns="1"] {
  grid-template-columns: 182px 1fr;
}
.table-wrapper__inner--has-rowspan[data-columns="2"] {
  grid-template-columns: 182px repeat(2, 1fr);
}
.table-wrapper__inner--has-rowspan[data-columns="3"] {
  grid-template-columns: 182px repeat(3, 1fr);
}
.table-wrapper__inner--has-rowspan[data-columns="4"] {
  grid-template-columns: 182px repeat(4, 1fr);
}
.table-wrapper__inner--has-rowspan[data-columns="5"] {
  grid-template-columns: 182px repeat(5, 1fr);
}
.table-wrapper__inner--has-rowspan[data-columns="6"] {
  grid-template-columns: 182px repeat(6, 1fr);
}
.table__label {
  flex-shrink: 0;
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.table__value {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .table__value {
    font-size: var(--wp--preset--font-size--l);
    line-height: 24px;
    padding-left: var(--wp--preset--spacing--8);
  }
}
.table__value strong {
  font-weight: var(--wp--custom--font-weight--black);
}
.table__value .text--red {
  color: var(--wp--preset--color--red);
  font-weight: 700;
}
.table__value--header {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
}
.table__value--header .paragraph {
  color: var(--wp--preset--color--white);
}
.table--normal {
  gap: var(--wp--preset--spacing--24);
  border-bottom: 1px dashed #c6c6c6;
  align-items: stretch;
}
@media (max-width: 1000px) {
  .table--normal {
    flex-direction: column;
    gap: 8px;
    border-bottom: none;
  }
}
.table--normal .table__label {
  width: 200px;
  font-size: var(--wp--preset--font-size--l);
  line-height: 24px;
  padding: var(--wp--preset--spacing--4) 0;
}
@media (max-width: 1000px) {
  .table--normal .table__label {
    width: 100%;
    font-size: var(--wp--preset--font-size--m);
  }
}
@media (max-width: 1000px) {
  .table--normal .table__value {
    padding-left: 0;
    width: 100%;
  }
}
.table--short {
  gap: var(--wp--preset--spacing--24);
  border-bottom: 1px dashed #c6c6c6;
}
@media (max-width: 1000px) {
  .table--short {
    gap: var(--wp--preset--spacing--8);
  }
}
.table--short .table__label {
  width: 160px;
  font-size: var(--wp--preset--font-size--s);
  line-height: 24px;
}
@media (max-width: 1000px) {
  .table--short .table__label {
    width: 90px;
    font-size: var(--wp--preset--font-size--m);
    line-height: 38px;
  }
}
.table--bordered {
  align-items: stretch;
  gap: 0;
  padding: 0;
}
.table--bordered:last-child {
  border-bottom: 1px solid var(--wp--preset--color--table-border);
}
.table-wrapper__inner--has-rowspan .table--bordered {
  display: contents;
}
@media (max-width: 1000px) {
  .table--bordered {
    flex-direction: column;
    justify-content: center;
  }
}
.table--bordered .table__label {
  width: 182px;
  border-top: 1px solid var(--wp--preset--color--table-border);
  font-size: var(--wp--preset--font-size--l);
  line-height: 24px;
  padding: var(--wp--preset--spacing--8) 0;
}
@media (max-width: 1000px) {
  .table--bordered .table__label {
    width: 100%;
    flex: 1;
    min-height: 80px;
  }
}
.table--bordered .table__value {
  background-color: var(--wp--preset--color--white);
  border-top: 1px solid var(--wp--preset--color--table-border);
  border-right: 1px solid var(--wp--preset--color--table-border);
  padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
  padding-right: var(--wp--preset--spacing--16);
  flex: 1;
}
@media (max-width: 1000px) {
  .table--bordered .table__value {
    border-left: 1px solid var(--wp--preset--color--table-border);
    border-top: none;
    width: 100%;
    padding-left: var(--wp--preset--spacing--16);
    padding-right: var(--wp--preset--spacing--16);
  }
}
.table--bordered .table__value--header {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
  border-right: 1px solid var(--wp--preset--color--table-border);
}
.table--bordered .table__value--header .paragraph {
  color: var(--wp--preset--color--white);
}
.table--bordered .table__value[data-colspan="2"] {
  flex: 2;
}
.table--bordered .table__value[data-colspan="3"] {
  flex: 3;
}
.table--bordered .table__value[data-colspan="4"] {
  flex: 4;
}
.table--bordered .table__value[data-colspan="5"] {
  flex: 5;
}
.table--bordered .table__value[data-colspan="6"] {
  flex: 6;
}
.table--bordered .table__value[data-rowspan="2"] {
  align-self: stretch;
  display: flex;
  flex-direction: column;
}
.table--bordered .table__value[data-rowspan="3"] {
  align-self: stretch;
  display: flex;
  flex-direction: column;
}
.table--bordered .table__value[data-rowspan="4"] {
  align-self: stretch;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1000px) {
  .table--bordered .table__value + .table__value {
    border-left: 1px solid var(--wp--preset--color--table-border);
    border-top: 1px solid var(--wp--preset--color--table-border);
  }
}

.table--bordered-html {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--wp--preset--color--table-border);
}
.table--bordered-html th,
.table--bordered-html td {
  border: 1px solid var(--wp--preset--color--table-border);
  padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
  vertical-align: top;
}
.table--bordered-html th {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
  width: 182px;
}
@media (max-width: 1000px) {
  .table--bordered-html th {
    width: 100%;
    display: block;
  }
}
.table--bordered-html th.table__label--header {
  display: none;
}
.table--bordered-html td {
  background-color: var(--wp--preset--color--white);
}
@media (max-width: 1000px) {
  .table--bordered-html td {
    display: block;
    width: 100%;
    border-left: 1px solid var(--wp--preset--color--table-border);
    border-top: none;
  }
}
.table--bordered-html td.table__value--header {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
}
.table--bordered-html td.table__value--header .paragraph {
  color: var(--wp--preset--color--white);
}
@media (max-width: 1000px) {
  .table--bordered-html {
    display: block;
    border: none;
  }
  .table--bordered-html tr {
    display: block;
    border-top: 1px solid var(--wp--preset--color--table-border);
    border-bottom: 1px solid var(--wp--preset--color--table-border);
    margin-bottom: var(--wp--preset--spacing--8);
  }
}

.table--bordered-html {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--wp--preset--color--table-border);
}
.table--bordered-html th,
.table--bordered-html td {
  border: 1px solid var(--wp--preset--color--table-border);
  padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
  vertical-align: top;
}
.table--bordered-html th {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
  width: 182px;
}
@media (max-width: 1000px) {
  .table--bordered-html th {
    width: 100%;
    display: block;
  }
}
.table--bordered-html th.table__label--header {
  display: none;
}
.table--bordered-html td {
  background-color: var(--wp--preset--color--white);
}
@media (max-width: 1000px) {
  .table--bordered-html td {
    display: block;
    width: 100%;
    border-left: 1px solid var(--wp--preset--color--table-border);
    border-top: none;
  }
}
.table--bordered-html td.table__value--header {
  background-color: var(--table-label-bg-color, var(--wp--preset--color--site-color-2));
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
}
.table--bordered-html td.table__value--header .paragraph {
  color: var(--wp--preset--color--white);
}
@media (max-width: 1000px) {
  .table--bordered-html {
    display: block;
    border: none;
  }
  .table--bordered-html tr {
    display: block;
    border-top: 1px solid var(--wp--preset--color--table-border);
    border-bottom: 1px solid var(--wp--preset--color--table-border);
    margin-bottom: var(--wp--preset--spacing--8);
  }
}

.section[data-color="1"] .table__label,
.section[data-color="1"] .table--bordered-html th {
  --table-label-bg-color: var(--wp--preset--color--site-color-1);
}

.section[data-color="2"] .table__label,
.section[data-color="2"] .table--bordered-html th {
  --table-label-bg-color: var(--wp--preset--color--site-color-2);
}

.section[data-color="3"] .table__label,
.section[data-color="3"] .table--bordered-html th {
  --table-label-bg-color: var(--wp--preset--color--site-color-3);
}

.section[data-color="4"] .table__label,
.section[data-color="4"] .table--bordered-html th {
  --table-label-bg-color: var(--wp--preset--color--site-color-4);
}

.educational-goals__sub-contents {
  padding: var(--wp--preset--spacing--40);
  width: calc(100% + var(--wp--preset--spacing--24) * 2);
  margin: 0 calc(var(--wp--preset--spacing--24) * -1);
}
@media (max-width: 1000px) {
  .educational-goals__sub-contents {
    padding: var(--wp--preset--spacing--20);
    margin: 0;
    width: 100%;
  }
}

.educational-goals__sub-content {
  display: flex;
  gap: var(--wp--preset--spacing--20);
  margin: 0 auto;
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-content {
    flex-direction: column;
    gap: var(--wp--preset--spacing--16);
    align-items: center;
  }
}

.educational-goals__sub-left {
  width: 520px;
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-left {
    width: 100%;
    align-items: center;
  }
}

.educational-goals__sub-phrase {
  display: flex;
  height: 160px;
  justify-content: space-between;
  margin-bottom: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-phrase {
    flex-direction: column;
    height: auto;
    gap: var(--wp--preset--spacing--16);
    width: 100%;
    align-items: center;
  }
}

.educational-goals__sub-logo {
  position: relative;
  width: 200px;
  height: 160px;
}
@media (max-width: 1000px) {
  .educational-goals__sub-logo {
    width: 100%;
    height: 165px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
}

.educational-goals__sub-logo-heart {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 200px;
  height: 160px;
  display: block;
  color: inherit;
}
@media (max-width: 1000px) {
  .educational-goals__sub-logo-heart {
    width: 200px;
    height: 160px;
    top: 0;
    position: relative;
    transform: none;
    left: auto;
  }
}

.educational-goals__sub-logo-label {
  position: absolute;
  left: 66px;
  top: 40px;
  margin: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-logo-label {
    position: absolute;
    left: 50%;
    top: 48px;
    transform: translateX(-50%);
    text-align: center;
  }
}

.educational-goals__sub-logo-text {
  position: absolute;
  left: 50%;
  top: 70px;
  transform: translateX(-50%);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: 48px;
  line-height: var(--wp--preset--spacing--40);
  text-align: center;
  margin: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-logo-text {
    top: 74px;
  }
}

.educational-goals__sub-phrase-content {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--12);
  width: 320px;
  justify-content: center;
  align-items: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-phrase-content {
    width: 100%;
    gap: 0;
  }
}

.educational-goals__sub-phrase-label {
  text-align: center;
}

@media (min-width: 1001px) {
  .educational-goals__sub-phrase-title {
    gap: 0 !important;
    min-height: 0 !important;
  }
  .educational-goals__sub-phrase-title:before, .educational-goals__sub-phrase-title:after {
    display: none !important;
  }
}

.educational-goals__sub-body {
  height: 160px;
  display: flex;
  flex-direction: column;
}
.educational-goals__sub-body p {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--medium);
  font-size: var(--wp--preset--font-size--m);
  line-height: var(--wp--preset--spacing--24);
  color: var(--wp--preset--color--text-dark);
  margin: 0;
}
.educational-goals__sub-body p:last-child {
  margin-bottom: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-body {
    height: auto;
    margin-top: var(--wp--preset--spacing--16);
    width: 100%;
  }
}

.educational-goals__sub-right {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--20);
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-right {
    width: 100%;
    align-items: center;
    gap: var(--wp--preset--spacing--16);
  }
}
@media (min-width: 1001px) {
  .educational-goals__sub-right--pairs {
    min-width: fit-content;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: var(--wp--preset--spacing--20);
    align-items: flex-start;
  }
}

.educational-goals__sub-description {
  padding: 0 var(--wp--preset--spacing--20);
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-description {
    height: auto;
    padding: var(--wp--preset--spacing--16) 0 0;
    width: 100%;
  }
}
.educational-goals__sub-description--items {
  height: auto;
  justify-content: flex-start;
  gap: var(--wp--preset--spacing--20);
}
@media (max-width: 1000px) {
  .educational-goals__sub-description--items {
    flex-direction: column;
    gap: var(--wp--preset--spacing--16);
  }
}

.educational-goals__sub-description-item {
  width: 165px;
  flex-shrink: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-description-item {
    width: 100%;
  }
}

.educational-goals__sub-images {
  display: flex;
  gap: var(--wp--preset--spacing--20);
  padding: 0 var(--wp--preset--spacing--20);
  align-items: center;
  margin-top: auto;
  flex-wrap: nowrap;
  justify-content: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-images {
    flex-direction: column;
    padding: 0;
    gap: var(--wp--preset--spacing--16);
    width: 100%;
    margin-top: 0;
  }
}
.educational-goals__sub-images--single {
  padding: 0;
}
.educational-goals__sub-images--single .educational-goals__sub-image {
  width: 350px;
  height: 220px;
}
@media (max-width: 1000px) {
  .educational-goals__sub-images--single .educational-goals__sub-image {
    width: 100%;
    height: auto;
    aspect-ratio: 350/220;
  }
}

.educational-goals__sub-image-pair {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--20);
  align-items: center;
  width: 165px;
  flex-shrink: 0;
}
@media (max-width: 1000px) {
  .educational-goals__sub-image-pair {
    gap: var(--wp--preset--spacing--16);
    width: 100%;
  }
}

.educational-goals__sub-image-label {
  display: flex;
  align-items: center;
  justify-content: center;
}
.educational-goals__sub-image-label .paragraph {
  text-align: center;
}
@media (max-width: 1000px) {
  .educational-goals__sub-image-label {
    width: 100%;
  }
}

.educational-goals__sub-image {
  width: 165px;
  height: 260px;
  overflow: hidden;
  flex-shrink: 0;
  border-radius: 24px;
}
.educational-goals__sub-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
@media (max-width: 1000px) {
  .educational-goals__sub-image {
    width: 165px;
    height: 260px;
  }
}

.educational-goals__sub-contents--chi {
  background-color: #d3f5ff;
}
.educational-goals__sub-contents--chi .educational-goals__sub-logo-heart,
.educational-goals__sub-contents--chi .educational-goals__sub-logo-label,
.educational-goals__sub-contents--chi .educational-goals__sub-logo-text,
.educational-goals__sub-contents--chi .educational-goals__sub-phrase-label,
.educational-goals__sub-contents--chi .educational-goals__sub-phrase-title {
  color: var(--wp--preset--color--site-color-4);
}

.educational-goals__sub-contents--toku {
  background-color: #ffe6ed;
}
.educational-goals__sub-contents--toku .educational-goals__sub-logo-heart,
.educational-goals__sub-contents--toku .educational-goals__sub-logo-label,
.educational-goals__sub-contents--toku .educational-goals__sub-logo-text,
.educational-goals__sub-contents--toku .educational-goals__sub-phrase-label,
.educational-goals__sub-contents--toku .educational-goals__sub-phrase-title {
  color: var(--wp--preset--color--site-color-1);
}
.educational-goals__sub-contents--toku .educational-goals__sub-phrase-label {
  text-align: left;
}

.educational-goals__sub-contents--tai {
  background-color: #daf0c9;
}
.educational-goals__sub-contents--tai .educational-goals__sub-logo-heart,
.educational-goals__sub-contents--tai .educational-goals__sub-logo-label,
.educational-goals__sub-contents--tai .educational-goals__sub-logo-text,
.educational-goals__sub-contents--tai .educational-goals__sub-phrase-label,
.educational-goals__sub-contents--tai .educational-goals__sub-phrase-title {
  color: var(--wp--preset--color--site-color-2);
}

/**
 * スケジュールリストコンポーネントのスタイル
 *
 * 時間割表のスタイル定義
 * ヘッダーの色を変更可能、リストの数は増減可能
 * PC/SPで異なるレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.schedule-list-wrapper {
  position: relative;
  display: flex;
  justify-content: center;
  width: 420px;
}
@media (max-width: 1000px) {
  .schedule-list-wrapper {
    width: 100%;
  }
}
.schedule-list-wrapper .schedule-list__illustration-image {
  position: absolute;
  z-index: -1;
  pointer-events: none;
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.schedule-list-wrapper .schedule-list__illustration-image.schedule-list__illustration--rabbit {
  bottom: 7px;
  left: -91px;
  aspect-ratio: 116/187;
  width: 116px;
  height: 187px;
}
.schedule-list-wrapper .schedule-list__illustration-image.schedule-list__illustration--chick {
  bottom: 10px;
  aspect-ratio: 109/142;
  right: -83px;
  width: 109px;
  height: 142px;
}
@media (max-width: 1000px) {
  .schedule-list-wrapper .schedule-list__illustration-image {
    display: none;
  }
}
.schedule-list-wrapper .schedule-list__hand {
  position: absolute;
  pointer-events: none;
  z-index: 2;
}
.schedule-list-wrapper .schedule-list__hand--rabbit {
  bottom: 43px;
  left: -23px;
  width: 45px;
  height: 17px;
}
.schedule-list-wrapper .schedule-list__hand--chick {
  bottom: 51px;
  right: -40px;
  width: 53px;
  height: 30px;
}
.schedule-list-wrapper .schedule-list__hand-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
@media (max-width: 1000px) {
  .schedule-list-wrapper .schedule-list__hand {
    display: none;
  }
}

.schedule-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
  background-color: var(--wp--preset--color--white);
  border: 1px solid;
}
.schedule-list__header {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 72px;
  width: 100%;
}
.schedule-list__header-text {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: 700;
  font-size: var(--wp--preset--font-size--3-xl);
  color: var(--wp--preset--color--white);
  text-align: center;
  line-height: 24px;
  margin: 0;
}
.schedule-list__content {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  width: 100%;
  padding-bottom: var(--wp--preset--spacing--16);
}
.schedule-list__item {
  display: flex;
  align-items: center;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
  padding: var(--wp--preset--spacing--16) 0;
  border-bottom: 1px dashed #c6c6c6;
}
.schedule-list__item--last {
  border-bottom: none;
}
.schedule-list__time {
  flex-shrink: 0;
  width: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.schedule-list__time .schedule-list__time-text {
  text-align: center;
}
.schedule-list__activity {
  flex: 1;
  min-width: 0;
}

/**
 * 画像コンポーネントのスタイル
 *
 * 様々なサイズバリエーションに対応した画像表示コンポーネントのスタイル定義
 * PC版・SP版それぞれで全幅、1カラム、2カラム、3カラム、4カラム、スクエアのサイズに対応
 *
 * @package Yatsu
 * @version 1.0.0
 */
.image {
  max-width: 100%;
  height: auto;
  overflow: hidden;
  border-radius: 24px;
}
.image__element {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border-radius: 24px;
}
.image__placeholder {
  width: 100%;
  height: 100%;
  background-color: #c6c6c6;
  border-radius: 24px;
}
.image--full-width.image--pc {
  width: 100%;
  max-width: 1600px;
  height: 409px;
}
.image--1-column {
  width: 100%;
  height: 532px;
}
@media (max-width: 1000px) {
  .image--1-column {
    aspect-ratio: 335/210;
    height: auto;
  }
}
.image--2-column {
  aspect-ratio: 588/368;
}
.image--3-column {
  width: 100%;
  max-width: 384px;
  height: 241px;
}
.image--4-column.image--pc {
  width: 100%;
  max-width: 285px;
  height: 181px;
}
.image--square {
  width: 180px;
  height: 180px;
  border-radius: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .image--square {
    width: 100%;
  }
}
.image--full-width.image--sp {
  width: 100%;
  max-width: 335px;
  height: 170px;
}
.image--1-column.image--sp {
  width: 100%;
  max-width: 335px;
  height: 210px;
  border-radius: 80px;
}
.image--1-column.image--sp .image__element,
.image--1-column.image--sp .image__placeholder {
  border-radius: 80px;
}
.image--2-column.image--sp {
  width: 100%;
  max-width: 159.783px;
  height: 100px;
}
.image--3-column.image--sp {
  width: 100%;
  max-width: 105.789px;
  height: 66.394px;
}
@media (max-width: 1000px) {
  .image--full-width:not(.image--pc):not(.image--sp) {
    width: 100%;
    aspect-ratio: 335/210;
  }
  .image--2-column:not(.image--pc):not(.image--sp) {
    width: 100%;
    height: auto;
  }
  .image--3-column:not(.image--pc):not(.image--sp) {
    width: 100%;
    aspect-ratio: 300/188;
    height: auto;
  }
  .image--4-column:not(.image--pc):not(.image--sp) {
    width: 100%;
    max-width: 105.789px;
    height: 66.394px;
  }
  .image--full-width.image--pc {
    width: 100%;
    max-width: 335px;
    height: 170px;
  }
  .image--1-column.image--pc {
    width: 100%;
    max-width: 335px;
    height: 210px;
  }
  .image--2-column.image--pc {
    width: 100%;
    max-width: 159.783px;
    height: 100px;
  }
  .image--4-column.image--pc {
    width: 100%;
    max-width: 105.789px;
    height: 66.394px;
  }
}

/**
 * コンテンツカードコンポーネントのスタイル
 *
 * 見出し、画像、テキストを含むコンテンツカードコンポーネント
 * 見出しのボーダー色を変更可能、画像とテキストは親から指定可能
 * PC/SPで異なるレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.content-card {
  display: flex;
  flex-direction: column;
  width: 100%;
  gap: var(--wp--preset--spacing--16);
}
.content-card__image-wrapper {
  width: 100%;
}
.content-card__image {
  width: 100%;
}
.content-card__text-wrapper {
  width: 100%;
}
.content-card__text {
  margin: 0;
}

/**
 * 動画カードコンポーネントのスタイル
 *
 * YouTube、Vimeo、または直接動画ファイルを埋め込むコンポーネントのスタイル定義
 * PC版とSP版のサイズに対応
 *
 * @package Yatsu
 * @version 1.0.0
 */
.video-card {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
  flex: 1;
  min-width: 0;
}
.video-card__wrapper {
  width: 100%;
  aspect-ratio: 384/241;
  border-radius: var(--wp--preset--spacing--24);
  overflow: hidden;
  background-color: #c6c6c6;
  position: relative;
}
.video-card__iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}
.video-card__title {
  width: 100%;
}
.video-card__title .heading {
  justify-content: flex-start;
  text-align: left;
  margin-bottom: 0;
}
.video-card__paragraph {
  width: 100%;
  color: var(--wp--preset--color--site-color-2);
  text-align: center;
}
.video-card__paragraph .paragraph {
  margin-bottom: 0;
}

/**
 * テキストリストコンポーネントのスタイル
 *
 * @package yatsu
 * @since 1.0.0
 */
.text-list {
  margin: 0;
  list-style: none;
}
.text-list--vertical {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.text-list--horizontal {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .text-list--horizontal {
    flex-direction: column;
    gap: var(--wp--preset--spacing--8);
  }
}
.text-list__item {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--wp--preset--spacing--4);
}
@media (max-width: 1000px) {
  .text-list__item {
    font-size: var(--wp--preset--font-size--m);
  }
}
.text-list__item::before {
  content: "●";
  color: var(--wp--preset--color--site-color-3);
  font-size: var(--wp--preset--font-size--m);
}
@media (max-width: 1000px) {
  .text-list__item::before {
    font-size: var(--wp--preset--font-size--m);
  }
}
.text-list--vertical .text-list__item + .text-list--vertical .text-list__item {
  margin-top: var(--wp--preset--spacing--12);
}
@media (max-width: 1000px) {
  .text-list--vertical .text-list__item + .text-list--vertical .text-list__item {
    margin-top: var(--wp--preset--spacing--8);
  }
}

/**
 * 日記カードコンポーネントのスタイル
 *
 * 記事一覧ページで使用する日記カードコンポーネント
 * サムネイル画像、タイトル、投稿日、カテゴリー、抜粋、続きを読むリンクを含む
 * PC/SPで異なるレイアウトに対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.diary-card {
  position: relative;
}
.diary-card__link {
  display: flex;
  flex-direction: row;
  width: 100%;
  gap: var(--wp--preset--spacing--24);
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  transition: opacity 0.2s ease-in-out;
}
@media (max-width: 1000px) {
  .diary-card__link {
    flex-direction: column;
  }
}
@media (any-hover: hover) {
  .diary-card__link {
    opacity: 0.9;
  }
}
.diary-card__thumbnail {
  flex-shrink: 0;
}
@media (max-width: 1000px) {
  .diary-card__thumbnail {
    width: 100%;
  }
}
.diary-card__content {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
  min-width: 0;
}
@media (max-width: 1000px) {
  .diary-card__content {
    width: 100%;
  }
}
.diary-card__header {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.diary-card__meta {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--4);
}
.diary-card__title {
  margin: 0;
  color: var(--wp--preset--color--site-color-2);
  padding-bottom: var(--wp--preset--spacing--16);
  border-bottom: 1px solid var(--wp--preset--color--site-color-2);
}
.diary-card__excerpt {
  width: 100%;
}
.diary-card__excerpt-text {
  margin: 0;
}
.diary-card__footer {
  margin-top: auto;
  display: flex;
  justify-content: flex-end;
}
.diary-card__read-more .text__content {
  color: var(--wp--preset--color--site-color-2);
}

/**
 * 写真ギャラリーカードコンポーネント
 *
 * @package Yatsu
 * @since 1.0.0
 */
.photo-gallery-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--wp--preset--spacing--8);
  padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
  background-color: var(--wp--preset--color--white);
  border: 1px solid var(--wp--preset--color--table-border);
  border-width: 0 1px 1px 0;
}
.photo-gallery-card__title {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--l);
  color: var(--wp--preset--color--text-dark);
  font-weight: var(--wp--custom--font-weight--medium);
  text-align: center;
  margin: 0;
}
@media (max-width: 1000px) {
  .photo-gallery-card__title {
    font-size: var(--wp--preset--font-size--m);
  }
}

/**
 * ボタンコンポーネント
 *
 * @package Yatsu
 * @since 1.0.0
 */
.button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 200px;
  height: 56px;
  padding: 0 var(--wp--preset--spacing--24);
  border-radius: 9999px;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--m);
  text-decoration: none;
  transition: opacity 0.2s ease;
}
@media (max-width: 1000px) {
  .button {
    min-width: 160px;
    height: 48px;
    padding: 0 var(--wp--preset--spacing--16);
    font-size: var(--wp--preset--font-size--s);
  }
}
.button:hover {
  opacity: 0.8;
}

.button__text {
  text-align: center;
}

.button__icon {
  position: absolute;
  right: var(--wp--preset--spacing--24);
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 24px;
  height: 24px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
@media (max-width: 1000px) {
  .button__icon {
    right: var(--wp--preset--spacing--16);
  }
}

.button--primary {
  background-color: var(--wp--preset--color--site-color-3);
  color: var(--wp--preset--color--white);
}
.button--primary .button__icon {
  filter: brightness(0) invert(1);
}

.button--secondary {
  background-color: var(--wp--preset--color--site-color-1);
  color: var(--wp--preset--color--white);
}
.button--secondary .button__icon {
  filter: brightness(0) invert(1);
}

.button--outline {
  background-color: var(--wp--preset--color--white);
  color: var(--wp--preset--color--site-color-3);
  border: 2px solid var(--wp--preset--color--site-color-3);
}
.button--outline .button__icon {
  filter: brightness(0) saturate(100%) invert(56%) sepia(57%) saturate(1037%) hue-rotate(298deg) brightness(96%) contrast(93%);
}

.button--large {
  height: 64px;
  padding: 0 var(--wp--preset--spacing--32);
  justify-content: flex-start;
  font-size: var(--wp--preset--font-size--l);
}
@media (max-width: 1000px) {
  .button--large {
    min-width: inherit;
    height: auto;
    padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--56);
  }
}
.button--large .button__text {
  text-align: left;
}
.button--large .button__icon {
  right: var(--wp--preset--spacing--16);
}
@media (max-width: 1000px) {
  .button--large .button__icon {
    right: var(--wp--preset--spacing--24);
  }
}

.button--small {
  min-width: 160px;
  height: 32px;
  padding: 0 var(--wp--preset--spacing--12);
  font-size: var(--wp--preset--font-size--l);
}
.button--small .button__icon {
  right: var(--wp--preset--spacing--12);
}

.button--index-diary {
  width: 515px;
  max-width: 100%;
  justify-content: center;
}
.button--index-diary .button__text {
  text-align: center;
}

.button--index-info {
  width: 515px;
  max-width: 100%;
  justify-content: center;
}
.button--index-info .button__text {
  text-align: center;
}

/**
 * 施設カードコンポーネント
 *
 * @package Yatsu
 * @since 1.0.0
 */
.facility-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--wp--preset--spacing--8);
  text-decoration: none;
  cursor: pointer;
}
@media (any-hover: hover) {
  .facility-card .facility-card__image img {
    transform: scale(1.05);
  }
}
.facility-card__image {
  width: 100%;
  aspect-ratio: 280/180;
  overflow: hidden;
  border-radius: 16px;
}
.facility-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.facility-card__caption {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: var(--wp--custom--font-weight--medium);
  color: var(--wp--preset--color--text-dark);
  text-align: center;
  margin: 0;
}
@media (max-width: 1000px) {
  .facility-card__caption {
    font-size: var(--wp--preset--font-size--s);
  }
}

/**
 * テキストマーキーコンポーネントのスタイル
 *
 * 文字が無限ループで流れる
 *
 * @package yatsu
 * @since 1.0.0
 */
.marquee-text {
  position: relative;
  width: 100%;
  overflow: hidden;
  height: fit-content;
}

.marquee-text__track {
  display: flex;
  width: fit-content;
  gap: var(--wp--preset--spacing--24);
  animation: marquee-text-scroll var(--marquee-speed, 20s) linear infinite;
}

.marquee-text__content {
  flex-shrink: 0;
  white-space: nowrap;
  font-family: var(--wp--preset--font-family--noto-sans);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: 160px;
  color: var(--wp--preset--color--index-color-runner-text);
  line-height: 1;
  text-box-trim: trim-both;
}
@media (max-width: 1000px) {
  .marquee-text__content {
    font-size: 110px;
  }
}

.marquee-text--reverse .marquee-text__track {
  animation-direction: reverse;
}

@keyframes marquee-text-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}
/**
 * マーキーギャラリーコンポーネントのスタイル
 *
 * 画像を無限スクロールで表示
 *
 * @package yatsu
 * @since 1.0.0
 */
.marquee-gallery {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-top: 160px;
  z-index: 1;
}
@media (max-width: 1000px) {
  .marquee-gallery {
    height: 341px;
  }
}

.marquee-gallery__track {
  display: flex;
  width: fit-content;
  animation: marquee-scroll var(--marquee-speed, 30s) linear infinite;
}

.marquee-gallery__content {
  flex-shrink: 0;
  width: 2900px;
}
@media (max-width: 1000px) {
  .marquee-gallery__content {
    width: 2044px;
    height: 341px;
  }
}

.marquee-gallery__image {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 1000px) {
  .marquee-gallery__image {
    width: 100%;
    height: 341px;
    object-fit: contain;
    object-position: left center;
  }
}

@media (max-width: 1000px) {
  .marquee-gallery__track {
    animation-name: marquee-scroll-sp;
  }
}

@keyframes marquee-scroll {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-2900px);
  }
}
@keyframes marquee-scroll-sp {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-2044px);
  }
}
/**
 * 日付コンポーネントのスタイル
 *
 * @package yatsu
 * @since 1.0.0
 */
.date {
  display: flex;
  align-items: center;
  gap: var(--wp--preset--spacing--8);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: 700;
}

.date__icon {
  display: inline-block;
  width: 40px;
  height: 27px;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/figure_05.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
}
@media (max-width: 1000px) {
  .date__icon {
    width: 30px;
    height: 20px;
  }
}

.date__text {
  white-space: nowrap;
}

.date--color-1 {
  color: var(--wp--preset--color--site-color-1);
}

.date--color-2 {
  color: var(--wp--preset--color--site-color-2);
}

/**
 * TOPページ用記事カードコンポーネントのスタイル
 *
 * @package yatsu
 * @since 1.0.0
 */
.index-diary-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background-color: var(--wp--preset--color--white);
  border-radius: var(--wp--preset--spacing--24);
  overflow: visible;
  width: 100%;
  margin-top: 58px;
}

.index-diary-card__thumbnail {
  width: 100%;
}

.index-diary-card__image {
  overflow: hidden;
  border-radius: var(--wp--preset--spacing--16) var(--wp--preset--spacing--16) 0 0;
  aspect-ratio: 285/181;
}
.index-diary-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0;
}

.index-diary-card__character {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 109px;
  height: auto;
  z-index: 1;
}

.index-diary-card--character-1 .index-diary-card__character {
  top: -57px;
}

.index-diary-card--character-2 .index-diary-card__character {
  top: -55px;
}

.index-diary-card__content {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
  padding: var(--wp--preset--spacing--24) var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .index-diary-card__content {
    gap: var(--wp--preset--spacing--12);
    padding: var(--wp--preset--spacing--16);
  }
}

.index-diary-card__meta {
  display: flex;
  align-items: center;
}

.index-diary-card__title {
  color: var(--wp--preset--color--site-color-1);
}
@media (max-width: 1000px) {
  .index-diary-card__title {
    font-size: var(--wp--preset--font-size--m);
  }
}

.index-diary-card__excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.index-diary-card__footer {
  display: flex;
  justify-content: center;
  margin-top: var(--wp--preset--spacing--8);
}

.index-diary-card__button {
  max-width: 192px;
  width: 100%;
}
@media (max-width: 1000px) {
  .index-diary-card__button {
    max-width: none;
  }
}

/**
 * Rich Linkコンポーネントのスタイル
 *
 * 画像とテキストを含むリンクカードコンポーネント
 *
 * @package yatsu
 * @since 1.0.0
 */
.rich-link {
  display: block;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.rich-link:hover {
  opacity: 0.8;
}
.rich-link__image-wrapper {
  width: 270px;
  height: 170px;
  overflow: hidden;
}
@media (max-width: 1000px) {
  .rich-link__image-wrapper {
    width: 100%;
    height: auto;
    aspect-ratio: 270/170;
  }
}
.rich-link__image {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
@media (max-width: 1000px) {
  .rich-link__image {
    height: auto;
  }
}
.rich-link__text {
  margin-top: var(--wp--preset--spacing--8);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: 700;
  color: var(--wp--preset--color--text-dark);
  text-align: center;
}
@media (max-width: 1000px) {
  .rich-link__text {
    font-size: var(--wp--preset--font-size--s);
    margin-top: var(--wp--preset--spacing--4);
  }
}

/**
 * ページネーションコンポーネントのスタイル
 *
 * アーカイブページと個別投稿ページで使用する共通のページネーション
 *
 * @package yatsu
 * @since 1.0.0
 */
.pagination {
  width: 100%;
  padding: var(--wp--preset--spacing--48) 0;
}
@media (max-width: 1000px) {
  .pagination {
    padding: var(--wp--preset--spacing--32) 0;
  }
}
.pagination__nav-links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--wp--preset--spacing--16);
  position: relative;
}
@media (max-width: 1000px) {
  .pagination__nav-links {
    flex-wrap: wrap;
    gap: var(--wp--preset--spacing--12);
  }
}
.pagination__nav-button {
  flex: 0 0 auto;
}
.pagination__page-numbers {
  display: flex;
  align-items: center;
  gap: var(--wp--preset--spacing--8);
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.pagination__nav-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 160px;
  height: 40px;
  padding: 0 var(--wp--preset--spacing--24);
  background-color: var(--wp--preset--color--site-color-2);
  color: var(--wp--preset--color--white);
  text-decoration: none;
  border-radius: 0;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: 700;
  transition: opacity 0.2s ease;
}
@media (max-width: 1000px) {
  .pagination__nav-button {
    min-width: 120px;
    height: 32px;
    padding: 0 var(--wp--preset--spacing--16);
    font-size: var(--wp--preset--font-size--s);
  }
}
.pagination__nav-button:hover {
  opacity: 0.8;
}
.pagination__page-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 var(--wp--preset--spacing--8);
  background-color: var(--wp--preset--color--white);
  color: var(--wp--preset--color--site-color-2);
  text-decoration: none;
  border: 1px solid var(--wp--preset--color--site-color-2);
  border-radius: 0;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: 700;
  transition: all 0.2s ease;
}
@media (max-width: 1000px) {
  .pagination__page-number {
    min-width: 32px;
    height: 32px;
    font-size: var(--wp--preset--font-size--s);
  }
}
.pagination__page-number:hover {
  background-color: color-mix(in srgb, var(--wp--preset--color--site-color-2) 10%, transparent);
}
.pagination__page-number--current {
  background-color: var(--wp--preset--color--site-color-2);
  color: var(--wp--preset--color--white);
  border-color: var(--wp--preset--color--site-color-2);
}
.pagination__page-dots {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--wp--preset--color--site-color-2);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--m);
  font-weight: 700;
}

/**
 * 採用バナーコンポーネントのスタイル
 *
 * @package yatsu
 * @since 1.0.0
 */
.recruitment-banner {
  display: block;
  width: 100%;
  text-decoration: none;
  background-color: var(--wp--preset--color--site-color-2);
  border-radius: 8px 0 0 8px;
  opacity: 1;
  transition: opacity 0.3s ease;
}
.recruitment-banner--fixed {
  position: fixed;
  top: 230px;
  right: 0;
  width: 60px;
  z-index: 1000;
}
@media (max-width: 1000px) {
  .recruitment-banner--fixed {
    top: 122px;
    width: 40px;
  }
}
.recruitment-banner__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--wp--preset--spacing--4);
  padding: var(--wp--preset--spacing--16) 0;
}
@media (max-width: 1000px) {
  .recruitment-banner__content {
    gap: var(--wp--preset--spacing--8);
    padding: var(--wp--preset--spacing--12) 0;
    width: 40px;
  }
}
.recruitment-banner__text {
  writing-mode: vertical-rl;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-size: var(--wp--preset--font-size--l);
  font-weight: 700;
  color: var(--wp--preset--color--white);
  letter-spacing: 0.1em;
}
@media (max-width: 1000px) {
  .recruitment-banner__text {
    font-size: var(--wp--preset--font-size--xs);
  }
}
.recruitment-banner__icon {
  display: block;
  width: 24px;
  height: 24px;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
@media (max-width: 1000px) {
  .recruitment-banner__icon {
    width: 18px;
    height: 18px;
  }
}

/**
 * ヘッダーレイアウトコンポーネントのスタイル
 *
 * ロゴとメニューボタンを含むヘッダー
 * PC版とSP版のレスポンシブ対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.header {
  width: 100%;
  padding: var(--wp--preset--spacing--24) var(--wp--preset--spacing--32) var(--wp--preset--spacing--8);
  max-width: 1920px;
  margin: 0 auto;
  height: 154px;
}
@media (max-width: 1000px) {
  .header {
    padding: var(--wp--preset--spacing--16) calc(var(--wp--preset--spacing--20) / 375px * 100vw) var(--wp--preset--spacing--8);
    height: 96px;
  }
}
.header__container {
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}
.header__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.header__logo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-shrink: 0;
}
.header__logo .logo {
  max-width: 340px;
  width: 100%;
}
@media (max-width: 1000px) {
  .header__logo .logo {
    max-width: 240px;
  }
}
.header__menu-button {
  position: fixed;
  top: var(--wp--preset--spacing--24);
  right: var(--wp--preset--spacing--32);
  z-index: 10000;
}
@media (max-width: 1000px) {
  .header__menu-button {
    top: 0;
    right: calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}

.header--fixed {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.header--fixed body {
  padding-top: 120px;
}
@media (max-width: 1000px) {
  .header--fixed body {
    padding-top: 100px;
  }
}

/**
 * フッターレイアウトコンポーネントのスタイル
 *
 * 学校法人さかえ学園 谷津幼稚園のフッタースタイル
 * Figmaデザインを正確に再現
 *
 * @package yatsu
 * @since 1.0.0
 */
.footer {
  position: relative;
  width: 100%;
  overflow: hidden;
  text-box: trim-both;
  margin-top: -273px;
}
@media (max-width: 1000px) {
  .footer {
    padding-top: 0;
  }
}
.footer__decoration {
  width: 100%;
  height: 273px;
  position: relative;
}
.footer__grass {
  position: absolute;
  left: 0;
  top: 215px;
  width: 100%;
  height: 74px;
  z-index: 1;
  background-size: 1500px auto;
  background-repeat: repeat-x;
  background-position: left center;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/grass.svg");
}
@media (max-width: 1000px) {
  .footer__grass {
    left: -512px;
    width: 1600px;
    top: 211px;
  }
}
.footer__tree {
  position: absolute;
  z-index: 2;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/tree.svg");
  left: calc(166px / 1600px * 100vw);
  bottom: 0;
  width: 100px;
  aspect-ratio: 100/155;
}
@media (max-width: 1000px) {
  .footer__tree {
    width: 85px;
    left: calc(15px / 1000px * 100vw);
  }
}
.footer__background-image {
  position: absolute;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url("/wp-content/themes/yatsu2026/assets/images/footer/children-background.png");
  z-index: 3;
  display: block;
  right: calc(121px / 1600px * 100vw);
  top: 28px;
  width: 312px;
  aspect-ratio: 312/245;
}
@media (max-width: 1000px) {
  .footer__background-image {
    top: 77px;
    width: 249px;
    right: calc(20px / 1000px * 100vw);
  }
}
.footer__content {
  background-color: var(--wp--preset--color--site-color-1);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 3;
}
@media (max-width: 1000px) {
  .footer__content {
    width: 100%;
    padding: var(--wp--preset--spacing--24) calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}
.footer__content-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--wp--preset--spacing--24);
  width: 331px;
  text-align: center;
  padding: var(--wp--preset--spacing--16) 0;
}
@media (max-width: 1000px) {
  .footer__content-inner {
    gap: var(--wp--preset--spacing--16);
    width: 100%;
    padding: 0;
  }
}
.footer__school-info {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
}
@media (max-width: 1000px) {
  .footer__school-info {
    gap: var(--wp--preset--spacing--16);
  }
}
.footer__school-name {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .footer__school-name {
    width: 100%;
    gap: var(--wp--preset--spacing--16);
  }
}
.footer__school-organization {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  color: var(--wp--preset--color--white);
  margin: 0;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  gap: 4px;
  line-height: 1;
}
.footer__school-designation {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--xs);
  color: var(--wp--preset--color--white);
  margin: 0;
  line-height: 1;
}
.footer__school-title {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--6-xl);
  color: var(--wp--preset--color--white);
  margin: 0;
  white-space: nowrap;
  line-height: 1;
}
.footer__contact-info {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  line-height: 1.3;
  color: var(--wp--preset--color--white);
  text-align: center;
  min-width: 100%;
}
.footer__address {
  margin: 0;
  line-height: 1;
}
.footer__phone {
  margin: 0;
  line-height: 1;
}
.footer__phone .paragraph--tel-link {
  color: var(--wp--preset--color--white);
}
.footer__copyright {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--s);
  line-height: 1;
  color: var(--wp--preset--color--white);
  text-align: center;
  width: 100%;
}

/**
 * MVセクションコンポーネントのスタイル
 *
 * 固定ページのアイキャッチ画像を使用したメインビジュアル
 * PC版とSP版のレスポンシブ対応
 *
 * @package yatsu
 * @since 1.0.0
 */
.mv {
  position: relative;
  width: 100%;
  overflow: hidden;
  max-width: 1920px;
  margin: 0 auto;
}

.mv__container {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .mv__container {
    padding: 0 calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}

.mv__image-area {
  position: relative;
  width: 100%;
  height: 360px;
  border-radius: 40px 40px 0 0;
  overflow: hidden;
}
.mv__image-area:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 35px;
  z-index: 1;
  background-size: 70px auto;
  background-repeat: repeat-x;
  background-position: center 0;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/cloud.svg");
}
@media (max-width: 1000px) {
  .mv__image-area {
    height: 360px;
  }
}

.mv__background-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: top;
  background-repeat: no-repeat;
  z-index: 1;
  background-image: var(--bg-image-pc);
}
@media (max-width: 1000px) {
  .mv__background-image {
    background-image: var(--bg-image-sp);
  }
}

.mv__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  width: 100%;
  max-width: 1200px;
  padding: 0 var(--wp--preset--spacing--8);
}
@media (max-width: 1000px) {
  .mv__content {
    max-width: 335px;
    padding: 0 var(--wp--preset--spacing--8);
  }
}

.mv__text-container {
  text-align: center;
  color: var(--wp--preset--color--white);
}

.mv__title {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--8-xl);
  line-height: 1.2;
  margin: 0;
  text-shadow: rgba(0, 0, 0, 0.45) 0px 0px 10px;
}
@media (max-width: 1000px) {
  .mv__title {
    font-size: var(--wp--preset--font-size--5-xl);
    line-height: 1.3;
  }
}

.mv__subtitle {
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--8-xl);
  line-height: 1.2;
  margin: 0;
  text-shadow: rgba(0, 0, 0, 0.45) 0px 0px 10px;
}
@media (max-width: 1000px) {
  .mv__subtitle {
    font-size: var(--wp--preset--font-size--5-xl);
    line-height: 1.3;
  }
}

/**
 * TOPページ用MVセクションコンポーネントのスタイル
 *
 * 3枚の画像をフェードで切り替えるスライドショー
 *
 * @package yatsu
 * @since 1.0.0
 */
.mv-index {
  position: relative;
  width: 100%;
  overflow: hidden;
  max-width: 1920px;
  margin: 0 auto;
}

.mv-index__container {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .mv-index__container {
    padding: 0 calc(var(--wp--preset--spacing--20) / 375px * 100vw);
  }
}

.mv-index__image-area {
  position: relative;
  width: 100%;
  height: 656px;
  border-radius: var(--wp--preset--spacing--40) var(--wp--preset--spacing--40) 0 0;
  overflow: hidden;
}
.mv-index__image-area::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 35px;
  z-index: 10;
  background-size: 70px auto;
  background-repeat: repeat-x;
  background-position: center 0;
  background-image: url("/wp-content/themes/yatsu2026/assets/svg/cloud.svg");
}
@media (max-width: 1000px) {
  .mv-index__image-area {
    height: 480px;
  }
}

.mv-index__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  background-image: var(--bg-image-pc);
}
@media (max-width: 1000px) {
  .mv-index__slide {
    background-image: var(--bg-image-sp);
  }
}
.mv-index__slide--active {
  opacity: 1;
}

.mv-index__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
  width: 100%;
  max-width: 1200px;
  padding: 0 var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .mv-index__content {
    max-width: 335px;
    padding: 0 var(--wp--preset--spacing--16);
  }
}

.mv-index__catch {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0;
}

.mv-index__catch-line {
  display: flex;
  justify-content: space-between;
  width: 5em;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: 130px;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 3px var(--wp--preset--color--white);
}
@media (max-width: 1000px) {
  .mv-index__catch-line {
    font-size: 54px;
    line-height: 80px;
  }
}

.page-guide .policy-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--64);
  max-width: 860px;
  margin: 0 auto;
}

.page-educational-goals .educational-goals__catch {
  aspect-ratio: 600/453;
  max-width: 600px;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .page-educational-goals .educational-goals__catch {
    max-width: 100%;
  }
}
.page-educational-goals .educational-goals__category {
  font-size: 80px;
  font-weight: var(--wp--custom--font-weight--black);
  text-align: center;
  line-height: 1;
}
.page-educational-goals .educational-goals__section {
  margin-bottom: var(--wp--preset--spacing--64);
}
@media (max-width: 1000px) {
  .page-educational-goals .educational-goals__section {
    margin-bottom: var(--wp--preset--spacing--40);
  }
}
.page-educational-goals .educational-goals__section:last-child {
  margin-bottom: 400px;
}
.page-educational-goals .educational-goals__section .section__inner {
  width: 90vw;
  padding: var(--wp--preset--spacing--120) var(--wp--preset--spacing--64) var(--wp--preset--spacing--40) !important;
}
@media (max-width: 1000px) {
  .page-educational-goals .educational-goals__section .section__inner {
    padding: var(--wp--preset--spacing--40) var(--wp--preset--spacing--8) var(--wp--preset--spacing--8) !important;
  }
}
.page-educational-goals .educational-goals__section[data-color="4"] .section__inner {
  background-color: #edfafe;
}
.page-educational-goals .educational-goals__section[data-color="4"] .section__inner .educational-goals__category,
.page-educational-goals .educational-goals__section[data-color="4"] .section__inner .educational-goals__sub-phrase-label .paragraph {
  color: var(--wp--preset--color--site-color-4);
}
.page-educational-goals .educational-goals__section[data-color="1"] .section__inner {
  background-color: var(--wp--preset--color--sub-color-1);
}
.page-educational-goals .educational-goals__section[data-color="1"] .section__inner .educational-goals__category,
.page-educational-goals .educational-goals__section[data-color="1"] .section__inner .educational-goals__sub-phrase-label .paragraph {
  color: var(--wp--preset--color--site-color-1);
}
.page-educational-goals .educational-goals__section[data-color="2"] .section__inner {
  background-color: var(--wp--preset--color--sub-color-2);
}
.page-educational-goals .educational-goals__section[data-color="2"] .section__inner .educational-goals__category,
.page-educational-goals .educational-goals__section[data-color="2"] .section__inner .educational-goals__sub-phrase-label .paragraph {
  color: var(--wp--preset--color--site-color-2);
}

.page-infant-care .infant-care__schedule-list-wrapper {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
.page-infant-care .infant-care__images {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .page-infant-care .infant-care__images {
    display: none;
  }
}
.page-infant-care .infant-care__image {
  flex-shrink: 0;
}
.page-infant-care .infant-care__image:nth-child(2) {
  margin-top: 55px;
}
.page-infant-care .infant-care__yearly-schedule-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .page-infant-care .infant-care__yearly-schedule-wrapper {
    gap: var(--wp--preset--spacing--32);
  }
}
.page-infant-care .infant-care__month-section {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
}
@media (max-width: 1000px) {
  .page-infant-care .infant-care__month-section {
    gap: var(--wp--preset--spacing--20);
  }
}
.page-infant-care .infant-care__month-heading {
  margin-bottom: 0;
}
.page-infant-care .infant-care__cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--wp--preset--spacing--24);
  width: 100%;
}
@media (max-width: 1000px) {
  .page-infant-care .infant-care__cards-grid {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--16);
  }
}
.page-infant-care .infant-care__other-events {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-infant-care .infant-care__other-events-title {
  color: var(--wp--preset--color--black);
}
.page-infant-care .infant-care__other-events-list {
  display: flex;
  gap: var(--wp--preset--spacing--40);
  list-style: none;
  padding: 0;
  margin: 0;
}
.page-infant-care .infant-care__other-events-item {
  display: flex;
  gap: var(--wp--preset--spacing--4);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--regular);
  font-size: var(--wp--preset--font-size--m);
  color: var(--wp--preset--color--black);
  position: relative;
}
@media (max-width: 1000px) {
  .page-infant-care .infant-care__other-events-item {
    font-size: var(--wp--preset--font-size--s);
  }
}
.page-infant-care .infant-care__other-events-item::before {
  content: "●";
  color: var(--wp--preset--color--site-color-3);
}

.page-kids-club .kids-club__images {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .page-kids-club .kids-club__images {
    flex-direction: column;
  }
}

.page-safety-management .safety-management__videos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--wp--preset--spacing--24);
  margin-bottom: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .page-safety-management .safety-management__videos {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--64);
    margin-bottom: var(--wp--preset--spacing--24);
  }
}

.page-recruitment .paragraph-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
}

.page-admission-guide .admission-guide__list {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-admission-guide .admission-guide__content {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
.page-admission-guide .admission-guide__content h4.heading {
  color: var(--wp--preset--color--black);
}
.page-admission-guide .admission-guide__gallery {
  display: flex;
  gap: var(--wp--preset--spacing--24);
  margin-top: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .page-admission-guide .admission-guide__gallery {
    flex-direction: column;
    gap: var(--wp--preset--spacing--16);
  }
}
.page-admission-guide .admission-guide__gallery-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-admission-guide .admission-guide__gallery-item img {
  width: 100%;
  height: auto;
  border-radius: 4px;
}
.page-admission-guide .admission-guide__link-list {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--16);
}
.page-admission-guide .admission-guide__link-list a {
  word-break: break-all;
}
.page-admission-guide .admission-guide__schedule-table-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-admission-guide .admission-guide__schedule-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.page-admission-guide .admission-guide__schedule-table {
  width: 100%;
  min-width: 800px;
  border-collapse: collapse;
  border: 1px solid var(--wp--preset--color--table-border);
  margin-top: var(--wp--preset--spacing--24);
  table-layout: fixed;
}
.page-admission-guide .admission-guide__schedule-table th,
.page-admission-guide .admission-guide__schedule-table td {
  border: 1px solid var(--wp--preset--color--table-border);
  vertical-align: middle;
}
.page-admission-guide .admission-guide__schedule-table th {
  background-color: var(--wp--preset--color--site-color-2);
  color: var(--wp--preset--color--white);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  line-height: 24px;
  width: 182px;
  min-width: 182px;
  max-width: 182px;
  padding: var(--wp--preset--spacing--8) 0;
  text-align: center;
}
.page-admission-guide .admission-guide__schedule-table td {
  background-color: var(--wp--preset--color--white);
  padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
}
.page-admission-guide .admission-guide__schedule-table-header {
  background-color: var(--wp--preset--color--site-color-2);
  color: var(--wp--preset--color--white);
  font-weight: var(--wp--custom--font-weight--black);
}
.page-admission-guide .admission-guide__schedule-table-header .paragraph {
  color: var(--wp--preset--color--white);
}
.page-admission-guide .admission-guide__table-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-admission-guide .admission-guide__table-wrapper .table-wrapper {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.page-admission-guide .admission-guide__table-wrapper .table-wrapper__inner {
  min-width: 800px;
}
.page-admission-guide .admission-guide__table-wrapper .table--bordered {
  flex-direction: row;
}
.page-admission-guide .admission-guide__table-wrapper .table__label {
  min-width: 182px;
  width: 182px;
  flex: none;
}
@media (max-width: 1000px) {
  .page-admission-guide .admission-guide__table-wrapper .table__label {
    min-width: 150px;
    width: 150px;
  }
}
.page-admission-guide .admission-guide__table-wrapper .table__value {
  flex: 1;
  border-left: none;
  border-top: 1px solid var(--wp--preset--color--table-border);
  width: auto;
  padding-left: var(--wp--preset--spacing--16);
  justify-content: center;
}
.page-admission-guide .admission-guide__table-wrapper .table__value + .table__value {
  border-left: none;
  border-top: 1px solid var(--wp--preset--color--table-border);
}
.page-admission-guide .admission-guide__qa-list {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .page-admission-guide .admission-guide__qa-list {
    gap: var(--wp--preset--spacing--24);
  }
}
.page-admission-guide .admission-guide__qa-list h4.heading {
  color: var(--wp--preset--color--site-color-2);
}
.page-admission-guide .admission-guide__qa-item-with-table {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-admission-guide .admission-guide__qa-item-with-table .table-wrapper {
  margin-top: var(--wp--preset--spacing--8);
}

.page-early-childhood-care .early-childhood-care__schedule-list-wrapper {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__schedule-list-wrapper {
    flex-direction: column;
    gap: var(--wp--preset--spacing--24);
  }
}
.page-early-childhood-care .early-childhood-care__images {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__images {
    display: none;
  }
}
.page-early-childhood-care .early-childhood-care__image {
  flex-shrink: 0;
}
.page-early-childhood-care .early-childhood-care__image:nth-child(2) {
  margin-top: 55px;
}
.page-early-childhood-care .early-childhood-care__yearly-schedule-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__yearly-schedule-wrapper {
    gap: var(--wp--preset--spacing--32);
  }
}
.page-early-childhood-care .early-childhood-care__month-section {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__month-section {
    gap: var(--wp--preset--spacing--20);
  }
}
.page-early-childhood-care .early-childhood-care__month-heading {
  margin-bottom: 0;
}
.page-early-childhood-care .early-childhood-care__cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--wp--preset--spacing--24);
  width: 100%;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__cards-grid {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--20);
  }
}
.page-early-childhood-care .early-childhood-care__other-events {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-early-childhood-care .early-childhood-care__other-events-title {
  color: var(--wp--preset--color--black);
}
.page-early-childhood-care .early-childhood-care__other-events-list {
  display: flex;
  gap: var(--wp--preset--spacing--40);
  list-style: none;
  padding: 0;
  margin: 0;
}
.page-early-childhood-care .early-childhood-care__other-events-item {
  display: flex;
  gap: var(--wp--preset--spacing--4);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--regular);
  font-size: var(--wp--preset--font-size--m);
  color: var(--wp--preset--color--black);
  position: relative;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__other-events-item {
    font-size: var(--wp--preset--font-size--s);
  }
}
.page-early-childhood-care .early-childhood-care__other-events-item::before {
  content: "●";
  color: var(--wp--preset--color--site-color-3);
}
.page-early-childhood-care .early-childhood-care__uniform-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--wp--preset--spacing--24);
  margin-top: var(--wp--preset--spacing--40);
  width: 100%;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-wrapper {
    gap: var(--wp--preset--spacing--16);
    margin-top: var(--wp--preset--spacing--24);
  }
}
.page-early-childhood-care .early-childhood-care__uniform-main {
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-main {
    max-width: 100%;
  }
}
.page-early-childhood-care .early-childhood-care__uniform-grid {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
  max-width: 781px;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-grid {
    flex-direction: column;
    gap: var(--wp--preset--spacing--16);
    max-width: 100%;
  }
}
.page-early-childhood-care .early-childhood-care__uniform-item {
  flex-shrink: 0;
}
.page-early-childhood-care .early-childhood-care__uniform-item:nth-child(1) {
  width: 296px;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-item:nth-child(1) {
    width: 100%;
  }
}
.page-early-childhood-care .early-childhood-care__uniform-item:nth-child(2) {
  width: 204px;
  margin-top: 15.5px;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-item:nth-child(2) {
    width: 100%;
    margin-top: 0;
  }
}
.page-early-childhood-care .early-childhood-care__uniform-item:nth-child(3) {
  width: 229px;
  margin-top: 6.5px;
}
@media (max-width: 1000px) {
  .page-early-childhood-care .early-childhood-care__uniform-item:nth-child(3) {
    width: 100%;
    margin-top: 0;
  }
}

/**
 * 園の施設 スタイル
 *
 * @package Yatsu
 * @version 1.0.0
 */
.page-facilities .facilities__map-section .section__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-facilities .facilities__map-group {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
  max-width: 880px;
}
.page-facilities .facilities__map-image {
  width: 100%;
  margin: 0 auto;
}
.page-facilities .facilities__map-image img {
  width: 100%;
  height: auto;
  display: block;
}
.page-facilities .facilities__gallery {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--wp--preset--spacing--24);
  width: 100%;
  max-width: 880px;
  margin: 0 auto;
}
.page-facilities .facilities__gallery .facility-card {
  width: calc((100% - 72px) / 4);
}
@media (max-width: 1000px) {
  .page-facilities .facilities__gallery .facility-card {
    width: 100%;
  }
}
@media (max-width: 1000px) {
  .page-facilities .facilities__gallery {
    flex-direction: column;
    gap: var(--wp--preset--spacing--16);
  }
}

/**
 * キッズ写真館ページ
 *
 * @package Yatsu
 * @since 1.0.0
 */
.kids-photo-gallery__container {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
}
@media (max-width: 1000px) {
  .kids-photo-gallery__container {
    gap: var(--wp--preset--spacing--24);
  }
}
.kids-photo-gallery__notice {
  text-align: center;
  color: var(--wp--preset--color--red);
}
.kids-photo-gallery__list {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--40);
}
.kids-photo-gallery__group {
  display: flex;
  flex-direction: column;
  border: solid var(--wp--preset--color--table-border);
  border-width: 1px 0 0 1px;
}
.kids-photo-gallery__date {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--wp--preset--spacing--12) var(--wp--preset--spacing--24);
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--black);
  font-size: var(--wp--preset--font-size--l);
  color: var(--wp--preset--color--white);
}
[data-color="1"] .kids-photo-gallery__date {
  background-color: var(--wp--preset--color--site-color-1);
}
[data-color="2"] .kids-photo-gallery__date {
  background-color: var(--wp--preset--color--site-color-2);
}
[data-color="3"] .kids-photo-gallery__date {
  background-color: var(--wp--preset--color--site-color-3);
}
[data-color="4"] .kids-photo-gallery__date {
  background-color: var(--wp--preset--color--site-color-4);
}
@media (max-width: 1000px) {
  .kids-photo-gallery__date {
    padding: var(--wp--preset--spacing--8) var(--wp--preset--spacing--16);
    font-size: var(--wp--preset--font-size--m);
  }
}
.kids-photo-gallery__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 1000px) {
  .kids-photo-gallery__grid {
    grid-template-columns: 1fr;
  }
}
.kids-photo-gallery__empty {
  text-align: center;
  font-family: var(--wp--preset--font-family--zen-maru-gothic);
  font-weight: var(--wp--custom--font-weight--medium);
  font-size: var(--wp--preset--font-size--l);
  color: var(--wp--preset--color--text-dark);
}

.page-extended-care .extended-care__content {
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--24);
}
@media (max-width: 1000px) {
  .page-extended-care .extended-care__content {
    gap: var(--wp--preset--spacing--16);
  }
}
.page-extended-care .extended-care__content-heading {
  color: var(--wp--preset--color--site-color-2);
  margin-bottom: 0;
}
.page-extended-care .extended-care__paragraph {
  margin-bottom: 0;
}
.page-extended-care .extended-care__note {
  margin-bottom: 0;
}
.page-extended-care .extended-care__table-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media (max-width: 1000px) {
  .page-extended-care .extended-care__table-wrapper {
    margin-top: var(--wp--preset--spacing--16);
  }
}
.page-extended-care .extended-care__table {
  padding: 0;
}
.page-extended-care .extended-care__table .table__label {
  background-color: var(--wp--preset--color--site-color-2);
}
.page-extended-care .extended-care__table .table__value {
  display: flex;
  gap: var(--wp--preset--spacing--16);
  flex-direction: column;
  justify-content: center;
}
.page-extended-care .extended-care__image-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--wp--preset--spacing--24);
  margin-top: var(--wp--preset--spacing--32);
}
@media (max-width: 1000px) {
  .page-extended-care .extended-care__image-grid {
    grid-template-columns: 1fr;
    gap: var(--wp--preset--spacing--16);
    margin-top: var(--wp--preset--spacing--24);
  }
}
.page-extended-care .extended-care__image-grid .image {
  width: 100%;
  height: auto;
  max-width: none;
}
.page-extended-care .extended-care__image-grid .image .image__element {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.page-access .access__google-map {
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--wp--preset--spacing--8);
}
.page-access .access__google-map-embed {
  width: 100%;
  border-radius: var(--wp--preset--spacing--24);
  overflow: hidden;
  aspect-ratio: 1200/532;
}
@media (max-width: 1000px) {
  .page-access .access__google-map-embed {
    aspect-ratio: 335/210;
  }
}
.page-access .access__google-map-embed iframe {
  display: block;
  width: 100%;
  height: 100%;
}
.page-access .access__google-map-link {
  width: fit-content;
  align-self: flex-end;
  color: var(--wp--preset--color--site-color-1);
}
.page-access .access__map {
  width: 100%;
  max-width: 740px;
  margin: 0 auto;
}
.page-access .access__map img {
  width: 100%;
}

/**
 * メインSCSSファイル
 * すべてのスタイルをここでインポート
 *
 * @package Yatsu
 * @version 1.0.0
 */