@charset "UTF-8";
/* Sass Document */
/* ----------------------------------------------------------------------------------------------------
*  基本情報
* --------------------------------------------------------------------------------------------------*/
@layer components, variations;
@layer components {
  a,
  abbr,
  acronym,
  address,
  applet,
  article,
  aside,
  audio,
  b,
  big,
  blockquote,
  body,
  canvas,
  caption,
  center,
  cite,
  code,
  dd,
  del,
  details,
  dfn,
  div,
  dl,
  dt,
  em,
  embed,
  fieldset,
  figcaption,
  figure,
  footer,
  form,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  header,
  hgroup,
  html,
  i,
  iframe,
  img,
  ins,
  kbd,
  label,
  legend,
  li,
  mark,
  menu,
  nav,
  object,
  ol,
  output,
  p,
  pre,
  q,
  ruby,
  s,
  samp,
  section,
  small,
  span,
  strike,
  strong,
  summary,
  table,
  tbody,
  td,
  tfoot,
  th,
  thead,
  time,
  tr,
  tt,
  u,
  ul,
  var,
  video {
    margin: 0;
    padding: 0;
    border: 0;
    font: inherit;
    font-size: 100%;
    vertical-align: baseline;
  }
  picture {
    display: block;
  }
  p {
    font-size: 1.6rem;
    line-height: 2;
  }
  @media screen and (max-width: 767.98px) {
    p {
      font-size: 1.5rem;
      line-height: 1.8666666667;
    }
  }
  button {
    border: none;
    font: inherit;
    color: currentColor;
  }
  ol,
  ul,
  menu {
    list-style: none;
    margin: 0;
    padding: 0;
  }
  li {
    list-style: none;
    margin: 0;
    padding: 0;
  }
}
html {
  line-height: 1;
}

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

strong {
  font-weight: 700;
}

caption,
td,
th {
  text-align: left;
}

blockquote,
q {
  quotes: none;
}

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

a img {
  border: none;
}

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

html {
  font-size: 100%;
}

* {
  box-sizing: border-box;
  word-break: break-word;
  overflow-wrap: break-word;
  line-break: strict;
  white-space: normal;
}

html {
  font-size: 100%;
  width: 100%;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
  font-size: min(0.78125vw, 62.5%);
}
@media screen and (max-width: 767.98px) {
  html {
    font-size: 2.56410256vw;
  }
}

body {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  position: relative;
  font-weight: 400;
  font-family: "Zen Maru Gothic", sans-serif;
  color: #333;
  font-size: 1.6rem;
  scroll-behavior: smooth;
  line-height: 1.75;
}
body * {
  letter-spacing: 0.075em;
}
body.is-fixed {
  overscroll-behavior-y: none;
  overflow: hidden;
}
body.is-fixed::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 100%;
  z-index: 15;
  background-color: rgba(255, 255, 255, 0.8);
}
@media screen and (max-width: 767.98px) {
  body.is-fixed::before {
    display: none;
  }
}

div[id],
section[id],
h2[id],
h3[id] {
  scroll-margin-top: 10rem;
}

@media (min-width: 768px) {
  a[href*="tel:"] {
    text-decoration: none;
    cursor: default;
    pointer-events: none;
  }
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

#l-main {
  background: #FAF9F7;
  overflow: clip;
}

.js-animate {
  opacity: 0;
  transform: translateY(6rem);
  transition: 1s opacity, 1s transform;
}
@media screen and (max-width: 767.98px) {
  .js-animate {
    transform: translateY(3rem);
  }
}
.js-animate.is-show {
  opacity: 1;
  transform: translateY(0);
}

#l-header {
  overflow: hidden;
}

.l-header__logo {
  position: absolute;
  z-index: 10;
  width: 20rem;
  height: 20rem;
/*
  width: 24.6rem;
  height: 24.6rem;
*/
  border-radius: 100%;
  display: grid;
  place-content: center;
  background-color: #fff;
  top: 3rem;
  left: 3rem;
}
@media screen and (max-width: 767.98px) {
  .l-header__logo {
    width: 13.6rem;
    height: 13.6rem;
    left: -3rem;
    top: -2rem;
  }
}
.l-header__logo img {
  width: 8.0rem;
/*  width: 9.6rem;*/
}
@media screen and (max-width: 767.98px) {
  .l-header__logo img {
    width: 4.6rem;
  }
}

.l-global-nav-wrapper {
  position: fixed;
  right: 0;
  top: 0;
  z-index: 1000;
}
.l-global-nav-wrapper .c-deco {
  width: 9.4rem;
  height: 9.4rem;
  left: 2.88rem;
  z-index: 10;
  bottom: 10rem;
  pointer-events: none;
}
@media screen and (max-width: 767.98px) {
  .l-global-nav-wrapper .c-deco {
    width: 5.2rem;
    height: 5.2rem;
    left: 1rem;
    bottom: 4rem;
  }
}
@media screen and (max-width: 767.98px) {
  .l-global-nav-wrapper {
    left: 0;
  }
}
.l-global-nav-wrapper > .l-hamburger__wrapper {
  position: absolute;
  top: 3rem;
  right: 3rem;
}
@media screen and (max-width: 767.98px) {
  .l-global-nav-wrapper > .l-hamburger__wrapper {
    top: 1rem;
    right: 1rem;
  }
}

.l-global__nav {
  padding-top: 2rem;
  width: 64rem;
  height: 100vh;
  overflow: auto;
  position: absolute;
  right: 0;
  top: 0;
  background-color: #fff;
  z-index: 1001;
  transform: translateX(100%);
  transition: 0.5s transform;
}
.l-global__nav.is-open {
  transform: translateX(0);
}
@media screen and (max-width: 767.98px) {
  .l-global__nav {
    width: 100%;
    height: 100dvh;
    left: 0;
    padding-top: 1rem;
  }
}
.l-global__nav .l-nav__contact {
  margin-inline: auto;
  justify-content: center;
}
.l-global__nav .l-hamburger__wrapper {
  position: absolute;
  top: 1rem;
  right: 10rem;
}
@media screen and (max-width: 767.98px) {
  .l-global__nav .l-hamburger__wrapper {
    right: 1rem;
  }
}

.l-global__nav-inner {
  background-color: #f2eee7;
  padding-top: 13rem;
  padding-bottom: 2.5rem;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .l-global__nav-inner {
    padding-top: 12rem;
  }
}
.l-global__nav-inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 9rem;
  background-color: #fff;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1279.83 70.82" preserveAspectRatio="none"><title>wave</title><path class="cls-1" d="M0,11.46s211.97,60.56,336.95,59.34,275.96-27.85,323.96-37.54S873.88-1.86,971.87,1.77c97.99,3.63,288.96,23.01,307.96,36.33V0H0v11.46Z"/></svg>') no-repeat top center/100% 100%;
}
@media screen and (max-width: 767.98px) {
  .l-global__nav-inner::before {
    width: 45rem;
    height: 9rem;
    left: auto;
    mask-position: top right;
  }
}

.l-global__nav-list {
  font-size: 2rem;
  width: fit-content;
  margin-inline: auto;
  padding-left: 2rem;
}
@media screen and (max-width: 767.98px) {
  .l-global__nav-list {
    font-size: 1.8rem;
    padding-left: 2.8rem;
  }
}
.l-global__nav-list a {
  text-decoration: none;
  color: currentColor;
  display: inline-block;
  position: relative;
}
.l-global__nav-list a::after {
  content: "";
  position: absolute;
  top: calc(100% + 0.1rem);
  left: 0;
  width: 100%;
  height: 0.2rem;
  background-color: #5ba938;
  transform: scaleX(0);
  transition: transform 0.3s;
  transform-origin: right;
}
@media (any-hover: hover) {
  .l-global__nav-list a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
  }
}

.l-global__nav-item > a {
  font-weight: 500;
}
.l-global__nav-item > a::before {
  top: 1rem;
  content: "";
  position: absolute;
  width: 2rem;
  height: 1.7rem;
  background: url(../img/common/icn_nav_arrow.svg) no-repeat center/contain;
  left: -2.3rem;
}
@media screen and (max-width: 767.98px) {
  .l-global__nav-item > a::before {
    left: -2.2rem;
    top: 0.9rem;
  }
}
.l-global__nav-item + .l-global__nav-item {
  margin-top: 0.5rem;
}

.l-global__subnav-list {
  margin-top: 0.5rem;
  padding-left: 1em;
}

.l-global__subnav-item + .l-global__subnav-item {
  margin-top: 0.5rem;
}

.l-hamburger__wrapper {
  width: 9.4rem;
  height: 9.1rem;
  z-index: 1000;
  position: relative;
}
@media screen and (max-width: 767.98px) {
  .l-hamburger__wrapper {
    width: 6rem;
    height: 5.8rem;
  }
}

.l-hamburger {
  background: url(../img/common/deco_green.svg) no-repeat center/contain;
  width: 100%;
  height: 100%;
  cursor: pointer;
  position: relative;
}
.l-hamburger.is-cross .c-line:first-of-type {
  top: 46%;
  transform: rotate(45deg);
  background-color: #fdd000;
}
.l-hamburger.is-cross .c-line:nth-of-type(2) {
  opacity: 0;
}
.l-hamburger.is-cross .c-line:nth-of-type(3) {
  top: 46%;
  transform: rotate(-45deg);
}
.l-hamburger.is-cross .c-txt {
  display: none;
}
.l-hamburger span {
  position: absolute;
}
.l-hamburger .c-line {
  width: 5rem;
  height: 0.4rem;
  background-color: #fff;
  left: 0;
  right: 0;
  margin-inline: auto;
  top: 40%;
  transition: all 0.3s;
}
@media screen and (max-width: 767.98px) {
  .l-hamburger .c-line {
    width: 3.2rem;
    height: 2px;
  }
}
.l-hamburger .c-line:first-of-type {
  top: calc(40% - 1.4rem);
}
@media screen and (max-width: 767.98px) {
  .l-hamburger .c-line:first-of-type {
    top: calc(40% - 0.8rem);
  }
}
.l-hamburger .c-line:nth-of-type(2) {
  background-color: #fdd000;
}
.l-hamburger .c-line:nth-of-type(3) {
  top: calc(40% + 1.4rem);
}
@media screen and (max-width: 767.98px) {
  .l-hamburger .c-line:nth-of-type(3) {
    top: calc(40% + 0.8rem);
  }
}
.l-hamburger .c-txt {
  color: #fff;
  font-weight: 700;
  font-size: 1.4rem;
  left: 0;
  right: 0;
  bottom: 1rem;
}
@media screen and (max-width: 767.98px) {
  .l-hamburger .c-txt {
    font-size: 1rem;
    bottom: 0.9rem;
  }
}

#l-footer {
  overflow: hidden;
  position: relative;
  padding-bottom: 27.34375vw;
  background: url(../img/common/bg_footer_img.png) #f2eee7 no-repeat bottom center/100% 31.25vw;
}
@media screen and (max-width: 767.98px) {
  #l-footer {
    padding-bottom: 26.3rem;
    background: url(../img/common/bg_footer_sp.png) #f2eee7 no-repeat bottom center/100% auto;
  }
}
#l-footer::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  width: 100%;
  height: 8rem;
  background-color: #faf9f7;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1279.83 70.82" preserveAspectRatio="none"><title>wave</title><path class="cls-1" d="M0,11.46s211.97,60.56,336.95,59.34,275.96-27.85,323.96-37.54S873.88-1.86,971.87,1.77c97.99,3.63,288.96,23.01,307.96,36.33V0H0v11.46Z"/></svg>') no-repeat top center/100% 100%;
}
@media screen and (max-width: 767.98px) {
  #l-footer::before {
    width: 68rem;
    height: 5rem;
    top: 0;
    right: -7.3rem;
    left: auto;
  }
}
#l-footer .c-deco {
  width: 14.4rem;
  z-index: 10;
  right: 0.5rem;
  bottom: 17rem;
}
@media screen and (max-width: 767.98px) {
  #l-footer .c-deco {
    width: 6.4rem;
    right: 1rem;
  }
}
#l-footer .l-nav__contact {
  grid-row: 2/4;
  grid-column: 3;
}

.l-footer__inner {
  max-width: 117rem;
  margin-inline: auto;
  padding-top: 12rem;
  position: relative;
}
@media screen and (max-width: 767.98px) {
  .l-footer__inner {
    padding-top: 4rem;
  }
}

.l-footer__grid {
  display: grid;
  grid-template-columns: auto auto 1fr;
  grid-template-rows: auto auto 1fr;
  padding-right: 1.7rem;
/*  padding-right: 6.7rem;*/
}
@media screen and (max-width: 767.98px) {
  .l-footer__grid {
    display: block;
    padding-right: 0;
  }
}

.l-footer__logo-company-info {
  grid-row: 1/4;
  grid-column: 1;
}

.l-footer__company-info {
  font-size: 1.6rem;
  font-weight: 500;
  margin: 1.3rem 0 0 4.6rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
}
@media screen and (max-width: 767.98px) {
  .l-footer__company-info {
    font-size: 1.4rem;
    margin: 1rem auto 0;
    width: fit-content;
  }
}

.l-footer__logo {
  background-color: #fff;
  clip-path: circle(50% at 50% 50%);
  width: 28.6rem;
  height: 28.6rem;
  display: grid;
  place-content: center;
}
@media screen and (max-width: 767.98px) {
  .l-footer__logo {
    width: 12.3rem;
    height: 12.3rem;
    margin-inline: auto;
  }
}
.l-footer__logo img {
  width: 12.1rem;
  display: block;
}
@media screen and (max-width: 767.98px) {
  .l-footer__logo img {
    width: 5.2rem;
  }
}

.l-footer__nav {
  display: flex;
  grid-row: 1;
  grid-column: 2/4;
  font-size: 1.6rem;
  margin: 2rem 0 0 -1.5rem;
}
@media screen and (max-width: 767.98px) {
  .l-footer__nav {
    display: none;
  }
}
.l-footer__nav a {
  color: currentColor;
  text-decoration: none;
  position: relative;
  display: inline-block;
}
.l-footer__nav a::after {
  content: "";
  position: absolute;
  top: calc(100% + 0.1rem);
  left: 0;
  width: 100%;
  height: 0.2rem;
  background-color: #5ba938;
  transform: scaleX(0);
  transition: transform 0.3s;
  transform-origin: right;
}
@media (any-hover: hover) {
  .l-footer__nav a:hover::after {
    transform: scaleX(1);
    transform-origin: left;
  }
}

.l-footer__nav-list {
  padding-left: 1.8rem;
}
.l-footer__nav-list:nth-of-type(2) {
  margin-left: 3.5rem;
}
.l-footer__nav-list:nth-of-type(3) {
  margin-left: 5rem;
}

.l-footer__nav-item {
  font-weight: 500;
}
.l-footer__nav-item > a::before {
  content: "";
  position: absolute;
  width: 1.1rem;
  height: 1.3rem;
  background: url(../img/common/icn_nav_arrow.svg) no-repeat center/contain;
  left: -1.8rem;
  top: 0.9rem;
}
.l-footer__nav-item + .l-footer__nav-item {
  margin-top: 0.5rem;
}

.l-footer__subnav-list {
  padding-left: 1em;
  font-weight: 400;
  margin-top: 0.3rem;
}

.l-footer__subnav-item + .l-footer__subnav-item {
  margin-top: 0.5rem;
}

.l-footer__copyright {
  text-align: center;
  margin-top: 4rem;
}

.l-footer__copyright-text {
  font-size: 1.4rem;
  color: #333;
}

.l-top-btn {
  position: fixed;
  bottom: 5rem;
  right: 5rem;
  width: 7.1rem;
  z-index: 100;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s opacity;
}
@media screen and (max-width: 767.98px) {
  .l-top-btn {
    right: 1.5rem;
    bottom: 1rem;
  }
}
@media (any-hover) {
  .l-top-btn a {
    transition: 0.3s opacity;
  }
  .l-top-btn a:hover {
    opacity: 0.7;
  }
}
.l-top-btn.is-show {
  opacity: 1;
  pointer-events: auto;
}

.l-footer__copyright {
  position: absolute;
  left: 0;
  right: 0;
  max-width: 108.6rem;
  margin-inline: auto;
  bottom: 0.56rem;
  width: 100%;
}
@media screen and (max-width: 767.98px) {
  .l-footer__copyright {
    display: none;
  }
}

.c-copyright {
  font-size: 1.4rem;
  font-weight: 500;
  display: block;
  color: #fff;
  text-align: right;
}

.u-pc {
  display: block;
}
@-moz-document url-prefix() {
    .u-pc {
      display: inline-block;
    }
}

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

.u-sp {
  display: none;
}
@media screen and (max-width: 767.98px) {
  .u-sp {
    display: block;
  }
}

.c-deco {
  display: inline-block;
  position: absolute;
}
.c-deco.-re img {
  transform: scale(-1, 1);
}

@keyframes upDonw {
  0% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-10%);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes kaiten {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.u-updown {
  animation: upDonw 3s ease-in-out infinite;
  animation-delay: var(--delay);
}

.l-nav__contact {
  display: flex;
  align-items: flex-start;
  margin-left: auto;
  margin-top: 2rem;
}
@media screen and (max-width: 767.98px) {
  .l-nav__contact {
    width: fit-content;
    margin: 2rem auto 0;
  }
}
.l-nav__contact p {
  font-size: 1.4rem;
  font-weight: 500;
  width: fit-content;
  margin-inline: auto;
  line-height: 1.4;
}
@media screen and (max-width: 767.98px) {
  .l-nav__contact p {
    font-size: 1.2rem;
  }
}

.l-lower {
  background: #FAF9F7;
  overflow: clip;
}

.l-nav__tel {
  background: url(../img/common/bg_tel.svg) no-repeat center/100% 100%;
  width: 29.9rem;
  height: 16.9rem;
  padding-top: 4.7rem;
  text-align: center;
  margin: 2.6rem -3rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .l-nav__tel {
    width: 19.2rem;
    height: 13rem;
    padding-top: 2.5rem;
    margin: 0.7rem -2rem 0 0;
  }
}
.l-nav__tel p {
  border-bottom: 0.4rem dotted #fdd000;
}
.l-nav__tel a {
  font-size: 3.6rem;
  text-decoration: none;
  color: #5ba938;
  font-weight: 900;
  line-height: 1;
  margin-top: 0.3rem;
  display: inline-block;
}
@media screen and (max-width: 767.98px) {
  .l-nav__tel a {
    width: 6.3rem;
    margin-top: 0.5rem;
  }
}

.l-nav__mail {
  background: url(../img/common/bg_mail.svg) no-repeat center/100% 100%;
  width: 22.6rem;
  height: 16.3rem;
  padding-top: 3.7rem;
  text-align: center;
}
@media screen and (max-width: 767.98px) {
  .l-nav__mail {
    width: 18.9rem;
    height: 13.6rem;
    padding-top: 3.2rem;
  }
}
.l-nav__mail p {
  border-bottom: 0.4rem dotted #5ba938;
}
.l-nav__mail a {
  font-weight: 600;
  line-height: 1;
  display: inline-block;
  margin-top: 1rem;
  width: 7.5rem;
}
@media (any-hover) {
  .l-nav__mail a {
    transition: 0.3s opacity;
  }
  .l-nav__mail a:hover {
    opacity: 0.7;
  }
}
@media screen and (max-width: 767.98px) {
  .l-nav__mail a {
    width: 6.3rem;
    margin-top: 0.5rem;
  }
}

.c-section__ttl {
  font-size: 6rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.07em;
  position: relative;
  z-index: 10;
}
.c-section__ttl .u-txtsize--small {
  font-size: 63.3%;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl {
    padding-left: 1em;
  }
}
.c-section__ttl.u-deco-ttl .c-ttl {
  position: relative;
  z-index: 1;
}
.c-section__ttl.u-deco-ttl .c-ttl::before {
  content: "";
  position: absolute;
  width: 14.4rem;
  height: 14.4rem;
  left: -9rem;
  top: -4rem;
  z-index: -1;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl .c-ttl::before {
    width: 7.4rem;
    height: 7.4rem;
    left: -4.4rem;
    top: -2.4rem;
  }
}
.c-section__ttl.u-deco-ttl .c-ttl.-blog {
  display: block;
  font-size: 4rem;
  line-height: 1.75;
  text-align: left;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl .c-ttl.-blog {
    font-size: 2.4rem;
  }
}
.c-section__ttl.u-deco-ttl .c-ttl img {
  width: auto;
  height: 10.6rem;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl .c-ttl img {
    height: 6rem;
  }
}
.c-section__ttl.u-deco-ttl .c-ttl:has(img) {
  display: inline-block;
  line-height: 1;
  padding: 1.9rem 0;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl .c-ttl:has(img) {
    padding: 1rem 0;
  }
}
.c-section__ttl.u-deco-ttl .c-ttl:has(img)::before {
  top: 0;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl .c-ttl:has(img)::before {
    top: 0 !important;
  }
}
.c-section__ttl.u-deco-ttl.-green span::before {
  background: url(../img/common/deco_dots_green.png) no-repeat center/100% 100%;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl.-green span::before {
    background-image: url(../img/common/deco_dots_green_sp.png);
  }
}
.c-section__ttl.u-deco-ttl.-yellow span::before {
  background: url(../img/common/deco_dots_yellow.png) no-repeat center/100% 100%;
  left: -7.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl.u-deco-ttl.-yellow span::before {
    left: -3.5rem;
    top: -1.4rem;
    background-image: url(../img/common/deco_dots_yellow_sp.png);
  }
}
@media screen and (max-width: 767.98px) {
  .c-section__ttl {
/*    font-size: 2.8rem;*/
    font-size: 6.4vw;
  }
}

.c-heading__txt {
  font-size: 2rem;
  text-align: center;
  line-height: 1.8;
  margin-top: 10rem;
}
@media screen and (max-width: 767.98px) {
  .c-heading__txt {
    font-size: 1.6rem;
    line-height: 1.75;
    text-align: justify;
    max-width: 33rem;
    margin: 8rem auto 0;
  }
}

.l-content__inner {
  max-width: 108.6rem;
  margin-inline: auto;
  padding-inline: 1.5rem;
  position: relative;
  z-index: 1;
  box-sizing: content-box;
}

.u-deco-wave {
  position: relative;
}
.u-deco-wave::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  width: 100%;
  height: 6.7rem;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1279.83 70.82" preserveAspectRatio="none"><title>wave</title><path class="cls-1" d="M0,11.46s211.97,60.56,336.95,59.34,275.96-27.85,323.96-37.54S873.88-1.86,971.87,1.77c97.99,3.63,288.96,23.01,307.96,36.33V0H0v11.46Z"/></svg>') no-repeat top center/100% 100%;
}
@media screen and (max-width: 767.98px) {
  .u-deco-wave::before {
    height: 2rem;
  }
}

.u-deco-wave.-beige {
  background-color: #f2eee7;
}
.u-deco-wave.-beige::before {
  background-color: #faf9f7;
}

.u-deco-wave.-body {
  background-color: #faf9f7;
}
.u-deco-wave.-body::before {
  background-color: #f2eee7;
}

.u-bgdeco {
  min-height: 94rem;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .u-bgdeco {
    min-height: 51.7rem;
  }
}
.u-bgdeco::before, .u-bgdeco::after {
  content: "";
  position: absolute;
}
.u-bgdeco::before {
  top: 14.6rem;
  left: 0;
  width: 48.4375%;
  height: 77.4rem;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 620.95 774.26" preserveAspectRatio="none"><title>bg</title> <path id="IMG_9544" data-name="IMG 9544" class="cls-1" d="M.01,70.26S43.16,12.48,97.01,5.72s89.34-8.45,155.25,0,144.75,38.53,172.75,57.53,87.51,43.86,112.86,140.2,77.14,171.8,82.14,236.8-10.63,188-33,217.81-39,42.25-106.6,70.98-174.77,45.21-220.4,45.21-129-11-163-27S-.99,682.87.01,658.06.01,70.26.01,70.26Z"/></svg>');
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100% 100%;
}
@media screen and (max-width: 767.98px) {
  .u-bgdeco::before {
    width: 44.6rem;
    height: 57rem;
    left: -12.4rem;
    top: 10.6rem;
  }
}
.u-bgdeco::after {
  top: 0;
  right: 0;
  z-index: 1;
  width: 66.09375%;
  height: 84.5rem;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 846.13 845.07" preserveAspectRatio="none"><title>bg</title><path id="_パス_55140" data-name="パス 55140" class="cls-1" d="M134.64,151.93c78.41-49.47,93.41-51.47,172.41-59.47s67.87,8.11,141.93-6.45,52.07-16.55,107.07-43.55,32.57-31.55,112-40,178.08,7.5,178.08,7.5v797.68s-59.15,27.04-155.48,35.49-371.8-13.52-371.8-13.52c0,0-92.95-8.45-126.75-21.97s-133.51-114.92-162.24-204.49S-12.39,393.6,14.65,329.38s41.58-127.98,119.99-177.45Z"/></svg>');
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100% 100%;
}
@media screen and (max-width: 767.98px) {
  .u-bgdeco::after {
    width: 60.7rem;
    height: 60.7rem;
    right: -31.3rem;
  }
}
.u-bgdeco.-left--green::before {
  background-color: #5ba938;
}
.u-bgdeco.-right--baige::after {
  background-color: #f2eee7;
}
.u-bgdeco.-left--baige::before {
  background-color: #f2eee7;
}
.u-bgdeco.-right--brown::after {
  background-color: #efdeb9;
}

.u-bgdeco.-rev::before {
  top: 0;
  right: 0;
  z-index: 1;
  width: 66.640625%;
  height: 85.2rem;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 853.18 852.12" preserveAspectRatio="none"><title>bg</title><path class="cls-1" d="M717.42,153.2c-79.06-49.88-94.19-51.89-173.84-59.96s-68.43,8.18-143.12-6.5-52.5-16.69-107.96-43.92S259.66,11.01,179.57,2.49,0,10.06,0,10.06v804.32s59.64,27.26,156.78,35.78,374.9-13.63,374.9-13.63c0,0,93.72-8.52,127.81-22.15s134.62-115.88,163.59-206.19,42.6-211.3,15.34-276.06-41.93-129.05-120.99-178.93Z"/></svg>');
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100% 100%;
}
@media screen and (max-width: 767.98px) {
  .u-bgdeco.-rev::before {
    width: 41rem;
    height: 53.4rem;
    left: -14.6rem;
  }
}
.u-bgdeco.-rev::after {
  top: 14.7rem;
  right: 0;
  z-index: 0;
  width: 49.6875%;
  height: 79.3rem;
  mask: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 636.6 793.78" preserveAspectRatio="none"><title>bg</title><path class="cls-1" d="M636.59,72.03s-44.24-59.23-99.44-66.16-91.6-8.66-159.17,0-148.4,39.51-177.1,58.99-89.72,44.97-115.71,143.73S6.08,384.72.96,451.36s10.9,192.74,33.83,223.3,39.98,43.31,109.29,72.77,179.18,46.35,225.96,46.35,132.25-11.28,167.11-27.68c34.86-16.4,100.47-66.01,99.45-91.44s0-602.63,0-602.63Z"/></svg>');
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100% 100%;
}
@media screen and (max-width: 767.98px) {
  .u-bgdeco.-rev::after {
    width: 36.9rem;
    height: 51.7rem;
    right: -7.4rem;
    top: 9rem;
  }
}

.p-detail__list {
  min-height: 4rem;
  margin-top: 1rem;
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
}
@media screen and (max-width: 767.98px) {
  .p-detail__list {
    min-height: inherit;
    margin-top: 0.5rem;
    gap: 0.5rem 1.5rem;
  }
}

.c-category {
  display: inline-block;
  background-color: #5ba938;
  font-size: 1.6rem;
  font-weight: 500;
  border-radius: 1rem;
  padding: 1rem;
  line-height: 1;
  color: #fff;
}
@media screen and (max-width: 767.98px) {
  .c-category {
    font-size: 1.4rem;
    border-radius: 0.8rem;
    padding: 1.2rem;
  }
}

.c-note {
  display: inline-block;
  font-size: 1.6rem;
}
@media screen and (max-width: 767.98px) {
  .c-note {
    font-size: 1.2rem;
  }
}

.js-animate {
  opacity: 0;
  transform: translateY(20%);
  transition: 0.3s opacity, 0.3s transform;
}
.js-animate.is-show {
  opacity: 1;
  transform: translateY(0);
}

.l-card__list {
  display: flex;
  flex-wrap: wrap;
}
.l-card__list.l-col--3 {
  gap: 3.5rem;
}
.l-card__list.l-col--3 .l-card__item {
  width: 33.8rem;
}
@media screen and (max-width: 767.98px) {
  .l-card__list.l-spcol--2 {
    justify-content: space-between;
    gap: 1rem;
  }
  .l-card__list.l-spcol--2 .l-card__item {
    width: 17.5rem;
  }
}

.l-card__item {
  background-color: #fff;
  border-radius: 1rem;
}
.l-card__item a {
  color: currentColor;
  text-decoration: none;
  display: block;
  height: 100%;
}
@media (any-hover: hover) {
  .l-card__item a:hover .l-card__img-wrapper img {
    transform: scale(1.1);
  }
}

.l-card__inner {
  padding: 2rem 2.4rem;
  height: 100%;
}
@media screen and (max-width: 767.98px) {
  .l-card__inner {
    padding: 1rem;
  }
}

.l-card__img-wrapper {
  border-radius: 1rem;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .l-card__img-wrapper {
    border-radius: 0.5rem;
  }
}
.l-card__img-wrapper img {
  transition: 0.3s transform;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.l-card__body {
  padding-top: 1rem;
}
@media screen and (max-width: 767.98px) {
  .l-card__body {
    padding-top: 0;
  }
}
.l-card__body time {
  font-size: 1.6rem;
  font-weight: 500;
  color: #5ba938;
}
@media screen and (max-width: 767.98px) {
  .l-card__body time {
    font-size: 1.2rem;
  }
}

.l-card__ttl {
  font-size: 1.8rem;
  line-height: 1.75;
}
@media screen and (max-width: 767.98px) {
  .l-card__ttl {
    font-size: 1.4rem;
    line-height: 1.75;
  }
}

time + .l-card__ttl {
  margin-top: 0.2rem;
}

.c-mv {
  background: #FAF9F7;
  margin: 0 0 24rem;
}
@media screen and (max-width: 767.98px) {
  .c-mv {
    margin: 0 0 4rem;
  }
}
.c-mv__img {
  position: relative;
  width: 100%;
}
@media screen and (max-width: 767.98px) {
  .c-mv__img {
    height: 20rem;
  }
  .c-mv__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
.c-mv__img::before {
  content: "";
  position: absolute;
  bottom: -0.2rem;
  left: 0;
  width: 100%;
  height: 6.8rem;
  background: url(../img/common/bg_mv.svg) center 0/100% 100% no-repeat;
}
@media screen and (max-width: 767.98px) {
  .c-mv__img::before {
    height: 3rem;
  }
}
.c-mv__bread {
  max-width: 108rem;
  margin: 4rem auto 0;
}
@media screen and (max-width: 767.98px) {
  .c-mv__bread {
    margin: 2rem 0 0;
    padding: 0 1.5rem;
  }
}
.c-mv__bread ol {
  font-size: 0;
}
.c-mv__bread ol li {
  display: inline;
  position: relative;
  font-size: 1.6rem;
  line-height: 1.75;
  letter-spacing: 0;
}
@media screen and (max-width: 767.98px) {
  .c-mv__bread ol li {
    font-size: 1.4rem;
  }
}
.c-mv__bread ol li::after {
  content: ">";
  margin: 0 0.6rem 0 0.3rem;
  letter-spacing: 0;
}
.c-mv__bread ol li:last-child::after {
  content: none;
}
.c-mv__bread ol li a {
  text-decoration: none;
  transition: 0.3s;
  color: #333;
}
.c-mv__bread ol li a:hover {
  opacity: 0.7;
}

.c-dot {
  position: absolute;
  opacity: 0.3;
  border-radius: 100%;
}
.c-dot.-or {
  background: url(../img/common/icn_dot_ye.png) center center/1rem auto repeat;
}
@media screen and (max-width: 767.98px) {
  .c-dot.-or {
    background-size: 1.2rem auto;
  }
}
.c-dot.-gr {
  opacity: 0.4;
  background: url(../img/common/icn_dot_gr.png) center center/1rem auto repeat;
}
@media screen and (max-width: 767.98px) {
  .c-dot.-gr {
    background-size: 1.2rem auto;
  }
}

.c-button {
  width: 18.1rem;
  height: 11.5rem;
  font-size: 1.6rem;
  line-height: 1.25;
  font-weight: 700;
  margin: 0 auto;
}
@media screen and (max-width: 767.98px) {
  .c-button {
    font-size: 1.4rem;
  }
}
.c-button a,
.c-button button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background: url(../img/common/button.svg) 0 0/100% auto no-repeat;
  color: #fff;
  text-decoration: none;
  padding: 0 6rem 0 1.5rem;
  transition: 0.3s;
}
.c-button a:hover,
.c-button button:hover {
  opacity: 0.7;
}

.c-archive {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  max-width: 108rem;
  margin: 0 auto;
  padding: 0 0 20rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive {
    flex-flow: column;
    padding: 0 1.5rem;
  }
}
.c-archive .c-section__ttl {
  width: 100%;
  margin: 0 0 11.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive .c-section__ttl {
    margin: 0 0 4rem;
  }
}
.c-archive__ttl {
  font-weight: 700;
  font-size: 4rem;
  width: 100%;
  margin: 0 0 5rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive__ttl {
    font-size: 2.4rem;
    margin: 0 0 2.4rem;
  }
}
.c-archive:has(.c-archive-side) .c-archive__main {
  width: 75rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive:has(.c-archive-side) .c-archive__main {
    width: 100%;
  }
}
.c-archive__main {
  width: 100%;
}
@media screen and (max-width: 767.98px) {
  .c-archive__main {
    width: 100%;
  }
}
.c-archive__inner {
  background: #fff;
  border-radius: 2rem;
  padding: 4rem 3.5rem 10rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive__inner {
    padding: 2rem 2rem 6rem;
    margin: 0 0 6rem;
  }
}
.c-archive-side {
  flex-shrink: 0;
  width: 28.6rem;
  margin-top: -7rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive-side {
    width: 100%;
    margin: 0;
    padding: 0 0 10rem;
  }
}
.c-archive-side__ttl {
  position: relative;
  font-size: 2.8rem;
  font-weight: 700;
  color: #5BA938;
  line-height: 1.4;
  margin: 0 0 2rem;
  z-index: 1;
}
@media screen and (max-width: 767.98px) {
  .c-archive-side__ttl {
    font-size: 1.8rem;
  }
}
.c-archive-cat {
  position: relative;
  min-height: 50.8rem;
  margin-top: 15.5rem;
  padding: 12.4rem 0 0 5rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive-cat {
    margin-top: 6rem;
  }
}
.c-archive-cat:first-child {
  margin-top: 0;
}
.c-archive-cat::before {
  content: "";
  position: absolute;
  top: -5.4rem;
  left: 22.5rem;
  width: 14.4rem;
  height: 14.4rem;
  background: url(../img/common/icn_dot_gr.png) center center/1rem auto repeat;
  border-radius: 100%;
  z-index: 1;
}
@media screen and (max-width: 767.98px) {
  .c-archive-cat::before {
    top: -1rem;
    right: 10rem;
    width: 10rem;
    height: 10rem;
    background-size: 1.2rem auto;
  }
}
.c-archive-cat.-type::before {
  background: url(../img/common/icn_dot_ye.png) center center/1rem auto repeat;
}
.c-archive-cat::after {
  content: "";
  position: absolute;
  top: 0;
  right: calc((100vw - 108rem) / 2 * -1);
  width: calc((100vw - 108rem) / 2 + 100%);
  height: 100%;
  background: url(../img/common/bg_side.svg) center center/100% 100% no-repeat;
}
@media screen and (max-width: 767.98px) {
  .c-archive-cat::after {
    right: -1.5rem;
    width: calc(100% + 1.5rem);
  }
}
.c-archive-cat-list {
  position: relative;
  z-index: 1;
}
.c-archive-cat-list__item {
  line-height: 1.6;
  margin-top: 0.6rem;
}
.c-archive-cat-list__item:first-child {
  margin-top: 0;
}
.c-archive-cat-list__item a {
  text-decoration: none;
  color: #333;
  transition: 0.3s;
}
.c-archive-cat-list__item a:hover {
  opacity: 0.7;
}
.c-archive-tag {
  margin: 10rem 0 0;
  padding: 0 0 0 5rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive-tag {
    margin-top: 6rem;
  }
}
.c-archive-tag-list {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 1rem;
}
.c-archive-tag-list__item {
  font-size: 1.4rem;
  border: 1px solid #5BA938;
  line-height: 1;
}
.c-archive-tag-list__item a {
  display: block;
  color: #333;
  background: #fff;
  padding: 0.5rem 2rem;
  transition: 0.3s;
  text-decoration: none;
}
.c-archive-tag-list__item a:hover {
  background: #5BA938;
  color: #fff;
}
.c-archive-select {
  margin: 10rem 0 0;
  padding: 0 0 0 5rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive-select {
    margin-top: 6rem;
  }
}
.c-archive-select__wrap {
  position: relative;
  height: 4rem;
  border: 1px solid #707070;
  background: #fff;
}
.c-archive-select__wrap::after {
  content: "";
  pointer-events: none;
  position: absolute;
  top: 50%;
  right: 1.8rem;
  width: 2rem;
  height: 0.7rem;
  background: url(../img/common/icn_select.png) 0 0/100% auto no-repeat;
  transform: translateY(-50%);
}
.c-archive-select__wrap select {
  appearance: none;
  width: 100%;
  height: 100%;
  background: none;
  font-family: inherit;
  line-height: 1;
  font-size: 2rem;
  color: #333;
  padding: 0 1rem;
  border: 0;
}
@media screen and (max-width: 767.98px) {
  .c-archive-select__wrap select {
    font-size: 1.6rem;
  }
}
.c-archive__btn {
  margin-top: 6rem;
}
@media screen and (max-width: 767.98px) {
  .c-archive__btn {
    margin-top: 4rem;
  }
}

.c-posts {
  border-bottom: 1px solid #F2EEE7;
  padding-bottom: 3.8rem;
}
.c-posts__item {
  border-top: 1px solid #F2EEE7;
  padding-top: 3.8rem;
  margin-top: 3.8rem;
}
@media screen and (max-width: 767.98px) {
  .c-posts__item {
    padding-top: 2.4rem;
    margin-top: 2.4rem;
  }
}
.c-posts__item:first-child {
  border-top: 0;
  margin-top: 0;
  padding-top: 0;
}
.c-posts__item a {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  text-decoration: none;
  transition: 0.3s;
}
@media screen and (max-width: 767.98px) {
  .c-posts__item a {
    flex-flow: column;
    gap: 1rem 0;
  }
}
.c-posts__item a:hover {
  opacity: 0.7;
}
.c-posts__inner {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  text-decoration: none;
  transition: 0.3s;
}
@media screen and (max-width: 767.98px) {
  .c-posts__inner {
    flex-flow: column;
    gap: 1rem 0;
  }
}
.c-posts__img {
  width: 16rem;
  height: 11rem;
}
@media screen and (max-width: 767.98px) {
  .c-posts__img {
    width: 100%;
    height: 20rem;
  }
}
.c-posts__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.c-posts__detail {
  position: relative;
  width: calc(100% - 19rem);
}
@media screen and (max-width: 767.98px) {
  .c-posts__detail {
    width: 100%;
  }
}
.c-posts__detail:not(:has(.c-posts-cat)) .c-posts__date {
  position: relative;
  top: auto;
  right: auto;
  text-align: right;
  margin: 0 0 0.5rem;
}
.c-posts__date {
  position: absolute;
  top: 0;
  right: 0;
  line-height: 1.5;
  color: #333;
}
@media screen and (max-width: 767.98px) {
  .c-posts__date {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.c-posts-cat {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 1.1rem;
  padding: 0 8rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-posts-cat {
    padding: 0 7rem 0 0;
  }
}
.c-posts-cat__item {
  background: #5BA938;
  border-radius: 0.5rem;
  color: #fff;
  line-height: 1.5;
  padding: 0 0.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-posts-cat__item {
    font-size: 1.4rem;
  }
}
.-blog .c-posts-cat__item {
  color: #5BA938;
  background: #fff;
}
:has(> .c-posts-cat__item:empty) {
  margin-bottom: 0;
}
:has(> .c-posts-cat__item:empty) + .c-posts-age {
  padding: 0 8rem 0 0;
}
@media screen and (max-width: 767.98px) {
  :has(> .c-posts-cat__item:empty) + .c-posts-age {
    padding: 0 7rem 0 0;
  }
}
:has(> .c-posts-cat__item:empty) + .c-posts-detail {
  padding: 0 8rem 0 0;
}
@media screen and (max-width: 767.98px) {
  :has(> .c-posts-cat__item:empty) + .c-posts-detail {
    padding: 0 7rem 0 0;
  }
}
.c-posts-age {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 1.1rem;
}
.c-posts-age__item {
  font-size: 1.4rem;
  font-weight: 500;
  border-radius: 2rem;
  border: 2px solid #ccc;
  line-height: 1;
  color: #333;
  text-decoration: none;
  padding: 0.5rem 1rem;
}
@media screen and (max-width: 767.98px) {
  .c-posts-age__item {
    font-size: 1.2rem;
  }
}
.c-posts-age__item.u-infant-toddler, .c-posts-age__item.u-age-0, .c-posts-age__item.u-age-1, .c-posts-age__item.u-age-2 {
  border: 2px solid #F093A5;
}
.c-posts-age__item.u-preschool, .c-posts-age__item.u-nensho, .c-posts-age__item.u-nenchu, .c-posts-age__item.u-nencho {
  border: 2px solid #5BA938;
}
.c-posts-age__item.u-elementary, .c-posts-age__item.u-elem-1-2, .c-posts-age__item.u-elem-3-4, .c-posts-age__item.u-elem-5-6 {
  border: 2px solid #FDD000;
}
.c-posts-age__item.u-middle-school {
  border: 2px solid #689BC2;
}
.c-posts-detail {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0 1rem;
}
.c-posts-detail__status {
  flex-shrink: 0;
  width: 4rem;
  text-align: center;
  background: #6398BA;
  color: #fff;
  line-height: 1;
  border-radius: 0.5rem;
  padding: 0.5rem 0;
}
.c-posts-detail__status.u-end {
  background: #D88E8D;
}
.c-posts-detail__ttl {
  color: #333;
  font-weight: 700;
  line-height: 1.75;
}

.c-cat {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0 0 3.2rem;
}
.c-cat__item {
  font-size: 1.4rem;
  font-weight: 500;
}
.c-cat__item a {
  display: block;
  border-radius: 2rem;
  border: 2px solid #ccc;
  line-height: 1;
  color: #333;
  text-decoration: none;
  padding: 0.5rem 1rem;
  transition: 0.3s;
}
.c-cat__item a:hover {
  opacity: 0.6;
}
@media screen and (max-width: 767.98px) {
  .c-cat__item a {
    font-size: 1.2rem;
  }
}
.c-cat__item a.u-infant-toddler, .c-cat__item a.u-age-0, .c-cat__item a.u-age-1, .c-cat__item a.u-age-2 {
  border: 2px solid #F093A5;
}
.c-cat__item a.u-preschool, .c-cat__item a.u-nensho, .c-cat__item a.u-nenchu, .c-cat__item a.u-nencho {
  border: 2px solid #5BA938;
}
.c-cat__item a.u-elementary, .c-cat__item a.u-elem-1-2, .c-cat__item a.u-elem-3-4, .c-cat__item a.u-elem-5-6 {
  border: 2px solid #FDD000;
}
.c-cat__item a.u-middle-school {
  border: 2px solid #689BC2;
}

.c-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 1rem;
  margin: 6rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-pager {
    gap: 0 0.6rem;
  }
}
.c-pager .item {
  width: 4rem;
  height: 4rem;
  line-height: 1;
  font-weight: 700;
  font-size: 1.7rem;
}
@media screen and (max-width: 767.98px) {
  .c-pager .item {
    font-size: 1.6rem;
  }
}
.c-pager .item.current {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #E6CD95;
  color: #fff;
  border-radius: 100%;
  padding: 0 0 0.2rem;
}
.c-pager .item a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  background: #fff;
  border-radius: 100%;
  border: 1px solid #E6CD95;
  padding: 0 0 0.2rem;
  transition: 0.3s;
  text-decoration: none;
  color: #E6CD95;
}
.c-pager .item a:hover {
  background: #E6CD95;
  color: #fff;
  opacity: 1;
  border: 1px solid #E6CD95;
}
.c-pager .item.dot {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2rem;
}
.c-pager .item.prev, .c-pager .item.next {
  width: 4rem;
  height: 4rem;
  font-size: 0;
}
@media screen and (max-width: 767.98px) {
  .c-pager .item.prev, .c-pager .item.next {
    width: 4rem;
    height: 4rem;
    font-size: 0;
  }
}
.c-pager .item.prev a, .c-pager .item.next a {
  position: relative;
  width: 100%;
  height: 100%;
  border: 1px solid #E6CD95;
  border-radius: 100%;
  background: url(../img/common/icn_arrow.png) center center/1rem auto no-repeat;
}
.c-pager .item.prev a:hover, .c-pager .item.next a:hover {
  background: url(../img/common/icn_arrow_wh.png) center center/1rem auto no-repeat #E6CD95;
}
.c-pager .item.prev span, .c-pager .item.next span {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  border: 1px solid #E6CD95;
  border-radius: 100%;
  background: url(../img/common/icn_arrow.png) center center/1rem auto no-repeat;
}
@media screen and (max-width: 767.98px) {
  .c-pager .item.next {
    margin-left: 0rem;
  }
}
.c-pager .item.next a,
.c-pager .item.next span {
  transform: scale(-1, 1);
}
@media screen and (max-width: 767.98px) {
  .c-pager .item.prev {
    margin-right: 0rem;
  }
}
.c-pager .item.prev a::before,
.c-pager .item.prev span::before {
  transform: translate(-50%, -50%) scale(-1, 1);
}

.c-table {
  table-layout: fixed;
  width: 100%;
    border-top: 1px solid #72B554;
}
@media screen and (max-width: 767.98px) {
  .c-page__scroll .c-table {
    width: 60rem;
  }
}
.c-table + .c-table {
  margin-top: 8rem;
}
.c-table th {
  width: 22.8rem;
  font-size: 2rem;
  line-height: 1.8;
  color: #72B554;
  border-bottom: 1px solid #72B554;
  padding: 2rem 0;
}
@media screen and (max-width: 767.98px) {
  .c-table th {
    display: block;
    width: 100%;
    font-size: 1.4rem;
    border-bottom: 0;
    padding: 1rem 0 0;
  }
}
.c-table thead th {
  font-size: 2rem;
  line-height: 1.8;
  color: #72B554;
  border-bottom: 1px solid #72B554;
  padding: 2rem 0;
}
@media screen and (max-width: 767.98px) {
  .c-table thead th {
    font-size: 1.4rem;
    padding: 1rem 0;
  }
}
.c-table td {
  font-size: 2rem;
  line-height: 1.8;
  border-bottom: 1px solid #72B554;
  padding: 2rem 0;
}
@media screen and (max-width: 767.98px) {
  .c-table td {
    display: block;
    width: 100%;
    font-size: 1.4rem;
    padding: 0 0 1rem 0;
  }
}
.c-table td .bold {
  font-weight: 700;
}
.c-table td a {
  color: #72B554;
}
.c-table td a:hover {
  text-decoration: none;
}
@media screen and (max-width: 767.98px) {
  .c-table.-scroll th,
  .c-table.-scroll td {
    display: table-cell;
    width: 25%;
    padding-top: 1rem;
  }
}
.c-table tbody tr:first-child th,
.c-table tbody tr:first-child td {
/*  padding-top: 0;*/
}
.c-table tbody tr:last-child th,
.c-table tbody tr:last-child td {
/*  border-bottom: 0;
  padding-bottom: 0;*/
}
.c-table:has(thead) tbody tr:first-child th,
.c-table:has(thead) tbody tr:first-child td {
  padding-top: 2rem;
}
@media screen and (max-width: 767.98px) {
  .c-table:has(thead) tbody tr:first-child th,
  .c-table:has(thead) tbody tr:first-child td {
    padding-top: 1rem;
  }
}
.c-table .imgblock {
  display: flex;
  margin: 3.2rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-table .imgblock {
    display: block;
    margin: 2rem 0;
  }
}
.c-table .imgblock .inner {
  width: 34rem;
}
@media screen and (max-width: 767.98px) {
  .c-table .imgblock .inner {
    width: 100%;
  }
}
.c-table .imgblock .img {
  width: 43rem;
  border-radius: 2rem;
  overflow: hidden;
  margin: 5rem 0 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-table .imgblock .img {
    width: 100%;
    margin: 2rem 0 0;
  }
}
.c-table .imgblock .img img {
  position: relative;
  right: -2rem;
}
@media screen and (max-width: 767.98px) {
  .c-table .imgblock .img img {
    right: auto;
  }
}
.c-table ul li {
  position: relative;
  padding: 0 0 0 1em;
}
.c-table ul li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
  font-weight: 700;
}
.c-table .td-heading {
    font-size: 2.4rem;
    font-weight: bold;
}
.c-event {
  max-width: 108rem;
  margin: 0 auto;
  padding: 0 0 20rem;
}
@media screen and (max-width: 767.98px) {
  .c-event {
    padding: 0 0 6rem;
  }
}
.c-event-head {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0 1.2rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-head {
    padding: 0 1.5rem;
  }
}
.c-event-head__date {
  flex-shrink: 0;
  font-size: 1.6rem;
  line-height: 1.625;
}
@media screen and (max-width: 767.98px) {
  .c-event-head__date {
    font-size: 1.4rem;
  }
}
.c-event-head__type {
  line-height: 1;
}
@media screen and (max-width: 767.98px) {
  .c-event-head__type {
    font-size: 1.4rem;
  }
}
.c-event-head__type a {
  display: block;
  background: #5BA938;
  color: #fff;
  border-radius: 0.5rem;
  text-decoration: none;
  padding: 0.5rem 0.5rem;
}
.c-event-data {
  margin-top: 1.5rem;
}
.c-event-data-tag {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0.8rem;
  max-width: 108rem;
  margin: 1.5rem auto 0;
}
@media screen and (max-width: 767.98px) {
  .c-event-data-tag {
    margin: 1rem 0 0;
    padding: 0 1.5rem;
  }
}
.c-event-data-tag__item {
  border: 1px solid #5BA938;
  background: #fff;
  font-size: 1.3rem;
  line-height: 1.6;
  padding: 0.1rem 0.8rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-data-tag__item {
    font-size: 1.2rem;
  }
}
.c-event-data-age {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-data-age {
    padding: 0 1.5rem;
  }
}
.c-event-data-age__item {
  font-size: 1.4rem;
  font-weight: 500;
  border-radius: 2rem;
  border: 2px solid #ccc;
  line-height: 1;
  color: #333;
  text-decoration: none;
  padding: 0.5rem 1rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-data-age__item {
    font-size: 1.2rem;
  }
}
.c-event-data-age__item.u-infant-toddler, .c-event-data-age__item.u-age-0, .c-event-data-age__item.u-age-1, .c-event-data-age__item.u-age-2 {
  border: 2px solid #F093A5;
}
.c-event-data-age__item.u-preschool, .c-event-data-age__item.u-nensho, .c-event-data-age__item.u-nenchu, .c-event-data-age__item.u-nencho {
  border: 2px solid #5BA938;
}
.c-event-data-age__item.u-elementary, .c-event-data-age__item.u-elem-1-2, .c-event-data-age__item.u-elem-3-4, .c-event-data-age__item.u-elem-5-6 {
  border: 2px solid #FDD000;
}
.c-event-data-age__item.u-middle-school {
  border: 2px solid #689BC2;
}
.c-event-heading {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0 1.5rem;
  margin: 4rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-event-heading {
    margin: 2rem 0 0;
    padding: 0 1.5rem;
  }
}
.c-event-heading__pre {
  flex-shrink: 0;
  background: #6398BA;
  color: #fff;
  border-radius: 0.5rem;
  font-size: 3.6rem;
  line-height: 1.2;
  margin-top: 0.6rem;
  padding: 0 0.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-heading__pre {
    font-size: 2rem;
  }
}
.c-event-heading__pre.u-end {
  background: #D88E8D;
}
.c-event-heading__ttl {
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767.98px) {
  .c-event-heading__ttl {
    font-size: 2.4rem;
  }
}
.c-event-body {
  border-radius: 2rem;
  background: #fff;
  padding: 4rem;
  margin-top: 10rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-body {
    margin-top: 6rem;
    padding: 4rem 1.5rem;
  }
}
.c-event-body__logo {
  text-align: center;
  margin: 0 0 10rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-body__logo {
    margin: 0 0 4rem;
  }
}
.c-event-body__logo img {
  width: auto;
  height: 10.6rem;
}
@media screen and (max-width: 767.98px) {
  .c-event-body__logo img {
    height: 8rem;
  }
}
.c-event-body:has(.c-table) .c-event-body__txt {
  margin-bottom: 8rem;
}
.c-event-body:has(.c-table) .c-event-body__txt:not(:has(*)) {
  margin-bottom: 0;
}
.c-event-body__txt:not(:has(*)) {
  margin-bottom: 0;
}
.c-event__btn {
  margin-top: 6rem;
}

.c-txt {
  overflow: hidden;
}
.c-txt h2 {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.3;
  margin: 0 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt h2 {
    font-size: 2.2rem;
    margin: 0 0 2rem;
  }
}
.c-txt h3 {
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.75;
  margin: 0 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt h3 {
    font-size: 2rem;
    margin: 0 0 2rem;
  }
}
.c-txt h4 {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.7;
  margin: 0 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt h4 {
    font-size: 1.8rem;
    margin: 0 0 2rem;
  }
}
.c-txt h5 {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.75;
  margin: 0 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt h5 {
    font-size: 1.6rem;
    margin: 0 0 2rem;
  }
}
.c-txt p {
  font-size: 2rem;
  line-height: 1.8;
}
@media screen and (max-width: 767.98px) {
  .c-txt p {
    font-size: 1.4rem;
  }
}
.c-txt p:has(img) + .gdc_row {
  margin-top: 2rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt p:has(img) + .gdc_row {
    margin-top: 1rem;
  }
}
.c-txt p:has(img) img {
  border-radius: 2rem;
}
.c-txt img[class*=wp-image-] {
  border-radius: 2rem;
}
.c-txt p + *, * + .c-txt p {
  margin-top: 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt p + *, * + .c-txt p {
    margin-top: 2rem;
  }
}
.c-txt * + h2,
.c-txt * + h3,
.c-txt * + h4,
.c-txt * + h5 {
  margin-top: 10rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt * + h2,
  .c-txt * + h3,
  .c-txt * + h4,
  .c-txt * + h5 {
    margin-top: 4rem;
  }
}
.c-txt .mark01 {
  background: linear-gradient(transparent 70%, rgba(253, 207, 0, 0.2941176471) 70%);
}
.c-txt .mark02 {
  background: linear-gradient(transparent 70%, rgba(216, 142, 141, 0.2666666667) 70%);
}
.c-txt ul {
  list-style: none;
  padding: 0 0 0 1.6rem;
  margin: 0;
}
.c-txt ul li {
  position: relative;
  font-size: 1.8rem;
  line-height: 1.7;
  background: #fff;
  padding: 0 0 0 2rem;
  margin-top: 0.6rem;
}
.c-txt .program-lists ul li {
  margin-top: 0;    
}
@media screen and (max-width: 767.98px) {
  .c-txt ul li {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
@media screen and (max-width: 767.98px) {
  .c-txt ul li {
    line-height: 1.333;
  }
}
.c-txt ul li:first-child {
  margin-top: 0;
}
.c-txt ul li::before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
  font-weight: 700;
}
.c-txt ol {
  counter-reset: item;
  list-style-type: none;
  padding: 0 0 0 1.6rem;
  margin: 0;
}
.c-txt ol li {
  position: relative;
  padding-left: 1em;
  font-size: 1.8rem;
  line-height: 1.7;
  word-break: normal;
  margin-top: 0.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt ol li {
    font-size: 1.4rem;
    line-height: 1.4;
  }
}
.c-txt ol li:first-child {
  margin-top: 0;
}
.c-txt ol li:before {
  counter-increment: item;
  content: counter(item) ".";
  position: absolute;
  top: 0;
  left: 0;
}
.c-txt * + ul,
.c-txt * + ol,
.c-txt * + blockquote {
  margin-top: 2rem;
}
.c-txt img + img,
.c-txt figure + img,
.c-txt img + figure,
.c-txt figure + figure {
  margin-top: 1rem;
}
.c-txt strong {
  font-weight: bold;
}
.c-txt em {
  font-style: italic;
}
.c-txt blockquote {
  display: block;
  background: #eee;
  border-radius: 0.5rem;
  padding: 2em;
}
.c-txt blockquote p {
  margin-top: 0;
}
.c-txt a {
  position: relative;
  color: #5ba938;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .c-txt a:hover {
    text-decoration: none;
    opacity: 1;
  }
}
.c-txt .aligncenter {
  display: block;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}
@media screen and (max-width: 767.98px) {
  .c-txt .aligncenter img {
    width: 100%;
    height: auto;
  }
}
.c-txt .alignright {
  float: right;
  margin-left: 2rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt .alignright {
    float: none;
    width: 100%;
    margin-left: 0;
  }
  .c-txt .alignright img {
    width: 100%;
    height: auto;
  }
}
.c-txt .alignleft {
  float: left;
  margin-right: 1.5em;
}
@media screen and (max-width: 767.98px) {
  .c-txt .alignleft {
    float: none;
    width: 100%;
    margin-right: 0;
  }
  .c-txt .alignleft img {
    width: 100%;
    height: auto;
  }
}
.c-txt .wp-block-embed {
  width: 40rem;
  height: 24rem;
  border-radius: 0.4rem;
  overflow: hidden;
  margin: 2rem auto;
}
@media screen and (max-width: 767.98px) {
  .c-txt .wp-block-embed {
    width: 100%;
    height: 24rem;
  }
}
.c-txt .wp-block-embed + * {
  margin-top: 1rem;
}
.c-txt .wp-block-embed .wp-block-embed__wrapper {
  min-width: 100%;
  height: 100%;
}
.c-txt .wp-block-embed iframe {
  width: 100%;
  height: 100%;
}
.c-txt iframe {
  width: 40rem;
  height: 24rem;
  margin: 2rem auto;
}
@media screen and (max-width: 767.98px) {
  .c-txt iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}
.c-txt .wp-block-image {
  margin-top: 4rem;
  margin-bottom: 4rem;
}
.c-txt .wp-block-image .aligncenter {
  max-width: 59rem;
  margin: 0 auto;
}
.c-txt .wp-element-caption {
  display: block !important;
  width: 100%;
}
.c-txt img,
.c-txt img[class*=wp-image-],
.c-txt img[class*=attachment-] {
  width: auto;
  height: auto;
  max-width: 100%;
}
.c-txt figcaption,
.c-txt .wp-caption-text {
  font-size: 1.4rem;
  line-height: 1.8;
}
@media screen and (max-width: 767.98px) {
  .c-txt figcaption,
  .c-txt .wp-caption-text {
    font-size: 1.2rem;
  }
}
.c-txt .wp-caption-text {
  margin-top: 1rem;
}
.c-txt .imgBlock {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
}
@media screen and (max-width: 767.98px) {
  .c-txt .imgBlock {
    gap: 1rem;
  }
}
.c-txt .imgBlock .img {
  width: 100%;
  border-radius: 2rem;
  overflow: hidden;
}
.c-txt .imgBlock .img.-half {
  width: calc(50% - 1rem);
}
@media screen and (max-width: 767.98px) {
  .c-txt .imgBlock .img.-half {
    width: calc(50% - 0.5rem);
  }
}
.c-txt .gdc_row {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
  width: 100%;
}
@media screen and (max-width: 767.98px) {
  .c-txt .gdc_row {
    gap: 1rem;
  }
}
.c-txt .gdc_row .gdc_column {
  float: none;
  border-radius: 2rem;
  overflow: hidden;
}
.c-txt .gdc_row .gdc_column.gdc_chalf {
  width: calc(50% - 1rem);
}
@media screen and (max-width: 767.98px) {
  .c-txt .gdc_row .gdc_column.gdc_chalf {
    width: calc(50% - 0.5rem);
  }
}
.c-txt .gdc_row .gdc_column .gdc_inner {
  padding: 0;
}
.c-txt .gdc_row .gdc_column .gdc_inner .wp-caption {
  width: 100% !important;
}

.c-detail {
  width: 75rem;
}
@media screen and (max-width: 767.98px) {
  .c-detail {
    width: 100%;
  }
}
.c-detail-head__catch {
  height: 41.8rem;
  border-radius: 2rem;
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .c-detail-head__catch {
    height: 24rem;
  }
}
.c-detail-head__catch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.c-detail-head__date {
  line-height: 1.75;
  margin: 1rem 0 0;
}
@media screen and (max-width: 767.98px) {
  .c-detail-head__date {
    font-size: 1.4rem;
  }
}
.c-detail-head-cat {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.2rem 0 0;
}
.c-detail-head-cat__item {
  line-height: 1.75;
}
@media screen and (max-width: 767.98px) {
  .c-detail-head-cat__item {
    font-size: 1.4rem;
  }
}
.c-detail-head-cat__item a {
  color: #5BA938;
  text-decoration: none;
}
.c-detail-head-cat__item a:hover {
  text-decoration: underline;
}
.c-detail-head-tag {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 0.5rem 0 0;
}
.c-detail-head-tag__item {
  font-size: 1.4rem;
  line-height: 1.75;
}
@media screen and (max-width: 767.98px) {
  .c-detail-head-tag__item {
    font-size: 1.2rem;
  }
}
.c-detail-head-tag__item a {
  text-decoration: none;
  border: 1px solid #5BA938;
  color: #333;
  transition: 0.3s;
  padding: 0 0.5rem;
}
.c-detail-head-tag__item a:hover {
  background: #5BA938;
  color: #fff;
}
.c-detail__txt {
  background: #fff;
  padding: 4rem 2rem;
  border-radius: 2rem;
  margin-top: 4rem;
}

.c-page {
  max-width: 108rem;
  margin: 0 auto;
  padding: 0 0 12rem;
}
@media screen and (max-width: 767.98px) {
  .c-page__scroll {
    overflow-x: scroll;
    margin-top: 2rem;
    padding: 0 0 2rem;
  }
}
.c-page__txt {
  background: #fff;
  border-radius: 2rem;
  padding: 3rem 4rem 6rem;
  margin-top: 11.5rem;
}
@media screen and (max-width: 767.98px) {
  .c-page__txt {
    padding: 4rem 1.5rem 6rem;
    margin-top: 4rem;
  }
}
.c-page-block {
  display: flex;
  gap: 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-page-block {
    flex-flow: column;
    gap: 2rem 0;
  }
}
.c-page-block.-reverse {
  flex-flow: row-reverse;
}
@media screen and (max-width: 767.98px) {
  .c-page-block.-reverse {
    flex-flow: column;
  }
}
.c-page-block + .c-page-block {
  margin-top: 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-page-block + .c-page-block {
    margin-top: 4rem;
  }
}
.c-page-block__inner {
  width: auto;
}
@media screen and (max-width: 767.98px) {
  .c-page-block__inner {
    width: 100%;
  }
}
.c-page-block__img {
  flex-shrink: 0;
  width: 42.8rem;
  height: 30rem;
  border-radius: 2rem;
  overflow: hidden;
}
@media screen and (max-width: 767.98px) {
  .c-page-block__img {
    width: 100%;
    height: 22rem;
  }
}
.c-page-block__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (max-width: 767.98px) {
  .c-page-block__img {
    width: 100%;
  }
}
.c-page-block__ttl {
  font-size: 2.6rem;
  font-weight: 700;
  color: #5BA938;
  margin: 0 0 4rem;
}
@media screen and (max-width: 767.98px) {
  .c-page-block__ttl {
    font-size: 1.8rem;
    margin: 0 0 1rem;
  }
}

/* 定義リスト  */
dl.sbs:after { content: ''; display: table; clear: both; }
dl.sbs > dt { float: left; }
dl.sbs.em3 > dd { padding-left: 3.5em; }
dl.sbs.em4 > dd { padding-left: 4.5em; }
dl.sbs.em5 > dd { padding-left: 5.5em; }
dl.sbs.em6 > dd { padding-left: 6.5em; }
dl.sbs.em7 > dd { padding-left: 7.5em; }
dl.sbs.em8 > dd { padding-left: 8.5em; }
dl.sbs.em9 > dd { padding-left: 9.5em; }
dl.sbs.em10 > dd { padding-left: 10.5em; }
dl.sbs.em11 > dd { padding-left: 11.5em; }
dl.sbs.em12 > dd { padding-left: 12.5em; }
dl.sbs.em13 > dd { padding-left: 13.5em; }
dl.sbs.em14 > dd { padding-left: 14.5em; }
dl.sbs.em15 > dd { padding-left: 15.5em; }

@media screen and (max-width: 767.98px) {
    dl.sbs > dt { float: none; font-weight: bold; }
    dl.sbs.em3 > dd,
    dl.sbs.em4 > dd,
    dl.sbs.em5 > dd,
    dl.sbs.em6 > dd,
    dl.sbs.em7 > dd,
    dl.sbs.em8 > dd,
    dl.sbs.em9 > dd,
    dl.sbs.em10 > dd,
    dl.sbs.em11 > dd,
    dl.sbs.em12 > dd,
    dl.sbs.em13 > dd,
    dl.sbs.em14 > dd,
    dl.sbs.em15 > dd { margin: 0 0 .5em; padding-left: 0; }
    dl.sp-float-left > dt { float: left !important;  }
}

.bold {
    font-weight: bold;
}
.green {
    color: #5BA938;
}

.sns-icon {
    display: flex;
    margin-left: 2rem;
}
.sns-icon img {
    width: 40px;
    height: 40px;
    margin-left: 2rem;
}
@media screen and (max-width: 767.98px) {
    .l-footer__company-info {
        flex-wrap: wrap;
        justify-content: center;
    }
    .sns-icon {
        margin: 2rem;
    }
    .sns-icon img {
        width: 52px;
        height: 52px;
        margin: 0 2rem;
    }
}

/* キャプション全体のレスポンシブ化 */
.wp-caption {
    max-width: 100% !important; /* 直書きのwidthより画面幅を優先 */
    width: auto !important;     /* 必要に応じて自動伸縮にする */
    height: auto;
}

/* キャプション内の画像も枠内に収まるようにする */
.wp-caption img {
    max-width: 100%;
    height: auto;
    display: block;
}
