@charset "UTF-8";
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.slick-track:before,
.slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none;
}
[dir="rtl"] .slick-slide {
  float: right;
}
.slick-slide img {
  display: block;
}
.slick-slide.slick-loading img {
  display: none;
}
.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .slick-slide {
  display: block;
}
.slick-loading .slick-slide {
  visibility: hidden;
}
.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}

/* -----------------------------------------------
* Plugins エントリーポイント
-------------------------------------------------- */
/* --------------------------------
l-page
----------------------------------- */
.l-page-cover {
  background-image: url(../img/common/cover.jpg);
  background-repeat: no-repeat;
  background-position: center 20%; /* 上部を少し下げる */
  background-size: cover;
  position: relative;
}
.l-page-cover.-bg01,
.l-page-cover.-bg02,
.l-page-cover.-bg03,
.l-page-cover.-bg04 {
  background-image: url(../img/common/cover.jpg);
}
.l-page-cover.-bg05 {
  background-image: url(../img/common/cover.jpg);
}
.l-page-cover.-bg06 {
  background-image: url(../img/home/gallery06.jpg);
}

/* .l-page-cover::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.7);
  background: linear-gradient(90deg, #2f9fede6 35%, #7cd5ca1f 35%);
  position: absolute;
  top: 0;
  left: 0;
} */
.l-page-cover__inner {
  padding: 100px 0 130px 0;
  position: relative;
  z-index: 1;
}
.l-page-cover__ttl {
  font-size: 12vw;
  font-weight: bold;
  line-height: 1.45;
  background: linear-gradient(90deg, #f0a0b0, #ffe6a0);
  background-clip: text;
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  margin-left: auto;
  margin-right: auto;
  max-width: 116.8rem;
  padding-left: 1.4rem;
  padding-right: 2.4rem;
  text-align: center;
  /* width: 35%; */
  position: relative;
  font-family: "Kiwi Maru", sans-serif;
}
.l-page-cover__ttl::before {
  display: none;
}
.l-page-cover__ttl span {
  display: block;
  font-size: 4vw;
  font-weight: 500;
}

.l-page-subWrapper {
  padding-top: 10vw;
  padding-bottom: 10vw;
}

/* --------------------------------
header
----------------------------------- */
.header-sp__top {
  height: 14vw;
}
.header-sp__logo {
  width: 45vw;
}
.header-sp .nav-drawer__list {
  color: #333;
}
.header-sp .nav-drawer__btn {
  background-image: linear-gradient(90deg, #f0a0b0 40%, #ffe6a0 100%);
  width: 300px;
}
.header-sp .nav-drawer__tel {
  color: #333;
}
.header-sp .nav-drawer__time {
  color: #333;
}
.header-sp .nav-drawer__time span {
  border-color: #333;
}
.header-sp .hamburger {
  background: linear-gradient(135deg, #f0a0b0, #FFCC3F);
}
/* --------------------------------
c-heading
----------------------------------- */
.c-heading01 {
  color: #002b4b;
  font-size: 9vw;
  font-weight: bold;
  line-height: 1.45;
  font-family: "Kiwi Maru", sans-serif;
}
.c-heading01 span {
  display: block;
  color: #f0a0b0;
  font-size: 4vw;
  margin-top: 1vw;
  font-weight: 500;
}
.c-heading01_center {
  text-align: center;
}
.c-heading01_border {
  padding-bottom: 10px;
  border-bottom: 2px solid #60c0f0;
}

.c-heading02 {
  background: linear-gradient(90deg, #f0a0b0, #60c0f0, #b0d000);
  /* background: #60c0f0; */
  padding: 1.5rem;
  color: #fff;
  font-size: 2.5rem;
  font-weight: 500;
}

.c-heading03 {
  font-size: 2rem;
  line-height: 1.3;
  font-weight: 600;
  color: #333;
  padding: 1.5rem 1.5rem 1.5rem 0.5rem;
  border-bottom: 2px solid;
  -o-border-image: linear-gradient(to right, #f0a0b0, #60c0f0, #b0d000) 1;
  border-image: linear-gradient(to right, #f0a0b0, #60c0f0, #b0d000) 1;
  font-family: "Kiwi Maru", sans-serif;
}

/* --------------------------------
c-text
----------------------------------- */
.c-text {
  font-size: 4vw;
  line-height: 1.7;
}

/* --------------------------------
c-news
----------------------------------- */
.c-news__item {
  border-bottom: 1px solid #e5e5e5;
}
.c-news__item:first-child {
  border-top: 1px solid #e5e5e5;
}
.c-news__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 2rem 0;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.c-news__img {
  position: relative;
  width: 10rem;
  padding-top: 10rem;
  margin-right: 1rem;
}
.c-news__img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.c-news__body {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.c-news__ttl {
  font-size: 1.8rem;
  font-weight: 500;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  padding-left: 2rem;
  position: relative;
}
.c-news__ttl::before {
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 2px;
  background: #f87468;
}
.c-news__time {
  display: block;
  color: #aaa;
  font-size: 14px;
/*   padding-top: 1rem; */
}
.c-news__txt {
  font-size: 4vw;
  padding-top: 2rem;
}
.c-news__txt p {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.5;
}
.c-news__txt p + p {
  display: none;
}

/* --------------------------------
btn
----------------------------------- */
.btn {
  background-color: #fff;
  color: #60c0f0;
}
.btn:hover {
  color: #fff;
}
.btn:hover::after {
  background: linear-gradient(135deg, #f0a0b0, #60c0f0, #b0d000);
}

.btn.-color {
  /*   background: -webkit-gradient(linear, left top, right top, from(#60c0f0), to(#ef6c00));
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%); */
  background: #60c0f0;
  border: 1px solid #60c0f0;
}
.btn.-color:hover {
  color: #fff;
}

/* --------------------------------
c-card
----------------------------------- */
.c-card {
  width: 100%;
  background-color: #fff;
  -webkit-box-shadow: 0px 0px 5px rgba(160, 160, 160, 0.2);
  box-shadow: 0px 0px 5px rgba(160, 160, 160, 0.2);
  border-radius: 1rem;
}
.c-card__img-wrap {
  overflow: hidden;
  /*   border-radius: 1rem 1rem 0 0; */
}
.c-card__img-wrap img {
  max-height: 250px;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 1rem 1rem 0 0;
}
.c-card__body {
  padding: 2rem;
}
.c-card__body-top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}
.c-card__time {
  -webkit-flex-shrink: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-right: 4vw;
}
.c-card__body-bottom {
  font-size: 4vw;
  line-height: 1.5;
  margin-top: 2vw;
  padding-top: 1rem;
}
.c-card .address {
  display: block;
  text-align: center;
  font-size: 2rem;
  font-weight: bold;
  color: #60c0f0;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.c-card .info {
  padding-top: 2rem;
}
.c-card .row {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -webkit-align-items: start;
  -ms-flex-align: start;
  align-items: start;
  line-height: 1.5;
  padding: 2rem 0 2rem;
  border-bottom: 1px solid #e5e5e5;
}
.c-card .left {
  width: 10rem;
  margin-right: 1rem;
}
.c-card .label {
  display: block;
  font-size: 1.2rem;
  background-color: #60c0f0;
  color: #fff;
  text-align: center;
  padding: 0.2rem;
}
.c-card .right {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.c-card .text {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 1.5rem;
}
.c-card .btn-wrap {
  padding-top: 2rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.c-card .btn.-color {
  background: #76af65;
  border: 1px solid #76af65;
}

/* --------------------------------
c-tag
----------------------------------- */
.c-tag {
  background-image: linear-gradient(90deg, #f0a0b0 40%, #ffe6a0 100%);
  color: #fff;
  font-size: 4vw;
  width: 35vw;
  height: 2.6rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-flex-shrink: 0;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

/* --------------------------------
c-media
----------------------------------- */
.c-media__body {
  padding-top: 2rem;
}
.c-media__ttl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  color: #60c0f0;
  line-height: 1.5;
  border-bottom: 2px solid #b8312d;
  padding-bottom: 5px;
}
.c-media__ttl .ja {
  font-size: 5vw;
  font-weight: bold;
}
.c-media__txt {
  line-height: 1.5;
  padding-top: 2.7rem;
}

/* --------------------------------
c-accordion
----------------------------------- */
.c-accordion {
  border-bottom: 1px solid #9da3a7;
}
.c-accordion__title {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  padding: 4vw 6vw 4vw 0;
  position: relative;
  font-size: 3.5vw;
  line-height: 1.75;
}
.c-accordion__title span {
  width: 8vw;
  height: 8vw;
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#60c0f0),
    to(#ef6c00)
  );
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%);
  color: #fff;
  font-weight: bold;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-right: 3vw;
}
.c-accordion__title::after {
  content: "";
  width: 2vw;
  height: 2vw;
  border-top: 1px solid #141414;
  border-right: 1px solid #141414;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
  position: absolute;
  top: 45%;
  right: 2vw;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.c-accordion__title.open::after {
  top: 41%;
  -webkit-transform: rotate(135deg);
  transform: rotate(135deg);
}
.c-accordion__content {
  display: none;
  background-color: #edf4fa;
  padding: 3vw;
}
.c-accordion__content p {
  font-size: 3vw;
  line-height: 1.75;
}

/* --------------------------------
c-flexbox
----------------------------------- */
.c-flexbox01__body {
  padding-top: 3rem;
}
.c-flexbox02__body {
  padding-top: 2rem;
}

/* --------------------------------
c-table
----------------------------------- */
.c-table01 {
  width: 100%;
  text-align: left;
}
.c-table01 tr {
  display: block;
  border-top: 1px solid #cecece;
  line-height: 1.5;
  padding: 3vw 1.8rem;
}
.c-table01 tr:last-child {
  border-bottom: 1px solid #cecece;
}
.c-table01 th {
  width: 22vw;
  vertical-align: top;
  color: #60c0f0;
  font-weight: 500;
}

.c-table02 {
  width: 100%;
  text-align: left;
}
.c-table02 tr {
  display: block;
  border-top: 1px solid #cecece;
  line-height: 1.5;
}
.c-table02 tr:last-child {
  border-bottom: 1px solid #cecece;
}
.c-table02 th,
.c-table02 td {
  padding: 1.2rem;
  font-size: 1.4rem;
}
.c-table02 th {
  width: 22vw;
  color: #002b4b;
  font-weight: 500;
  background-color: #f7f0f0;
}
.c-table02 td span {
  display: block;
}

/* --------------------------------
c-column
----------------------------------- */
.c-column-2__item:not(:first-of-type) {
  margin-top: 10vw;
}

.c-column-3 {
  gap: 3rem;
}
.c-column-3__item:not(:first-of-type) {
  margin-top: 10vw;
}

/* --------------------------------
pagination
----------------------------------- */
.pagination .page-numbers {
  border: 1px solid #60c0f0;
  color: #60c0f0;
}
.pagination .page-numbers.current {
  background: -webkit-gradient(
    linear,
    left top,
    right top,
    from(#60c0f0),
    to(#ef6c00)
  );
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%);
}
.pagination .page-numbers.next,
.pagination .page-numbers.prev {
  border: 1px solid #60c0f0;
}

.pagination-wrapper .pagination-wrapper__sp.sp-only .page-numbers {
  color: #60c0f0;
}
.pagination-wrapper .pagination-wrapper__sp.sp-only .page-numbers a {
  border: 1px solid #60c0f0;
}

/* --------------------------------
footer
----------------------------------- */
.footer {
  background-color: #f7f3f0;
  color: #333;
}
.footer__copyright {
  background: #e8643c;
  position: relative;
}
/* .footer__copyright::before {
	content: "";
    position: absolute;
    background-image: url(../img/common/footer-contact-bg.png);
    background-repeat: repeat-x;
    top: -200%;
    left: 0;
    width: 100%;
    height: 200%;
    background-size: contain;
} */

.footer-contact {
  /*   background-color: rgba(186, 186, 33, 0.08); */
  /* background-image: url(../img/sub/flow/sec01-bg.jpg); */
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  background: #f7f3f0;
}
.footer-contact__inner {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
.footer-contact .left__txt {
  text-align: center;
  line-height: 1.5;
  padding-top: 3rem;
  color: #fff;
}
.footer-contact .left__tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding-top: 3rem;
  color: #fff;
}
.footer-contact .left .tel__link {
  color: #60c0f0;
  font-size: 7vw;
  font-weight: bold;
  padding-left: 7vw;
  pointer-events: all;
  position: relative;
  color: #fff;
}
.footer-contact .left .tel__link::before {
  background-image: url(../img/common/tel-white.svg);
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 0;
  content: "";
  position: absolute;
  height: 5vw;
  left: 0;
  top: 1vw;
  width: 5vw;
}
.footer-contact .left .tel__opentime {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 5vw;
}
.footer-contact .left .tel__opentime span {
  color: #fff;
}
.footer-contact .left .tel__opentime span:nth-of-type(1) {
  font-size: 5vw;
  padding: 1vw 3vw;
  border: 1px solid #fff;
}
.footer-contact .left .tel__opentime span:nth-of-type(2) {
  font-size: 5vw;
  margin-left: 3vw;
}
.footer-contact .left__btn-wrap {
  padding-top: 3rem;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.footer-contact__right {
  /* padding: 20px !important; */
  /* background-image: url("../img/home/sec02-03.jpg"); */
  background-position: center;
  background-size: cover;
}
.footer-contact .right__map {
  padding-top: 56.25%;
  overflow: hidden;
  position: relative;
}
.footer-contact .right__map iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

/* --------------------------------
utility
----------------------------------- */
.u-mt10 {
  margin-top: 1rem;
}

.u-mt20 {
  margin-top: 2rem;
}

.u-mt30 {
  margin-top: 3rem;
}

.u-mt40 {
  margin-top: 4rem;
}

.u-mt50 {
  margin-top: 5rem;
}

.u-mt60 {
  margin-top: 6rem;
}

.u-mt70 {
  margin-top: 7rem;
}

.u-mt80 {
  margin-top: 8rem;
}

.u-mt90 {
  margin-top: 9rem;
}

.u-mt100 {
  margin-top: 10rem;
}

.u-mb10 {
  margin-bottom: 1rem;
}

.u-mb20 {
  margin-bottom: 2rem;
}

.u-mb30 {
  margin-bottom: 3rem;
}

.u-mb40 {
  margin-bottom: 4rem;
}

.u-mb50 {
  margin-bottom: 5rem;
}

.u-mb60 {
  margin-bottom: 6rem;
}

.u-mb70 {
  margin-bottom: 7rem;
}

.u-mb80 {
  margin-bottom: 8rem;
}

.u-mb90 {
  margin-bottom: 9rem;
}

.u-mb100 {
  margin-bottom: 10rem;
}

.u-mr10 {
  margin-right: 1rem;
}

.u-mr20 {
  margin-right: 2rem;
}

.u-mr30 {
  margin-right: 3rem;
}

.u-mr40 {
  margin-right: 4rem;
}

.u-mr50 {
  margin-right: 5rem;
}

.u-pt10 {
  padding-top: 1rem;
}

.u-pt20 {
  padding-top: 2rem;
}

.u-pt30 {
  padding-top: 3rem;
}

.u-pt40 {
  padding-top: 4rem;
}

.u-pt50 {
  padding-top: 5rem;
}

.u-pt60 {
  padding-top: 6rem;
}

.u-pt70 {
  padding-top: 7rem;
}

.u-pt80 {
  padding-top: 8rem;
}

.u-pt90 {
  padding-top: 9rem;
}

.u-pt100 {
  padding-top: 10rem;
}

.u-pb10 {
  padding-bottom: 1rem;
}

.u-pb20 {
  padding-bottom: 2rem;
}

.u-pb30 {
  padding-bottom: 3rem;
}

.u-pb40 {
  padding-bottom: 4rem;
}

.u-pb50 {
  padding-bottom: 5rem;
}

.u-pb60 {
  padding-bottom: 6rem;
}

.u-pb70 {
  padding-bottom: 7rem;
}

.u-pb80 {
  padding-bottom: 8rem;
}

.u-pb90 {
  padding-bottom: 9rem;
}

.u-pb100 {
  padding-bottom: 10rem;
}

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

.u-tar {
  text-align: right;
}

.u-tal {
  text-align: left;
}

.u-dfc {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
}

/* -----------------------------------------------
* Modules エントリーポイント
-------------------------------------------------- */
main.home {
  background-color: #fff;
}

.p-home-sec01 {
  margin-top: 5rem;
  margin-bottom: 5rem;
  /* background-image: url(../img/home/top-bg.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: right; */
}
.p-home-sec01__cont {
  padding-top: 8vw;
}
.p-home-sec01__btn-wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding-top: 3rem;
}
.home-news__title span {
  background: -webkit-gradient(
      linear,
      left top,
      left bottom,
      from(#ef6c00),
      to(#ef6c00)
    )
    0 100%/0 1px no-repeat;
  background: linear-gradient(#ef6c00, #ef6c00) 0 100%/0 1px no-repeat;
}

.p-home-sec02__inner {
  padding-top: 6rem;
  text-align: center;
}
.p-home-sec02 .c-heading01 {
  font-size: 4.5rem;
  margin: 0 0 3rem 0;
  position: relative;
  display: inline-block;
  padding-bottom: 10px;
}

.p-home-sec02 .c-heading01::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 110%;
  height: 10px;
  background: linear-gradient(to right, #d76d63, #ffcf22);
  transform: translateX(-50%);
  z-index: -1;
  bottom: -5px;
}

.p-home-sec02__txt {
  line-height: 1.5;
  text-align: center;
}
.p-home-sec02__item-wrap {
  padding-top: 5rem;
}
.p-home-sec02 .item {
  color: #fff;
}
.p-home-sec02 .item__link {
  display: block;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  position: relative;
}
.p-home-sec02 .item__link01 {
  background-image: url(../img/home/sec02-01.jpg);
  border: 3px solid #d76d63;
}
.p-home-sec02 .item__link02 {
  background-image: url(../img/home/sec02-02.jpg);
  border: 3px solid #ffcf22;
}
.p-home-sec02 .item__link03 {
  background-image: url(../img/home/sec02-03.jpg);
  border: 3px solid #639f77;
}
.p-home-sec02 .item__link::after {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.2);
  position: absolute;
  top: 0;
  left: 0;
}
.p-home-sec02 .item__inner {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 8rem 2rem;
}
.p-home-sec02 .item__ttl {
  font-size: 6vw;
  font-weight: bold;
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}
.p-home-sec02 .item__txt {
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
  line-height: 1.5;
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  padding-top: 2rem;
}
.p-home-sec02 .item__readmore {
  position: relative;
  margin-top: 3rem;
  text-shadow: 0 0 6px rgba(0, 0, 0, 0.16);
}
.p-home-sec02 .item__readmore::after {
  content: "";
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
}

.p-home-sec03 {
  /*   background: -webkit-gradient(linear, left top, right top, from(#60c0f0), to(#ef6c00));
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%); */
  background: #60c0f0;
  margin-top: 10rem;
}
.p-home-sec03__ttl {
  position: relative;
  z-index: 1;
  color: #fff;
}
.p-home-sec03__ttl span {
  color: #fff;
}
.p-home-sec03 .home-shop__text {
  background: #60c0f0;
}

.p-company-sec01__cont02 {
  padding-top: 4rem;
}

.p-business-sec01__map-wrap {
  padding-top: 30rem;
  overflow: hidden;
  position: relative;
}
.p-business-sec01__map-wrap iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.p-flow-sec01 {
  /* background-image: url(../img/sub/about/about-bg.jp); */
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  background: linear-gradient(135deg, #f0a0b0, #60c0f0, #b0d000);
  position: relative;
  padding-bottom: 14rem;
}
/* .p-flow-sec01::before {
  content: "";
  width: 250px;
  height: 250px;
  position: absolute;
  top: -7%;
  right: 2%;
  background-image: url(../img/home/illust01.svg);
  background-size: contain;
  background-repeat: no-repeat;
} */
.p-flow-sec01 .cont {
  background-color: #fff;
  box-shadow: 0px 0px 5px rgba(160, 160, 160, 0.2);
  padding: 5rem 2rem;
  border-radius: 14px;
}
.p-flow-sec01 .cont .ttl {
  color: #4e9f36;
  font-size: 5vw;
  font-weight: bold;
  line-height: 1.3;
  border-bottom: 2px solid #4e9f36;
  padding: 0 0.5rem 0.5rem 0.5rem;
}
.p-flow-sec01 .cont .top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
}
.p-flow-sec01 .cont .bottom {
  margin-top: -5rem;
  padding-top: 5rem;
}
.p-flow-sec01 .cont .bottom__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 5rem;
}
.p-flow-sec01 .cont .promise {
  background-color: #dff4d9;
  color: #4e9f36;
  text-align: center;
  line-height: 1.5;
  font-weight: bold;
  padding: 2rem;
  margin-top: 5rem;
  font-size: 2rem;
}
.p-flow-sec02 .flow_content .row {
  border-bottom: 1px solid #333;
  padding-bottom: 20px;
}
.p-flow-sec02 .flow_content .row + .row {
  margin-top: 20px;
}
.p-flow-sec02 .flow_content .detail {
  padding: 0 0 0 50px;
  margin-top: 10px;
  position: relative;
}
.p-flow-sec02 .flow_content .detail .num {
  width: 40px;
  height: 40px;
  line-height: 40px;
  font-size: 2.5rem;
  border-radius: 50%;
  color: #fff;
  background-color: #a9783f;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
}
.p-flow-sec02 .flow_content .detail .head {
  font-size: 2rem;
  padding: 10px 0 20px 0;
}
.p-flow-sec02 .flow_content .detail .text {
  line-height: 1.5;
}
.p-flow-sec02 .promise {
  background-color: #dff4d9;
  color: #4e9f36;
  text-align: center;
  line-height: 1.5;
  font-weight: bold;
  padding: 2rem;
  font-size: 2rem;
}
.sub-archive-proprty .sub-archive__top {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -webkit-align-items: start;
  -ms-flex-align: start;
  align-items: start;
}
.sub-archive-proprty .cat-wrap {
  width: 100%;
  border: 3px solid #c69b30;
}
.sub-archive-proprty .cat-wrap ul {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: -1rem;
  padding: 1rem;
}
.sub-archive-proprty .cat-wrap ul li {
  width: 49%;
  margin-top: 1rem;
}
.sub-archive-proprty .cat-wrap ul li a {
  padding: 1.3rem;
  background-color: #c69b30;
  color: #fff;
  text-align: center;
  -webkit-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.sub-archive-proprty .cat-wrap ul li a:hover {
  opacity: 0.8;
}
.sub-archive-proprty .cat-wrap02 {
  border: 3px solid #82b31a;
}
.sub-archive-proprty .cat-wrap02 ul li a {
  background-color: #82b31a;
}
.sub-archive-proprty .sub-archive__category-name {
  color: #333;
  text-align: center;
  padding: 1rem;
  font-weight: 500;
}
.sub-archive-proprty .c-card {
  border: #ddd 1px solid;
  box-shadow: none;
}

.sub-single__title {
  color: #333;
}
.sub-single__main {
  border-top: 1px solid #60c0f0;
}

.sub-single-property .property-slider__img-wrap {
  position: relative;
  padding-top: 25rem;
}
.sub-single-property .property-slider__img-wrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /*   -o-object-fit: cover;
     object-fit: cover; */
  -o-object-fit: contain;
  object-fit: contain;
}
.sub-single-property .property-slider__arw {
  position: absolute;
  top: 30%;
  z-index: 1;
  cursor: pointer;
  width: 4rem;
  height: 5rem;
  background-color: #ef6c00;
}
.sub-single-property .property-slider__arw.prev::before,
.sub-single-property .property-slider__arw.next::before {
  content: "";
  display: inline-block;
  width: 1rem;
  height: 1rem;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  position: absolute;
}
.sub-single-property .property-slider__arw.prev {
  border-top-right-radius: 0.3rem;
  border-bottom-right-radius: 0.3rem;
  left: 0;
}
.sub-single-property .property-slider__arw.prev::before {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(-135deg);
  transform: translateY(-50%) rotate(-135deg);
  left: 1.8rem;
}
.sub-single-property .property-slider__arw.next {
  border-top-left-radius: 0.3rem;
  border-bottom-left-radius: 0.3rem;
  right: 0;
}
.sub-single-property .property-slider__arw.next::before {
  top: 50%;
  -webkit-transform: translateY(-50%) rotate(45deg);
  transform: translateY(-50%) rotate(45deg);
  right: 1.8rem;
}
.sub-single-property .property-slider__dots {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  /* flex-wrap: wrap; */
  padding-top: 2rem;
  margin-top: -0.5rem;
}
.sub-single-property .property-slider__dots li {
  opacity: 0.5;
  position: relative;
  width: 13%;
  padding-top: 7%;
  cursor: pointer;
  margin-right: 0.5%;
  margin-top: 0.5rem;
}
.sub-single-property .property-slider__dots li:last-child {
  margin-right: 0;
}
.sub-single-property .property-slider__dots li img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.sub-single-property .property-slider__dots .slick-active {
  opacity: 1;
  border: 1px solid #ef6c00;
}
.sub-single-property .info .point {
  background-color: #f7fcf5;
  border: 2px solid #4e9f36;
  border-radius: 0.5rem;
  padding: 2rem 1rem;
  /*   background-image: url(../img/sub/property/si-sa.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: right center; */
}
.sub-single-property .info .point__head {
  color: #4e9f36;
  font-weight: bold;
  font-size: 5vw;
}
.sub-single-property .info .table01 .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #aaa;
  border-right: 1px solid #aaa;
  border-left: 1px solid #aaa;
  line-height: 1.5;
  position: relative;
}
.sub-single-property .info .table01 .row:last-child {
  border-bottom: 1px solid #aaa;
}
.sub-single-property .info .table01 .row .head,
.sub-single-property .info .table01 .row .body {
  padding: 1.2rem;
  font-size: 1.4rem;
}
.sub-single-property .info .table01 .row .head {
  width: 22vw;
  color: #60c0f0;
  font-weight: 500;
  background-color: #f5f8f7;
}
.sub-single-property .info .table01 .row .body {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.sub-single-property .info .table02 .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  border-top: 1px solid #aaa;
  border-right: 1px solid #aaa;
  border-left: 1px solid #aaa;
}
.sub-single-property .info .table02 .row:last-child {
  border-bottom: 1px solid #aaa;
}
.sub-single-property .info .table02 .row .head,
.sub-single-property .info .table02 .row .body {
  padding: 1.2rem;
  font-size: 1.4rem;
  line-height: 1.4;
}
.sub-single-property .info .table02 .row .head {
  width: 22vw;
  color: #60c0f0;
  font-weight: 500;
  background-color: #f5f8f7;
}
.sub-single-property .info .table02 .row .body {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.sub-single-property .info .table02 .row .body a {
  color: #60c0f0;
  text-decoration: underline;
}
.sub-single-property .info .map {
  padding-top: 25rem;
  overflow: hidden;
  position: relative;
}
.sub-single-property .info .map iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.sub-single-property .banner__item {
  border: 2px solid #aaa;
}
.sub-single-property .banner__item:not(:first-of-type) {
  margin-top: 10vw;
}
.sub-single-property .download__col {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: -2rem;
}
.sub-single-property .download__col a {
  width: 49%;
  margin-top: 2rem;
}

.p-contact-sec01 .sub-contact__tel {
  color: #002b4b;
}
.p-contact-sec01 .sub-contact__time span {
  color: #002b4b;
}
.p-contact-sec01 .sub-contact__time span:nth-of-type(1) {
  border: 1px solid #002b4b;
}
.p-contact-sec01 .sub-contact__item dt .required {
  background-color: #4e9f36;
}
.p-contact-sec01 .sub-contact__submit input {
  /*   background: -webkit-gradient(linear, left top, right top, from(#60c0f0), to(#ef6c00));
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%); */
  background: #60c0f0;
}

.p-sell-sec01 .tab__text {
  text-align: center;
  display: block;
  font-weight: bold;
  font-size: 2rem;
}
.p-sell-sec01 .tab__wrap {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: -1rem;
}
.p-sell-sec01 .tab__item {
  width: 100%;
  text-align: center;
  border: 2px solid #b7b7b7;
  margin-top: 1rem;
}
.p-sell-sec01 .tab__link {
  font-weight: bold;
  color: #b7b7b7;
  font-size: 1.8rem;
  padding: 1.5rem;
}
.p-sell-sec01 .js-tab-active.tab__item {
  border-color: #ef6c00;
}
.p-sell-sec01 .js-tab-active.tab__item .tab__link {
  color: #ef6c00;
}
.p-sell-sec01 .tab-cont {
  display: none;
  opacity: 0;
}
.p-sell-sec01 .tab-cont.js-tab-cont-active {
  display: block;
  -webkit-animation-name: displayAnime;
  animation-name: displayAnime;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
@-webkit-keyframes displayAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes displayAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.p-sell-sec01 .sub-contact__item dt {
  line-height: 1.5;
}
.p-sell-sec01 .sub-contact__item dt .required {
  background-color: #ef6c00;
}
.p-sell-sec01 .sub-contact__item dd .text {
  line-height: 2;
}
.p-sell-sec01 .sub-contact__item .very-short {
  width: 100%;
}
.p-sell-sec01 .sub-contact__item .select {
  background-color: #f8f8f8;
  border: 1px solid #9da3a7;
  border-radius: 0.4rem;
  padding: 0.75rem;
}
.p-sell-sec01 .sub-contact__item .radio label {
  line-height: 2;
}
.p-sell-sec01 .sub-contact__item .radio input {
  /* 色の変更※枠線の色は変更できない */
  accent-color: #ef6c00;
}
.p-sell-sec01 .sub-contact__item .copy-button {
  display: inline-block;
  margin-top: 1rem;
  border: 1px solid #aaa;
  padding: 1rem;
  border-radius: 0.5rem;
}
.p-sell-sec01 .sub-contact__submit input {
  /*   background: -webkit-gradient(linear, left top, right top, from(#60c0f0), to(#ef6c00));
  background: linear-gradient(90deg, #60c0f0 0%, #ef6c00 100%); */
  background: #60c0f0;
}

.sub-thanks__link a {
  color: #ef6c00;
  border-bottom: 1px solid #ef6c00;
}

.sub-404__link a {
  color: #ef6c00;
  border-bottom: 1px solid #ef6c00;
}
.sell_lead_area .point {
  background-color: rgba(194, 73, 42, 0.1);
  border: 2px solid #b8312d;
  border-radius: 0.5rem;
  padding: 1rem 2rem 3rem 2rem;
  background-image: url(../img/sub/property/si-sa.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: right center;
  text-align: center;
  line-height: 1.7;
}
.sell_lead_area {
  margin: 8rem 0 0 0;
}
.sell_lead_area img {
  max-width: 900px;
  margin: 0 auto;
}
.sell_lead_area .point span {
  color: #60c0f0;
}
.sell_lead_area .point .underline {
  text-decoration: underline;
}

/* -----------------------------------------------
* Page エントリーポイント
-------------------------------------------------- */

@media (min-width: 768px) {
  .l-page-cover__inner {
    /* padding: 190px 0 190px 0; */
    height: 70vh;
  }
  .l-page-cover__ttl {
    font-size: 5rem;
  }
  .l-page-cover__ttl span {
    font-size: 1.6rem;
  }
  .l-page-subWrapper {
    padding-top: 6rem;
    padding-bottom: 10rem;
  }
  .header {
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .header__main {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .header__nav {
    margin-right: 5rem;
  }
  .header__link {
    color: #333;
    position: relative;
  }
  /* .header__link::after {
    content: "";
    width: 7px;
    height: 7px;
    border-top: 2px solid #60c0f0;
    border-right: 2px solid #60c0f0;
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    position: absolute;
    top: 30%;
    left: -14px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  } */
  .header__top {
    padding-top: 0;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .header__tel {
    color: #333;
  }
  .header__time {
    padding-top: 1rem;
    margin-left: 0;
  }
  .header__time span {
    color: #333;
  }
  .header__btn {
    background: linear-gradient(135deg, #f0a0b0, #FFCC3F);
  }
  .header__item-child {
    position: relative;
  }
  .child__wrap {
    position: absolute;
    visibility: hidden;
    opacity: 0;
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    min-width: 20rem;
    width: 100%;
    top: 100%;
    left: 0;
    background-color: rgba(255, 255, 255, 0.8);
    padding-top: 2rem;
  }
  .child__link {
    display: block;
    letter-spacing: 0.1em;
    padding: 1rem 1rem;
    font-size: 1.4rem;
  }
  .child__link:hover {
    opacity: 0.8;
  }
  .header__item-child:hover > .child__wrap {
    visibility: visible;
    opacity: 1;
  }
  .c-heading01 {
    font-size: 4.5rem;
  }
  .c-heading01 span {
    font-size: 1.6rem;
    margin-top: 0;
  }
  .c-heading03 {
    font-size: 3.5rem;
  }
  .c-text {
    font-size: 1.6rem;
  }
  .c-news__link:hover {
    opacity: 0.8;
  }
  .c-news__img {
    width: 10%;
    padding-top: 7rem;
    position: relative;
    margin-right: 3rem;
  }
  .c-news__ttl {
    /*     font-size: 2.4rem; */
  }
  .c-news__time {
    font-size: 1.2rem;
  }
  .c-news__txt {
    font-size: 1.6rem;
  }
  .c-card {
    width: 31.5%;
  }
  .c-card__time {
    font-size: 1.2rem;
    margin-right: 2rem;
  }
  .c-card__body-bottom {
    font-size: 1.6rem;
    margin-top: 0;
  }
  .c-card_link .c-card__ttl {
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
    background: -webkit-gradient(
        linear,
        left top,
        left bottom,
        from(#ef6c00),
        to(#ef6c00)
      )
      0 100%/0 1px no-repeat;
    background: linear-gradient(#ef6c00, #ef6c00) 0 100%/0 1px no-repeat;
  }
  .c-card_link:hover .c-card__ttl {
    background-size: 100% 1px;
  }
  .c-tag {
    font-size: 1.2rem;
    width: 10rem;
  }
  .c-media {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .c-media__img-wrap {
    -webkit-box-flex: 0;
    -webkit-flex: 0 1 45%;
    -ms-flex: 0 1 45%;
    flex: 0 1 45%;
    margin-right: 3.3333%;
  }
  .c-media__body {
    width: 50rem;
    padding-top: 0;
  }
  .c-media__ttl .ja {
    font-size: 2.4rem;
  }
  .c-media_reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .c-media_reverse .c-media__img-wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -webkit-justify-content: end;
    -ms-flex-pack: end;
    justify-content: end;
    margin-right: 0;
  }
  .c-media_reverse .c-media__body {
    margin-right: 3.3333%;
  }
  .c-accordion__title {
    font-size: 1.6rem;
    padding: 3rem 2rem;
  }
  .c-accordion__title span {
    width: 3.3rem;
    height: 3.3rem;
    margin-right: 1rem;
  }
  .c-accordion__title::after {
    width: 0.9rem;
    height: 0.9rem;
    right: 2.3rem;
  }
  .c-accordion__content {
    padding: 2.9rem 2rem;
  }
  .c-accordion__content p {
    font-size: 1.6rem;
  }
  .c-flexbox01 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .c-flexbox01__head {
    width: 50rem;
    margin-right: 3.3333%;
  }
  .c-flexbox01__body {
    width: 50rem;
    padding-top: 0;
  }
  .c-flexbox02 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -webkit-align-items: start;
    -ms-flex-align: start;
    align-items: start;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-pack: start;
    -webkit-justify-content: start;
    -ms-flex-pack: start;
    justify-content: start;
  }
  .c-flexbox02__head {
    width: 50rem;
  }
  .c-flexbox02__body {
    width: 50rem;
    margin-right: 3.3333%;
    padding-top: 0;
  }
  .c-table01 tr {
    padding: 1.8rem;
  }
  .c-table01 th {
    width: 13rem;
  }
  .c-table02 th,
  .c-table02 td {
    font-size: 1.6rem;
    padding: 1.8rem;
  }
  .c-table02 th {
    width: 25rem;
  }
  .c-column-2 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .c-column-2__item:not(:first-of-type) {
    margin-top: 0;
  }
  .c-column-2__item {
    width: 50%;
  }
  .c-column-3 {
    gap: 3rem 2.75%;
  }
  .c-column-3 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .c-column-3__item:not(:first-of-type) {
    margin-top: 0;
  }
  .c-column-3__item {
    width: 31.5%;
  }
  .footer-contact__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    flex-direction: row-reverse;
    gap: 2rem;
    justify-content: center;
  }
  .footer-contact__left {
    /* width: 50%; */
  }
  .footer-contact .left .tel__link {
    font-size: 4.4rem;
    padding-left: 2.3rem;
  }
  .footer-contact .left .tel__link::before {
    height: 2.744rem;
    left: -2rem;
    margin: auto;
    top: 0.6rem;
    width: 2.744rem;
  }
  .footer-contact .left .tel__opentime {
    margin-top: 1.2rem;
  }
  .footer-contact .left .tel__opentime span:nth-of-type(1) {
    font-size: 1.6rem;
    padding: 0.4rem 1.2rem;
  }
  .footer-contact .left .tel__opentime span:nth-of-type(2) {
    font-size: 1.8rem;
    margin-left: 0.9rem;
  }
  .footer-contact__right {
    /* width: 50%; */
    padding-top: 0;
  }
  .home-mv__catch img {
    max-width: 800px;
  }
  .p-home-sec01__cont {
    padding-top: 3rem;
  }
  .p-home-sec02__item-wrap {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding-top: 5rem;
  }
  .p-home-sec02__item {
    width: 33.333%;
    overflow: hidden;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .p-home-sec02 .item__link {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    flex: 1;
    -webkit-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out;
  }
  .p-home-sec02 .item__link:hover {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  .p-home-sec02 .item__inner {
    padding: 11rem 5rem;
  }
  .p-home-sec02 .item__ttl {
    font-size: 2.4rem;
  }
  .p-home-sec02 .item__readmore {
    margin-top: 5rem;
  }
  .p-home-sec03 {
    background: #fff;
    margin-top: 0;
  }
  .p-home-sec03__inner {
    padding-bottom: 11rem;
  }
  .p-company-sec01__cont02 {
    padding-top: 8rem;
  }
  .p-flow-sec01 .cont .ttl {
    font-size: 2.5rem;
  }
  .p-flow-sec01 .cont .bottom {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .p-flow-sec01 .cont .bottom__item {
    width: 50%;
    padding: 0 2rem;
  }
  .p-flow-sec02 .flow_content {
    padding: 40px 80px;
  }
  .p-flow-sec02 .flow_content .row {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    padding-bottom: 30px;
  }
  .p-flow-sec02 .flow_content .row + .row {
    margin-top: 30px;
  }
  .p-flow-sec02 .flow_content .img {
    width: 40%;
  }
  .p-flow-sec02 .flow_content .detail {
    width: 60%;
    padding: 0 0 0 100px;
  }
  .p-flow-sec02 .flow_content .detail .num {
    width: 80px;
    height: 80px;
    line-height: 80px;
    font-size: 3.6rem;
  }
  .p-flow-sec02 .flow_content .detail .head {
    font-size: 2.4rem;
    padding: 20px 0;
    font-weight: 700;
    color: #60c0f0;
  }
  .sub-archive-proprty .inner {
    max-width: 130rem;
  }
  .sub-archive-proprty .cat-wrap ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .sub-archive-proprty .cat-wrap ul li {
    width: 100%;
  }
  .sub-archive-proprty .sub-archive__box {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .sub-archive-proprty .sub-archive__colL {
    width: 20%;
    margin-right: 2rem;
  }
  .sub-archive-proprty .sub-archive__colR {
    width: 80%;
  }
  .sub-archive-proprty .sub-archive__container {
    margin-top: 0;
    gap: 3rem 2.75%;
  }
  .sub-single-property .property-slider__img-wrap {
    padding-top: 55rem;
  }
  .sub-single-property .property-slider__arw {
    top: 35%;
  }
  .sub-single-property .info .point__head {
    font-size: 2rem;
  }
  .sub-single-property .info .table01 {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .sub-single-property .info .table01 .row {
    border-top: none;
    border-right: none;
  }
  .sub-single-property .info .table01 .row:last-child {
    border-bottom: none;
  }
  .sub-single-property .info .table01 .row::before {
    content: "";
    height: 1px;
    width: 100%;
    background-color: #aaa;
    position: absolute;
    top: -1px;
    left: 0;
  }
  .sub-single-property .info .table01 .row::after {
    content: "";
    height: 100%;
    width: 1px;
    background-color: #aaa;
    position: absolute;
    top: 0;
    right: -1px;
  }
  .sub-single-property .info .table01 .row {
    width: 50%;
  }
  .sub-single-property .info .table01 .row .head,
  .sub-single-property .info .table01 .row .body {
    font-size: 1.6rem;
    padding: 1.8rem;
    border-bottom: 1px solid #aaa;
  }
  .sub-single-property .info .table01 .row .head {
    width: 20rem;
  }
  .sub-single-property .info .table02 .row .head,
  .sub-single-property .info .table02 .row .body {
    font-size: 1.5rem;
    padding: 1.8rem;
    line-height: 1.4;
  }
  .sub-single-property .info .table02 .row .head {
    width: 20rem;
  }
  .sub-single-property .info .map {
    padding-top: 35rem;
  }
  .sub-single-property .banner__col {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .sub-single-property .banner__item {
    width: 49%;
  }
  .sub-single-property .banner__item:not(:first-of-type) {
    margin-top: 0;
  }
  .sub-single-property .download__col a {
    width: 31.5%;
  }
  .p-sell-sec01 .tab__item {
    width: 24%;
  }
  .p-sell-sec01 .tab__link {
    font-size: 2rem;
  }
  .p-sell-sec01 .sub-contact__item dt {
    width: 33.3rem;
  }
  .p-sell-sec01 .sub-contact__item dd .text {
    line-height: 1;
  }
  .p-sell-sec01 .sub-contact__item .very-short {
    width: 10rem;
  }
  .p-sell-sec01 .sub-contact__item .radio label {
    line-height: 1;
  }
}

@media (min-width: 768px) and (max-width: 1300px) {
  .header__btn {
    font-size: 1.5rem;
    padding: 3.3rem 1.4rem;
  }
  .header__logo {
    width: 20vw;
    margin-left: 1rem;
  }
  .header__nav {
    margin-right: 3rem;
  }
}

@media only screen and (max-width: 767px) {
  .c-card__time {
    font-size: 4vw;
  }

  .c-card + .c-card {
    margin: 3rem 0 0 0;
  }
  .c-news__img {
    padding-top: 8rem;
  }
  .c-news__time {
    font-size: 3vw;
  }
  .c-heading01 {
    font-size: 3rem;
  }
  .p-home-sec01 {
    margin-top: 4rem;
    margin-bottom: 4rem;
  }
  .c-media__txt {
    font-size: 4vw;
  }
  .c-table01 {
    font-size: 4vw;
  }
  .footer-contact .left__txt {
    font-size: 4vw;
  }
  .p-home-sec02__txt {
    font-size: 4vw;
  }
  .p-home-sec02 .item__txt {
    font-size: 4vw;
  }
  .p-home-sec02 .item__readmore {
    font-size: 4vw;
  }
  .p-flow-sec01 .cont .promise {
    font-size: 4vw;
  }
  .p-flow-sec02 .promise {
    font-size: 4vw;
  }
  .p-home-sec02 .c-heading01 {
    font-size: 2.4rem;
  }
  .p-home-sec03 {
    margin-top: 6rem;
  }
  .footer-contact__inner {
    padding-top: 4rem;
    padding-bottom: 5rem;
  }
  .c-heading02 {
    padding: 1rem;
    font-size: 1.8rem;
  }
  .c-heading03 {
    font-size: 1.8rem;
    padding: 1rem 1rem 1rem 0;
  }
  .p-flow-sec02 .c-heading02 {
    margin-top: 4rem;
  }
  .p-flow-sec02 .c-text {
    padding-top: 4rem;
  }
  .p-flow-sec02 .flow_content .detail .text {
    line-height: 1.7;
    font-size: 1.5rem;
  }
  .c-column-3__item:not(:first-of-type) {
    margin-top: 2rem;
  }
  .sub-single .c-column-3 {
    padding-top: 1rem;
  }
  .sub-single .c-column-3 .btn.-color {
    width: 49%;
  }
}

.sub-single-news .sub-single__main p {
  background-color: transparent;
}

/* ------ */
/* 注目ポイント部分 */

.sub-single-property .sub-single__title-area {
  position: relative;
}

.sub-single-property .sub-single__title-area .checkpoint {
  position: absolute;
  top: -60px;
  right: 0;
  background-color: #ef6c00;
  color: #fff;
  padding: 1rem;
  border-radius: 10px;
  font-size: 1.4rem;
  line-height: 1.2;
}

.c-card {
  position: relative;
}

.c-card .checkpoint {
  position: absolute;
  top: -3rem;
  right: -3rem;
  background-color: #ef6c00;
  color: #fff;
  padding: 1rem;
  border-radius: 10px;
  z-index: 1;
  font-size: 1.4rem;
  line-height: 1.1;
}

.recruit_img ul {
  display: flex;
  flex-wrap: wrap;
  gap: 2%;
  margin: 6rem 0 0 0;
  margin: 6rem auto 0 auto;
  max-width: 800px;
}
.recruit_img ul li {
  width: 49%;
}

/* 注目ポイント部分ここまで */
/* -------------- */

/* 20230901追加部分 */
/* ------- */
.sub-archive-proprty .cat-wrap03 {
  border: 3px solid #e8a4dd;
}
.sub-archive-proprty .cat-wrap03 ul li a {
  background-color: #e8a4dd;
}

.sub-single-property .property-slider__img-wrap {
  margin-bottom: 8rem;
}

.sub-single-property .property-slider__img-text {
  position: absolute;
  /* bottom: -6rem; */
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  margin-top: 2rem;
}

@media only screen and (max-width: 767px) {
  .sub-single-property .property-slider__img-wrap {
    margin-bottom: 7rem;
  }
}
/* --------- */
/* 20230901追加部分ここまで */

/* 20230907追加部分 */
/* ------- */
.cat-outer {
  width: 100%;
  border: 3px solid #60c0f0;
  border-radius: 5px;
  position: relative;
  padding-top: 2.5rem;
  padding-bottom: 1.5rem;
}

.cat-title {
  background-color: #fff;
  font-size: 2.4rem;
  font-weight: 500;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 1rem;
}

.sub-archive-proprty .cat-wrap01,
.sub-archive-proprty .cat-wrap02,
.sub-archive-proprty .cat-wrap03 {
  border: none;
}

.sub-archive-proprty .sub-archive__category-name {
  font-size: 1.8rem;
}

@media only screen and (max-width: 767px) {
  .sub-archive-proprty .sub-archive__category-name {
    font-size: 4vw;
  }
}

/* --------- */
/* 20230907追加部分ここまで */

/* ステラNEXT */

.header-flex {
  display: flex;
  align-items: center;
}
.header__nav {
  margin-right: 0;
}
/* --- nakayone風ヘッダー --- */
.header__container {
  display: flex;
  background: #ffffff99;
  padding: 0 0 0 4rem;
  border-radius: 50px 0 0 50px;
  align-items: center;
  backdrop-filter: blur(6px) saturate(120%);
  -webkit-backdrop-filter: blur(6px) saturate(120%);
}
.header__top {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #ef6c00;
  justify-content: flex-end;
  padding-right: 2rem;
}
.header__tel {
  font-size: 2.2rem;
  font-weight: 700;
  position: relative;
  color: #ef6c00;
}
.header__tel::before {
  background-image: url(../img/common/tel-color.svg);
  background-repeat: no-repeat;
  background-size: contain;
  bottom: 0;
  content: "";
  height: 1.6rem;
  left: -1.8rem;
  margin: auto;
  position: absolute;
  top: 0;
  width: 1.6rem;
}
.header__time_contents {
  font-size: 1.2rem;
  color: #555;
}
.header__nav {
  margin-right: 2rem;
}
.header__link {
  font-size: 1.4rem;
  font-weight: 500;
  color: #333;
}
.header-btn-wrap {
  display: flex;
  align-items: stretch;
}
.header__btn {
  background: linear-gradient(135deg, #f0a0b0, #FFCC3F);
  padding: 3.5rem 1.6rem 3.6rem 4rem;
  font-size: 1.5rem;
  font-weight: 500;
  color: #fff;
  position: relative;
  height: auto;
  border-radius: 50px 0 0 50px;
  display: flex;
  align-items: center;
  text-decoration: none;
  white-space: nowrap;
  width: auto;
  margin: 0;
}
.header__btn.email::before {
  position: absolute;
  content: "";
  background-image: url(../img/common/mail.svg);
  background-repeat: no-repeat;
  background-size: contain;
  top: 50%;
  transform: translateY(-50%);
  left: 1.2rem;
  width: 2.2rem;
  height: 2rem;
}
.header__btn img {
  display: none;
}
.home-mv__slide {
  position: relative;
}

.home-mv__slide::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  pointer-events: none;
}

.p-home-sec01_flex {
  display: grid;
  grid-template-columns: 20% 80%;
  align-items: center;
  gap: 4rem;
}
.c-heading01.-white,
.c-heading01.-white span {
  color: #fff;
}
.slider2 img {
  width: 100%;
  height: auto;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  border-radius: 14px;
}
.slider2 .slick-slide {
  margin: 0 0px;
  padding: 10px;
}

.grid-col03 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 3rem;
  margin-top: 4rem;
}
.grid-col03.-col4 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-top: 4rem;
}

.grid-item {
  padding: 2.5rem 2rem;
  background: #fff;
  text-align: center;
  border: 2px solid #d0d8e0;
  border-radius: 14px;
  transition: box-shadow 0.3s;
}
.grid-item:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.grid-item__icon {
  width: 13rem;
  height: 13rem;
  margin: 0 auto;
}
.grid-item__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.grid-item h3 {
  font-size: 2rem;
  font-weight: 600;
  line-height: 1.5;
  margin-top: 1rem;
  font-family: "Kiwi Maru", sans-serif;
  color: #002b4b;
}
.grid-item p {
  line-height: 1.8;
  margin-top: 1.2rem;
  font-size: 14px;
  text-align: left;
}
.home-program {
  padding: 6rem 15px;
  position: relative;
}
/* .home-program::before {
  content: "";
  width: 130px;
  height: 100px;
  position: absolute;
  top: 0;
  right: 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../img/home/intro-deco02.svg);
} */
.grid-col03.-col4 .grid-item img {
  max-width: 100px;
  margin: auto;
}
a.btn-border {
  position: relative;
  display: inline-block;
  padding: 1rem 4rem;
  border: none;
  border-radius: 100vh;
  color: #fff;
  font-family: "Kiwi Maru", sans-serif;
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  text-align: center;
  text-decoration: none;
  background-image: linear-gradient(90deg, #f0a0b0 40%, #ffe6a0 100%);
  box-shadow: 0 4px 12px rgba(240,160,176,0.3);
  transition: all 0.3s;
  overflow: hidden;
}
a.btn-border:after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  transition: all 0.5s;
  border-radius: 100vh;
  background-image: linear-gradient(90deg, #ffe6a0, #f0a0b0, #60c0f0);
}
a.btn-border span {
  position: relative;
  z-index: 1;
}
a.btn-border:hover {
  color: #fff;
  box-shadow: 0 6px 16px rgba(240,160,176,0.4);
  transform: translateY(-2px);
}
a.btn-border:after {
  opacity: 0;
}
a.btn-border:hover:after {
  opacity: 1;
}
.program-btn {
  margin-top: 4rem;
  text-align: center;
}
.top-intro_body {
  text-align: center;
}
.top-intro_flex {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.section-text {
  line-height: 2;
  margin-top: 2rem;
}
.top-intro {
  margin-top: 6rem;
  padding: 6rem 0;
  background-color: #f5f0f2;
  background-image: linear-gradient(#e2b4bf33 1px, transparent 1px),
    linear-gradient(to right, #e2b4bf33 1px, #f5f0f2 1px);
  background-size: 10px 10px;
  position: relative;
}
.top-intro::before {
  content: "";
  width: 130px;
  height: 100px;
  position: absolute;
  top: 0;
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
  background-image: url(../img/home/intro-deco01.svg);
}
.footer-contact {
  margin-top: 0;
}
.footer-flex {
  /* display: grid;
  grid-template-columns: 1fr 1fr; */
  padding: 4rem 15px;
  background: #fff;
  border-radius: 7px;
  /* border: 2px solid #000000; */
}
.wrapper {
  margin-top: 4rem;
}
.entry-content {
  margin-top: 2rem;
}
.entry-content a {
  font-weight: 600;
  padding: 1rem;
  text-decoration: underline;
  display: inline-block;
  position: relative;
  padding-left: 2rem;
	line-height: 1.3;
}
.entry-content a::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  position: absolute;
  top: 14px;
  left: 3px;
  background: #60c0f0;
  background-size: contain;
  background-repeat: no-repeat;
}
.pdf-icon {
  display: inline-block;
  margin-left: 5px;
  width: 15px;
  height: 20px;
  background-image: url(../img/sub/archive/pdf.png);
  background-size: cover;
  background-repeat: no-repeat;
  margin-bottom: -4px;
}
.greeting {
  padding-top: 6rem;
  padding-bottom: 6rem;
  position: relative;
  background: #f7f3f0;
}
/* .greeting::before {
  content: "";
  width: 250px;
  height: 250px;
  position: absolute;
  top: -3%;
  right: 2%;
  background-image: url(../img/home/illust02.svg);
  background-size: contain;
  background-repeat: no-repeat;
} */
.greeting-catch {
  text-align: center;
  margin-top: 3rem;
  line-height: 2;
  font-size: 2.2rem;
  font-weight: 600;
  position: relative;
  font-family: "Kiwi Maru", sans-serif;
}
.greeting-catch::before {
  content: "";
  width: 100px;
  height: 5px;
  position: absolute;
  bottom: -30%;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(to right, #f0a0b0, #60c0f0, #b0d000);
}
.grid-col02 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-top: 6rem;
  padding: 5rem;
  background: #fff;
  border-radius: 14px;
  position: relative;
}
/* .grid-col02::before {
  content: "";
  width: 340px;
  height: 190px;
  position: absolute;
  bottom: 15%;
  left: -6%;
  background-image: url(../img/home/illust03.svg);
  background-size: contain;
  background-repeat: no-repeat;
} */
.grid-col02_text {
  line-height: 2;
}
.sub-shop {
  margin-top: 4rem;
  position: relative;
}
/* .sub-shop::before {
  content: "";
  width: 340px;
  height: 190px;
  position: absolute;
  top: 5%;
  right: 2%;
  background-image: url(../img/home/illust04.svg);
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 3;
} */
.sub-shop .c-table02 {
  margin-top: 4rem;
}
.grid-col02.-dayservice {
  border: none;
  margin-top: 3rem;
  align-items: center;
}
.grid-col02.-dayservice .grid-col02_text {
  margin-top: 4rem;
}
.grid-col02.-dayservice img {
  border-radius: 14px;
}
.greeting-catch.-about {
  margin-top: 0;
  font-size: 2.8rem;
}
.greeting-catch.-about span {
  font-weight: 500;
  font-size: 3.2rem;
  color: #2ca5ff;
}
.greeting-catch.-about::before {
  bottom: -13%;
}
.p-flow-sec01 .c-text {
  text-align: center;
}
.sub-service .c-flexbox02 {
  align-items: center;
  justify-content: space-around;
  position: relative;
  background: #fff;
  margin-top: 3rem;
  padding: 3rem;
  border-radius: 14px;
}
/* .sub-service .c-flexbox02::before {
  content: "";
  width: 210px;
  height: 210px;
  position: absolute;
  top: 3%;
  left: 30%;
  background-image: url(../img/home/illust02.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
.sub-service .c-flexbox02.-ill02::before {
  background-image: url(../img/home/illust03.svg);
  width: 270px;
  height: 150px;
  left: 25%;
} */
.sub-service .c-text {
  line-height: 2;
  margin-top: 3rem;
}
.about-slider {
  margin-top: -10rem;
}
.service {
  padding: 6rem 0;
}
.custom-badge {
  display: flex;
  align-items: center;
  color: white;
  font-size: 2rem;
  font-weight: bold;
  padding: 15px 30px 15px 20px;
  border-radius: 50px; /* 丸みをつける */
  position: relative;
  width: fit-content;
  margin: auto;
  min-width: 720px;
  justify-content: center;
}
.custom-badge.-red {
  background: #f87468;
}
.custom-badge.-yellow {
  background: #d8b021;
}
.custom-badge.-blue {
  background: #60c0f0;
}
.custom-badge.-green {
  background: #639f77;
}

.badge-icon {
  background-color: white;
  width: 8rem;
  height: 8rem;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  left: -30px; /* テキストの外に半分出るように調整 */
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.2);
}

.badge-icon img {
  width: 50px;
  height: 50px;
}

.badge-text {
  margin-left: 50px;
  font-family: "Kiwi Maru", sans-serif;
}
.service-item {
  padding: 5rem 0;
  background: #f7f3f0;
  margin-top: 4rem;
  border-radius: 14px;
  padding: 5rem;
}
.service-txt {
  line-height: 2;
}
.service-body {
  display: grid;
  grid-template-columns: 30% 67%;
  gap: 3rem;
  align-items: center;
  margin-top: 4rem;
}
.service-body_grid {
  display: grid;
  grid-template-columns: 15% 80%;
  gap: 2rem;
  align-items: center;
  line-height: 1.5;
  margin-top: 2rem;
  color: #f87468;
}
.service-img img {
  aspect-ratio: 1 / 1;
  width: 100%;
  object-fit: cover;
}
.hours {
  background: linear-gradient(135deg, #f0a0b0, #60c0f0, #b0d000);
  padding: 4rem 0 6rem;
}
.hours-body {
  padding: 3rem 15px;
  background: #fff;
  color: #002b4b;
  margin-top: 3rem;
  text-align: center;
  font-weight: 600;
  font-size: 2rem;
  position: relative;
  font-family: "Kiwi Maru", sans-serif;
  line-height: 1.2;
}
.hours-body span {
  font-weight: 600;
  font-size: 3rem;
}
.staff {
  padding: 6rem 0;
  background: #f7f3f0;
}
.instagram {
  margin-top: 6rem;
}
.insta-wrap {
  margin-top: 4rem;
}
.header__link img {
  max-width: 2rem;
  margin: auto;
  margin-bottom: 0;
  margin-right: 1rem;
}

.top-intro .c-heading01 {
  position: relative;
}
.about-deco01 {
  position: absolute;
  top: -50px;
  right: 0;
  max-width: 100px;
}
@media only screen and (max-width: 1050px) {
  .about-deco01 {
    position: absolute;
    top: -60px;
    right: 0%;
    max-width: 90px;
  }
}
.top-intro-img {
  position: relative;
}
.top-intro-img img {
  border-radius: 14px;
}
.about-deco02 {
  position: absolute;
  bottom: -13%;
  left: -13%;
  max-width: 200px;
}
.link-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 2rem;
  margin-top: 4rem;
}
.link-item {
  text-align: center;
}

.link-item__title {
  display: inline-block;
  padding: 10px 20px;
  font-size: 2rem;
  font-weight: bold;
  position: relative;
  background: white;
  color: #002b4b;
  min-width: 180px;
}

.link-item__title::before,
.link-item__title::after {
  content: "";
  position: absolute;
  top: 0;
  width: 15px;
  height: 100%;
  background: white;
}

.link-item__title::before {
  left: -10px;
  transform: skewX(-20deg);
}
.link-item__title::after {
  right: -10px;
  transform: skewX(20deg);
}
.link-item__body {
  background: #fff;
  margin-top: -3rem;
  padding: 0 2rem 2rem 2rem;
  border-radius: 8px;
}
.link-item__txt {
  line-height: 2;
  text-align: left;
  position: relative;
  margin-top: 2rem;
}
.link-item__txt::before {
  content: "";
  width: 60px;
  height: 3px;
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(to right, #f0a0b0, #60c0f0, #b0d000);
}
.link-item img {
  border-radius: 8px 8px 0 0;
}
.link-grid .link-item:nth-child(1) {
  border: 2px solid #d76d63;
  border-radius: 10px;
  margin-top: 4rem;
}
.link-grid .link-item:nth-child(2) {
  border: 2px solid #ffcf22;
  border-radius: 10px;
}
.link-grid .link-item:nth-child(3) {
  border: 2px solid #639f77;
  border-radius: 10px;
  margin-top: 4rem;
}

.bnr-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 3rem;
}
.bnr-grid a {
  transition: all 0.3s;
}
.bnr-grid a:hover {
  opacity: 0.5;
}
.bnr {
  margin-top: 4rem;
  padding: 4rem 0;
  background-color: #ebf8ff;
  background-image: linear-gradient(#c5ecff 1px, transparent 1px),
    linear-gradient(to right, #c5ecff 1px, #ebf8ff 1px);
  background-size: 10px 10px;
  position: relative;
}
.footer-contact__right iframe {
  aspect-ratio: 2 / 1;
  width: 60vw;
  height: 100%;
}
.day-service {
  /* background: #eff8ff; */
  padding: 6rem 15px;
  background-color: #ebf8ff;
  background-image: linear-gradient(#c5ecff 1px, transparent 1px),
    linear-gradient(to right, #c5ecff 1px, #ebf8ff 1px);
  background-size: 10px 10px;
  position: relative;
}
.home-mv__catch {
  font-size: clamp(30px, 4rem, 40px);
  display: flex;
  flex-direction: column;
  align-items: center;
  opacity: 0;
  transform: translateY(50px) scale(0.9);
  animation: fadeBounce 1.7s ease-out forwards;
}

@keyframes fadeBounce {
  0% {
    opacity: 0;
    transform: translateY(50px) scale(0.9);
  }
  50% {
    opacity: 1;
    transform: translateY(-10px) scale(1);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.home-mv__deco01 {
  position: absolute;
  top: 15%;
  right: 3%;
  width: 230px;
  height: 130px;
}
.home-mv__deco02 {
  position: absolute;
  bottom: 15%;
  left: 3%;
  width: 170px;
  height: 170px;
}
.aboutus-logo {
  max-width: 33rem;
  margin: auto;
  margin-bottom: 2rem;
  margin-top: 5rem;
}
.service-body_list {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.service-body_list li {
  background: #f87468;
  color: #fff;
  padding: 5px 1rem 5px 3rem;
  border-radius: 5px;
  position: relative;
}
.service-body_list.-yellow li {
  background: #d8b021;
}
.service-body_list.-blue li {
  background: #60c0f0;
}
.service-body_list.-green li {
  background: #639f77;
}
.service-body_list li::before {
  content: "";
  width: 15px;
  height: 15px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 8px;
  background-image: url(../img/sub/service/check.svg);
  background-size: contain;
  background-repeat: no-repeat;
}
.page-link_group {
  position: relative;
  background: #fff;
  padding: 6rem 0 0;
  top: -5rem;
  margin: 0 5%;
  border-radius: 2rem;
}
.header__btn img {
  width: 4rem;
}
.header__banner {
  display: none;
}
.header__banner a {
  letter-spacing: 0.01em;
  font-weight: 500;
}
.header__banner span {
  font-size: 20px;
  font-weight: 600;
}
.header__banner li a {
  transition: all 0.3s ease-in-out;
  border-radius: 14px 0 0 14px;
  border-right: none;
  width: 70px;
}
.header__banner li a:hover {
  background: #fccd2a;
  transition: all 0.3s ease-in-out;
}
.sub-service {
  margin-top: 6rem;
  padding: 6rem 0;
  background-color: #ebf8ff;
  background-image: linear-gradient(#c5ecff 1px, transparent 1px),
    linear-gradient(to right, #c5ecff 1px, #ebf8ff 1px);
  background-size: 10px 10px;
  position: relative;
}
.c-flexbox02__head img {
  border-radius: 14px;
}
.sub-contact {
  padding-top: 0;
}
.news-bg {
  background-color: #fdf8ee;
  background-image: linear-gradient(#e9cb8233 1px, transparent 1px),
    linear-gradient(to right, #e9cb8233 1px, #fdf8ee 1px);
  background-size: 10px 10px;
  position: relative;
}
.news-bg .sub-archive__box {
  padding: 3rem;
  border-radius: 14px;
}
.scroll_down {
  position: absolute;
  bottom: 18%;
  right: 50%;
  animation: arrowmove 1s ease-in-out infinite;
}

.scroll_down a {
  position: absolute;
  left: -24px;
  bottom: 30px;
  color: #fff;
  font-size: 14px;
  font-family: "Josefin Sans", sans-serif;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  width: 24px;
  height: 24px;
  text-decoration: none;
}

.text {
  display: block;
  margin-top: 70px;
  margin-left: -14px;
  font-size: 12px;
  color: #fff;
  text-transform: uppercase;
  white-space: nowrap;
  letter-spacing: 2px;
}

.arrow {
  position: absolute;
  width: 28px;
  height: 5px;
  opacity: 0;
  transform: scale3d(0.5, 0.5, 0.5);
  animation: move 3s ease-out infinite;
}

.arrow:first-child {
  animation: move 3s ease-out 1s infinite;
}

.arrow:nth-child(2) {
  animation: move 3s ease-out 2s infinite;
}

.arrow:before,
.arrow:after {
  content: " ";
  position: absolute;
  top: 0;
  height: 100%;
  width: 51%;
  background: #fff;
}

.arrow:before {
  left: 0;
  transform: skew(0deg, 30deg);
}

.arrow:after {
  right: 0;
  width: 50%;
  transform: skew(0deg, -30deg);
}

@keyframes move {
  25% {
    opacity: 1;
  }
  33% {
    opacity: 1;
    transform: translateY(30px);
  }
  67% {
    opacity: 1;
    transform: translateY(40px);
  }
  100% {
    opacity: 0;
    transform: translateY(55px) scale3d(0.5, 0.5, 0.5);
  }
}
.hours-txt {
  line-height: 1.7;
  color: #fff;
}
.hours-grid {
  display: grid;
  grid-template-columns: 17% 80%;
  align-items: center;
  max-width: 660px;
  gap: 2rem;
  margin: 1rem auto 0;
}
#evaluation {
  padding-top: 0;
  margin-top: 2rem;
}
.blog-archive {
  padding-top: 0;
}
.sub-single-news {
  padding-top: 0;
}
.entry-header .c-heading01 {
	font-size: 3.5rem;
}
.program-link {
	padding: 6rem 15px;
}
.c-news-info {
	display: flex;
	gap:1.5rem;
	align-items: center;
	margin-bottom: 1rem;
}
a[href$=".pdf"] {
    position: relative; /* アイコンの位置指定のために必要 */
    padding-right: 20px; /* アイコンとテキストの間隔 */
}

a[href$=".pdf"]::after {
    content: "";
    background: url('../img/sub/archive/pdf.png') no-repeat center center;
    background-size: contain; /* アイコンサイズを最適化 */
    width: 16px; /* アイコンの幅 */
    height: 22px; /* アイコンの高さ */
    position: absolute;
    right: 0; /* 右端に配置 */
    top: 50%;
    transform: translateY(-50%);
}

/* mq */

@media only screen and (max-width: 767px) {
  .grid-col03 {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .p-home-sec01_flex {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .top-intro_flex {
    grid-template-columns: 1fr;
  }
  .grid-col03.-col4 {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
  .grid-item h3 {
    font-size: 1.8rem;
  }
  .footer-contact__right iframe {
    width: 100%;
  }
  .footer-flex {
    padding: 2rem 15px;
    display: flex;
    flex-direction: column-reverse;
  }
  .footer__list {
    padding-left: 0;
    border-left: none;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem;
    justify-items: start;
  }
  .footer__link {
    display: inline-block;
    white-space: nowrap;
  }
  .p-flow-sec01 {
    padding-top: 5rem;
  }
  .p-flow-sec01 .cont {
    padding: 2rem;
    margin-top: 3rem;
  }
  .greeting-catch.-about {
    font-size: 2.2rem;
    line-height: 1.7;
  }
  .greeting-catch.-about span {
    font-size: 2.8rem;
  }
  .p-flow-sec01 .c-text {
    text-align: left;
    line-height: 1.5;
  }
  .sub-service .c-text {
    line-height: 1.5;
  }
  .service-body {
    grid-template-columns: 1fr;
  }
  .badge-icon {
    left: 50%;
    top: -53px;
    transform: translateX(-50%);
  }
  .badge-text {
    margin-left: 0;
  }
  .custom-badge {
    padding: 30px 25px 15px;
    line-height: 1.5;
    font-size: 1.8rem;
    text-align: center;
  }
  .service-item {
    margin-top: 4rem;
    padding: 5rem 15px 3rem;
  }
  .service-body_grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .greeting-catch {
    font-size: 1.6rem;
  }
  .greeting-catch::before {
    bottom: -15%;
  }
  .grid-col02 {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding: 2rem;
  }
  .sub-shop {
    margin-top: 0;
  }
  .grid-col02.-dayservice {
    gap: 1rem;
  }
  .day-service {
    margin-top: 2rem;
  }
  .day-service .greeting-catch {
    margin-top: 0;
  }
  .btn.-color:hover {
    color: #fff;
  }
  /* .header__link::before {
    content: "";
    width: 10px;
    height: 10px;
    border-radius: 50%;
    position: absolute;
    top: 2px;
    left: -20px;
    background: #f87468;
  } */
  .link-grid {
    grid-template-columns: 1fr;
  }
  .link-grid .link-item:nth-child(1),
  .link-grid .link-item:nth-child(3) {
    margin-top: 0;
  }
  .home-mv__deco01 {
    width: 140px;
  }
  .home-mv__deco02 {
    width: 80px;
    height: 80px;
  }
  .about-deco02 {
    left: -5%;
    max-width: 120px;
  }
  .about-deco01 {
    width: 110px;
    top: -100px;
  }
  .bnr-grid {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
  .bnr {
    margin-top: 4rem;
  }
  .home-mv .slide-dots {
    margin-top: 0;
  }
  .l-page-cover::after {
    background: linear-gradient(90deg, #2f9fede6 60%, #7cd5ca1f 60%);
  }
  .l-page-cover__ttl {
    /* width: 60%; */
    font-size: 2.8rem;
  }
  .l-page-cover__ttl::before {
    width: 50px;
    height: 23px;
    top: -34%;
  }
  .sub-service .c-flexbox02::before {
    width: 170px;
    height: 170px;
    top: -7%;
    left: auto;
    right: -10%;
  }
  .sub-service .c-flexbox02.-ill02::before {
    width: 230px;
    height: 130px;
    left: auto;
    top: -3%;
  }
  .custom-badge {
    width: 100%;
    min-width: auto;
  }
  .greeting::before {
    width: 140px;
    height: 140px;
    top: -2%;
  }
  .grid-col02::before {
    width: 200px;
    height: 110px;
    bottom: auto;
    top: -5%;
  }
  .sub-shop::before {
    width: 220px;
    height: 90px;
    top: 0;
  }
  #evaluation {
    padding-left: 15px;
    padding-right: 15px;
  }
  #evaluation.sub-shop::before {
    width: 150px;
    top: 6%;
  }
  .p-flow-sec01::before {
    width: 120px;
    height: 120px;
    top: -3%;
    right: 0;
  }
  .home-mv__catch img {
    width: 90vw;
  }
  .nav-drawer .bnr-grid {
    margin-top: 2rem;
  }
  .grid-item {
    padding: 1rem;
  }
  .sub-service .c-flexbox02 {
    padding: 2rem;
  }
  .c-flexbox02__body {
    padding-top: 0;
  }
  .service {
    padding-top: 0;
  }
  .service-body_arrow {
    width: 200px;
    margin: auto;
  }
  .service-body_list {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .service-body_list li {
    display: flex;
    align-items: center;
  }
  .header__link {
    color: #002b4b;
    font-size: 1.8rem;
    font-weight: 600;
    position: relative;
    text-align: center;
    font-family: "Kiwi Maru", sans-serif;
    padding: 2rem 0;
    text-align: left;
    border-top: 1px solid #d0e0ed;
  }
  .hours-body span {
    font-size: 2.6rem;
  }
  .hours-body {
    padding: 2rem 15px;
  }
  .hours-grid {
    gap: 1rem;
    grid-template-columns: 20% 80%;
  }
	.entry-header .c-heading01 {
	font-size: 2.5rem;
}
	.program-link {
		padding: 4rem 15px;
	}
}

/* ================================
   TOP - MV テキストキャッチ
   ================================ */
.home-mv__catch-main {
  font-size: 4.5rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 3px 15px rgba(0, 0, 0, 0.5);
  line-height: 1.4;
  font-family: "Kiwi Maru", sans-serif;
  letter-spacing: 0.08em;
}
.home-mv__catch-sub {
  font-size: 1.6rem;
  font-weight: 400;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.4);
  margin-top: 2.5rem;
  font-family: "Kiwi Maru", sans-serif;
  letter-spacing: 0.03em;
  line-height: 2;
  max-width: 700px;
}

/* ================================
   TOP - 私たちについて キャッチ
   ================================ */
.top-intro__catch {
  font-size: 2.2rem;
  font-weight: 600;
  line-height: 1.6;
  margin-top: 2rem;
  font-family: "Kiwi Maru", sans-serif;
  color: #002b4b;
}

/* ================================
   TOP - 採用情報への導線
   ================================ */
.home-recruit {
  padding: 6rem 15px;
  background: url(../img/home/home-mv-slide02.jpg) center/cover no-repeat;
  position: relative;
}
.home-recruit::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.45);
  z-index: 0;
}
.home-recruit .inner {
  position: relative;
  z-index: 1;
}
.home-recruit .c-heading01,
.home-recruit .c-heading01 span {
  color: #fff;
}
.home-recruit__catch {
  text-align: center;
  font-size: 2.2rem;
  font-weight: 600;
  color: #fff;
  margin-top: 2rem;
  font-family: "Kiwi Maru", sans-serif;
  line-height: 1.6;
}
.home-recruit .program-btn a.btn-border {
  background-image: none;
  background-color: #fff;
  color: #002b4b;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.home-recruit .program-btn a.btn-border:after {
  background-image: none;
  background-color: rgba(0,43,75,0.15);
  border-radius: 100vh;
  opacity: 0;
}
.home-recruit .program-btn a.btn-border:hover {
  color: #002b4b;
}
.home-recruit .program-btn a.btn-border:hover:after {
  opacity: 1;
}

/* ================================
   TOP - MVキャッチコピー
   ================================ */
.home-mv__catch-copy {
  font-size: 1.8rem;
  font-weight: 500;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
  font-family: "Kiwi Maru", sans-serif;
  letter-spacing: 0.15em;
  margin-bottom: 2rem;
  padding: 0.8rem 2rem;
  background: rgba(255,255,255,0.15);
  border-radius: 50px;
  display: inline-block;
  backdrop-filter: blur(4px);
}

/* ================================
   TOP - 特徴セクション
   ================================ */
.home-features {
  padding: 6rem 15px;
  background-color: #ffffff;
}
.home-features .grid-item {
  border: none;
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.05);
  padding: 3rem 2rem;
  text-align: left;
}
.home-features .grid-item h3 {
  text-align: center;
  margin-top: 0;
  font-size: 1.9rem;
  color: #002b4b;
}
.home-features .grid-item p {
  margin-top: 1.5rem;
}

/* ================================
   TOP - 支援プログラム
   ================================ */
.home-program .section-text {
  max-width: 900px;
  margin: 3rem auto 0;
}
.home-program__catch {
  text-align: center;
  font-size: 2rem;
  font-weight: 600;
  color: #002b4b;
  margin-top: 2rem;
  font-family: "Kiwi Maru", sans-serif;
  line-height: 1.6;
}

/* ================================
   TOP - 5領域
   ================================ */
.home-domain {
  padding: 6rem 15px;
  background-color: #fdf8ee;
  background-image: linear-gradient(#e9cb8233 1px, transparent 1px),
    linear-gradient(to right, #e9cb8233 1px, #fdf8ee 1px);
  background-size: 10px 10px;
}
.home-domain__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2rem;
  margin-top: 4rem;
}
.home-domain__item {
  background: #fff;
  padding: 2.5rem 1.5rem;
  text-align: center;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.home-domain__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 0.8rem;
}
.home-domain__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.home-domain__num {
  font-size: 3rem;
  font-weight: 700;
  color: #d0d8e0;
  font-family: "Kiwi Maru", sans-serif;
  display: block;
  margin-bottom: 1rem;
}
.home-domain__item h3 {
  font-size: 1.8rem;
  font-weight: 600;
  line-height: 1.5;
  color: #002b4b;
  font-family: "Kiwi Maru", sans-serif;
}

/* ================================
   TOP - トピックス
   ================================ */
.home-topics {
  padding: 6rem 15px;
}

/* ================================
   TOP - 施設のご案内
   ================================ */
.home-facility {
  padding: 6rem 15px;
  background-color: #fbf0ee;
  background-image: linear-gradient(#da989822 1px, transparent 1px),
    linear-gradient(to right, #da989822 1px, #fbf0ee 1px);
  background-size: 10px 10px;
}
.home-facility__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  margin-top: 4rem;
}
.home-facility__item {
  background: #fff;
  padding: 3.5rem;
  border-radius: 14px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
  transition: box-shadow 0.3s;
}
.home-facility__item:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
}
.home-facility__item .program-btn {
  margin-top: 2.5rem;
}
.home-facility__item h3 {
  font-size: 2.4rem;
  font-weight: 700;
  color: #002b4b;
  font-family: "Kiwi Maru", sans-serif;
  margin-bottom: 2rem;
}
.home-facility__item address {
  font-style: normal;
  line-height: 2;
}
.home-facility__item address a {
  color: #53baf1;
  font-weight: 600;
}

/* ================================
   TOP - 採用情報
   ================================ */
.home-recruit__text {
  text-align: center;
  color: rgba(255,255,255,0.9);
  margin-top: 1.5rem;
  line-height: 2;
  max-width: 700px;
  margin-left: auto;
  margin-right: auto;
}

/* ================================
   TOP - お問い合わせ
   ================================ */
.home-contact {
  padding: 6rem 15px;
  background: #f7f3f0;
}
.home-contact__btns {
  display: flex;
  gap: 2rem;
  justify-content: center;
  margin-top: 4rem;
}
.home-contact__btns .btn {
  min-width: 300px;
  font-family: "Kiwi Maru", sans-serif;
}

/* ================================
   SP対応（追加分）
   ================================ */
@media only screen and (max-width: 767px) {
  .home-mv__catch-copy {
    font-size: 1.2rem;
    padding: 0.6rem 1.5rem;
    margin-bottom: 1.5rem;
  }
  .home-mv__catch-main {
    font-size: 2.6rem;
    line-height: 1.4;
  }
  .home-mv__catch-sub {
    font-size: 1.3rem;
    margin-top: 1.5rem;
    line-height: 1.8;
  }
  .top-intro__catch {
    font-size: 1.8rem;
  }
  .home-features .grid-col03.-col4 {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .home-features .grid-item {
    padding: 2.5rem 2rem;
  }
  .home-program__catch {
    font-size: 1.6rem;
  }
  .home-domain__grid {
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem;
  }
  .home-domain__num {
    font-size: 2.4rem;
  }
  .home-domain__item {
    padding: 2rem 1rem;
  }
  .home-domain__item h3 {
    font-size: 1.4rem;
  }
  .home-facility__grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .home-facility__item {
    padding: 2.5rem 2rem;
  }
  .home-facility__item h3 {
    font-size: 2rem;
  }
  .home-recruit__catch {
    font-size: 1.8rem;
  }
  .home-contact__btns {
    flex-direction: column;
    align-items: center;
    gap: 1.5rem;
  }
  .home-contact__btns .btn {
    min-width: auto;
    width: 100%;
    max-width: 320px;
  }
}

/* ================================
   page-saicolo
================================ */

/* --- コネクト×さいころについて --- */
.saicolo-about {
  padding: 6rem 15px;
}
.saicolo-about__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  margin-top: 4rem;
}
.saicolo-about__img img {
  border-radius: 14px;
  width: 100%;
  height: auto;
}
.saicolo-about__text .section-text {
  margin-top: 1.5rem;
}
.saicolo-about__text .section-text:first-child {
  margin-top: 0;
}

/* --- 私の想い --- */
.saicolo-thought {
    padding: 6rem 15px 10rem;
    background: linear-gradient(135deg, #f8d5df, #fef0c8, #d4eaf8);
    position: relative;
    margin: 3rem 9rem 12rem;
    border-radius: 2rem;
}
.saicolo-thought__body {
    /* max-width: 720px; */
    margin: 3rem auto 0;
    background: rgba(255,255,255,0.95);
    border-radius: 14px;
    padding: 4rem 3rem;
    text-align: center;
    line-height: 2;
    font-size: 1.6rem;
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}

/* --- 活動内容 --- */
.saicolo-activity {
  padding: 6rem 15px;
  background-color: #f5f0f2;
  background-image: linear-gradient(#e2b4bf33 1px, transparent 1px),
    linear-gradient(to right, #e2b4bf33 1px, #f5f0f2 1px);
  background-size: 10px 10px;
}
.saicolo-activity .section-text {
  margin-top: 2rem;
}
.saicolo-activity__item {
  display: grid;
  grid-template-columns: 38% 1fr;
  gap: 3rem;
  align-items: center;
  margin-top: 4rem;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
}
.saicolo-activity__item.-reverse {
  grid-template-columns: 1fr 38%;
}
.saicolo-activity__item.-reverse .saicolo-activity__img {
  order: 2;
}
.saicolo-activity__item.-reverse .saicolo-activity__content {
  order: 1;
}
.saicolo-activity__img img {
  border-radius: 14px;
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.saicolo-activity__content .c-heading03 {
  margin-bottom: 1rem;
}
.saicolo-activity__content .section-text {
  margin-top: 1.5rem;
}

/* --- 5領域に基づく支援 --- */
.saicolo-domain {
  padding: 6rem 15px;
  background-color: #fdf8ee;
  background-image: linear-gradient(#e9cb8233 1px, transparent 1px),
    linear-gradient(to right, #e9cb8233 1px, #fdf8ee 1px);
  background-size: 10px 10px;
}
.saicolo-domain .section-text {
  margin-top: 2rem;
}
.saicolo-domain__item {
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
  margin-top: 2.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.saicolo-domain__badge {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  color: #fff;
  padding: 0.8rem 2.5rem;
  border-radius: 50px;
  font-family: "Kiwi Maru", sans-serif;
}
.saicolo-domain__num {
  font-size: 2.4rem;
  font-weight: 700;
  opacity: 0.7;
}
.saicolo-domain__label {
  font-size: 1.8rem;
  font-weight: 600;
}
.saicolo-domain__body {
  margin-top: 1.5rem;
  line-height: 2;
}
.saicolo-domain__body p {
  margin-top: 0.8rem;
}
.saicolo-domain__body p:first-child {
  margin-top: 0;
}

/* --- 地域支援・連携 / 職員の質の向上 --- */
.saicolo-support {
  padding: 6rem 15px;
}
.saicolo-support__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}
.saicolo-support__item {
    background: #fffdf8;
    border-radius: 14px;
    padding: 3rem;
}
.saicolo-support__item .c-heading03 {
  margin-bottom: 0;
}
.saicolo-support__item .section-text {
  margin-top: 1.5rem;
}

/* --- 主な行事 --- */
.saicolo-events {
  padding: 6rem 15px;
  background: linear-gradient(135deg, #f8d5df, #fef0c8, #d4eaf8);
}
.saicolo-events__grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2rem;
  margin-top: 4rem;
}
.saicolo-events__item {
  background: #fff;
  border-radius: 14px;
  padding: 2.5rem 1.5rem;
  text-align: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
.saicolo-events__icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 1.5rem;
}
.saicolo-events__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.saicolo-events__item h3 {
  font-size: 1.6rem;
  font-weight: 600;
  color: #002b4b;
  line-height: 1.5;
  font-family: "Kiwi Maru", sans-serif;
}
.saicolo-events__item p {
  margin-top: 0.8rem;
  font-size: 1.3rem;
  line-height: 1.7;
  color: #555;
}

/* --- 施設概要 --- */
.saicolo-info {
  padding: 6rem 15px;
  background: #f7f3f0;
}
.saicolo-info__wrap {
  max-width: 800px;
  margin: 3rem auto 0;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
}
.saicolo-info__wrap .c-table02 {
  margin-top: 0;
}
.saicolo-info__map {
  margin-top: 3rem;
}

/* --- saicolo SP --- */
@media only screen and (max-width: 767px) {
  .saicolo-about__body {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .saicolo-thought {
    padding: 3rem 15px 5rem;
    margin: 0 0 4rem;
  }
  .saicolo-thought__body {
    padding: 3rem 2rem;
    font-size: 1.4rem;
  }
  .saicolo-activity__item,
  .saicolo-activity__item.-reverse {
    grid-template-columns: 1fr;
  }
  .saicolo-activity__item.-reverse .saicolo-activity__img {
    order: 0;
  }
  .saicolo-activity__item.-reverse .saicolo-activity__content {
    order: 0;
  }
  .saicolo-activity__item {
    padding: 2rem;
  }
  .saicolo-domain__item {
    padding: 2rem;
  }
  .saicolo-domain__badge {
    padding: 0.6rem 1.8rem;
  }
  .saicolo-domain__num {
    font-size: 2rem;
  }
  .saicolo-domain__label {
    font-size: 1.5rem;
  }
  .saicolo-support__grid {
    grid-template-columns: 1fr;
  }
  .saicolo-events__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .saicolo-events__grid .saicolo-events__item:last-child {
    grid-column: 1 / -1;
    max-width: 50%;
    margin: 0 auto;
  }
  .saicolo-info__wrap {
    padding: 2rem;
  }
  .saicolo-visible__intro {
    padding: 2rem;
  }
  .saicolo-visible__grid {
    grid-template-columns: 1fr !important;
    gap: 2.5rem;
    margin-top: 3rem;
  }
  .saicolo-visible__card {
    padding: 2.5rem 2rem;
  }
}
/* mq */

/* --- 職場環境改善の見える化 --- */
.saicolo-visible {
  padding: 6rem 15px;
}
.saicolo-visible .section-text {
  margin-top: 2rem;
}
.saicolo-visible__intro {
  max-width: 900px;
  margin: 3rem auto 0;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.saicolo-visible__intro .c-heading03 {
  margin-bottom: 1.5rem;
}
.saicolo-visible__intro .section-text {
  margin-top: 1.2rem;
}
.saicolo-visible__list {
  margin: 1.5rem 0;
  padding-left: 2em;
  list-style: none;
  counter-reset: abc-counter;
}
.saicolo-visible__list li {
  position: relative;
  padding-left: 2em;
  margin-top: 0.8rem;
  line-height: 1.8;
  font-size: 1.5rem;
  counter-increment: abc-counter;
}
.saicolo-visible__list li::before {
    content: counter(abc-counter, upper-alpha);
    position: absolute;
    left: 0;
    top: 0.1em;
    width: 2.2rem;
    height: 2.2rem;
    border-radius: 50%;
    background: linear-gradient(135deg, #f0a0b0, #FFCC3F);
    color: #fff;
    font-size: 1.2rem;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Kiwi Maru", sans-serif;
}
.saicolo-visible__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  margin-top: 3rem;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}
.saicolo-visible__card {
  background: #fff;
  border-radius: 14px;
  padding: 3rem 2.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border-top: 4px solid var(--card-color);
  text-align: center;
}
.saicolo-visible__icon {
  width: 72px;
  height: 72px;
  margin: 0 auto 1.5rem;
  background: color-mix(in srgb, var(--card-color) 12%, #fff);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
}
.saicolo-visible__icon svg {
  width: 100%;
  height: 100%;
}
.saicolo-visible__cat-name {
  font-size: 1.7rem;
  font-weight: 700;
  color: #002b4b;
  margin-bottom: 1.5rem;
  font-family: "Kiwi Maru", sans-serif;
  line-height: 1.5;
}
.saicolo-visible__detail {
  text-align: left;
  margin-top: 1.2rem;
  font-size: 1.4rem;
  line-height: 1.8;
}
.saicolo-visible__detail p {
  margin: 0;
}
.saicolo-visible__label {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 600;
  color: #fff;
  background: var(--card-color);
  padding: 0.3rem 1.2rem;
  border-radius: 50px;
  margin-bottom: 0.6rem;
  font-family: "Kiwi Maru", sans-serif;
}
.saicolo-visible__label.-act {
  background: #002b4b;
}

/* ==========================================================================
   SITE DECORATIONS - あしらい（全ページ共通＋個別）
   ========================================================================== */

/* --- ガーランド（三角旗） --- */
.deco-garland {
  height: 40px;
  margin-top: -5px;
  background: url("data:image/svg+xml,%3Csvg width='180' height='40' viewBox='0 0 180 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,4 Q45,1 90,4 Q135,7 180,4' stroke='%23ddd' stroke-width='1.2' fill='none'/%3E%3Cpolygon points='8,5 22,5 15,33' fill='%23f0c0d0'/%3E%3Cpolygon points='33,4 47,4 40,32' fill='%2398d8f8'/%3E%3Cpolygon points='58,5 72,5 65,33' fill='%23f0e0a0'/%3E%3Cpolygon points='83,4 97,4 90,32' fill='%23c8e870'/%3E%3Cpolygon points='108,5 122,5 115,33' fill='%23f0b0c0'/%3E%3Cpolygon points='133,4 147,4 140,32' fill='%23b0d8f0'/%3E%3C/svg%3E") repeat-x center top;
  background-size: 180px 40px;
  position: relative;
  z-index: 2;
}

/* --- 芝生ウェーブ --- */
.deco-grass {
  height: 70px;
  margin-bottom: -1px;
  margin-top: -3%;
  position: relative;
  z-index: 2;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 1200 70' preserveAspectRatio='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0,45 C80,15 160,60 280,35 C400,10 480,55 600,30 C720,5 840,50 960,25 C1060,5 1140,40 1200,25 L1200,70 L0,70 Z' fill='%23a8d86c' opacity='0.5'/%3E%3Cpath d='M0,55 C120,25 240,65 360,40 C480,15 600,55 720,35 C840,10 960,50 1080,30 C1140,20 1180,35 1200,32 L1200,70 L0,70 Z' fill='%2390c850'/%3E%3Ccircle cx='100' cy='42' r='4' fill='%23f0a0b0'/%3E%3Ccircle cx='300' cy='35' r='3' fill='%23f0e0a0'/%3E%3Ccircle cx='500' cy='38' r='3.5' fill='%23f0a0b0'/%3E%3Ccircle cx='700' cy='30' r='3' fill='%23f0e0a0'/%3E%3Ccircle cx='900' cy='35' r='4' fill='%23f0a0b0'/%3E%3Ccircle cx='1100' cy='28' r='3' fill='%23f0e0a0'/%3E%3Cpath d='M98,42 C96,34 100,28 102,34' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3Cpath d='M298,35 C296,27 300,21 302,27' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3Cpath d='M498,38 C496,30 500,24 502,30' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3Cpath d='M698,30 C696,22 700,16 702,22' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3Cpath d='M898,35 C896,27 900,21 902,27' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3Cpath d='M1098,28 C1096,20 1100,14 1102,20' stroke='%2390c850' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat bottom center;
  background-size: 100% 100%;
}
.deco-grass.-flip {
  margin-top: -1px;
  margin-bottom: 0;
  transform: scaleY(-1);
}

/* --- セクション装飾：ドット・リーフ --- */
.saicolo-about {
  position: relative;
  overflow: hidden;
}
.saicolo-about::before {
  content: "";
  position: absolute;
  top: 40px;
  right: 30px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0c0d0;
  box-shadow:
    -20px 30px 0 6px rgba(176,208,224,0.3),
    40px 60px 0 4px rgba(240,224,160,0.4),
    -50px 100px 0 8px rgba(240,192,208,0.2),
    60px 140px 0 5px rgba(176,208,224,0.3),
    -30px 180px 0 7px rgba(240,224,160,0.3),
    10px 250px 0 4px rgba(240,192,208,0.25),
    70px 300px 0 6px rgba(176,208,224,0.2);
  pointer-events: none;
  z-index: 0;
}
.saicolo-about::after {
  content: "";
  position: absolute;
  bottom: 60px;
  left: 15px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #b0d0e0;
  box-shadow:
    15px -40px 0 5px rgba(240,224,160,0.35),
    -10px -100px 0 7px rgba(240,192,208,0.2),
    25px -160px 0 4px rgba(176,208,224,0.3),
    -5px -220px 0 6px rgba(240,224,160,0.25);
  pointer-events: none;
  z-index: 0;
}

.saicolo-activity {
  position: relative;
  overflow: hidden;
}
.saicolo-activity::before {
  content: "";
  position: absolute;
  top: 100px;
  left: -10px;
  width: 60px;
  height: 200px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='30' cy='35' rx='18' ry='30' fill='%2390c850' opacity='0.15' transform='rotate(-20,30,35)'/%3E%3Cellipse cx='22' cy='100' rx='14' ry='25' fill='%2390c850' opacity='0.12' transform='rotate(15,22,100)'/%3E%3Cellipse cx='35' cy='165' rx='16' ry='28' fill='%2390c850' opacity='0.1' transform='rotate(-10,35,165)'/%3E%3C/svg%3E") no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}
.saicolo-activity::after {
  content: "";
  position: absolute;
  top: 60px;
  right: -10px;
  width: 60px;
  height: 200px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='30' cy='40' rx='16' ry='28' fill='%2390c850' opacity='0.12' transform='rotate(20,30,40)'/%3E%3Cellipse cx='35' cy='110' rx='14' ry='24' fill='%2390c850' opacity='0.1' transform='rotate(-15,35,110)'/%3E%3Cellipse cx='25' cy='170' rx='17' ry='26' fill='%2390c850' opacity='0.08' transform='rotate(10,25,170)'/%3E%3C/svg%3E") no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}

.saicolo-domain {
  position: relative;
  overflow: hidden;
}
.saicolo-domain::before {
  content: "";
  position: absolute;
  top: 20px;
  right: 20px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0e0a0;
  box-shadow:
    -30px 25px 0 5px rgba(240,192,208,0.3),
    20px 70px 0 3px rgba(176,208,224,0.35),
    -40px 120px 0 6px rgba(240,224,160,0.25),
    30px 180px 0 4px rgba(240,192,208,0.2),
    -20px 240px 0 7px rgba(176,208,224,0.2),
    10px 310px 0 5px rgba(240,224,160,0.3);
  pointer-events: none;
  z-index: 0;
}

.saicolo-support {
  position: relative;
  overflow: hidden;
}
.saicolo-support::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 20px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #b0d0e0;
  box-shadow:
    25px 30px 0 4px rgba(240,224,160,0.35),
    -10px 70px 0 6px rgba(240,192,208,0.2);
  pointer-events: none;
  z-index: 0;
}

.saicolo-visible {
  position: relative;
  overflow: hidden;
}
.saicolo-visible::after {
  content: "";
  position: absolute;
  bottom: 40px;
  right: 15px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0c0d0;
  box-shadow:
    -20px -30px 0 5px rgba(176,208,224,0.3),
    30px -80px 0 4px rgba(240,224,160,0.35),
    -40px -140px 0 6px rgba(240,192,208,0.2),
    20px -200px 0 3px rgba(176,208,224,0.25);
  pointer-events: none;
  z-index: 0;
}

/* --- 星あしらい（主な行事セクション） --- */
.saicolo-events {
  position: relative;
  overflow: hidden;
}
.saicolo-events::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background:
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.2'/%3E%3C/svg%3E") 5% 15% / 24px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.15'/%3E%3C/svg%3E") 92% 20% / 18px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.18'/%3E%3C/svg%3E") 15% 80% / 16px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.12'/%3E%3C/svg%3E") 88% 75% / 22px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.1'/%3E%3C/svg%3E") 50% 10% / 14px no-repeat;
  pointer-events: none;
  z-index: 0;
}

/* --- 虹あしらい（aboutセクション右上） --- */
.saicolo-about .inner {
  position: relative;
  z-index: 1;
}
.saicolo-thought .inner,
.saicolo-activity .inner,
.saicolo-domain .inner,
.saicolo-support .inner,
.saicolo-events .inner,
.saicolo-visible .inner {
  position: relative;
  z-index: 1;
}

/* --- SP装飾調整 --- */
@media only screen and (max-width: 767px) {
  .deco-garland {
    height: 30px;
    background-size: 130px 30px;
  }
  .deco-grass {
    height: 50px;
  }
  .saicolo-about::before {
    right: 10px;
    box-shadow:
      -15px 25px 0 4px rgba(176,208,224,0.25),
      30px 50px 0 3px rgba(240,224,160,0.3),
      -20px 80px 0 5px rgba(240,192,208,0.15);
  }
  .saicolo-about::after {
    display: none;
  }
  .saicolo-activity::before,
  .saicolo-activity::after {
    width: 40px;
    opacity: 0.7;
  }
  .top-intro::before,
  .top-intro::after,
  .home-program::after,
  .home-domain::before,
  .home-facility::after {
    display: none;
  }
  .switch-about::before,
  .switch-about::after,
  .switch-activity::after,
  .switch-domain::before {
    display: none;
  }
}

/* --- TOP PAGE あしらい --- */
.top-intro {
  position: relative;
  overflow: hidden;
}
.top-intro::before {
  content: "";
  position: absolute;
  top: 30px;
  right: 25px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0c0d0;
  box-shadow:
    -25px 35px 0 6px rgba(176,208,224,0.3),
    35px 70px 0 4px rgba(240,224,160,0.4),
    -45px 110px 0 8px rgba(240,192,208,0.2),
    50px 150px 0 5px rgba(176,208,224,0.3);
  pointer-events: none;
  z-index: 0;
}
.top-intro::after {
  content: "";
  position: absolute;
  bottom: 40px;
  left: 20px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #b0d0e0;
  box-shadow:
    20px -50px 0 5px rgba(240,224,160,0.35),
    -15px -110px 0 7px rgba(240,192,208,0.2);
  pointer-events: none;
  z-index: 0;
}
.top-intro .inner {
  position: relative;
  z-index: 1;
}

.home-features {
  position: relative;
  overflow: hidden;
}
.home-features .inner {
  position: relative;
  z-index: 1;
}

.home-program {
  position: relative;
  overflow: hidden;
}
.home-program::after {
  content: "";
  position: absolute;
  top: 50px;
  right: -10px;
  width: 60px;
  height: 200px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='30' cy='35' rx='18' ry='30' fill='%2390c850' opacity='0.15' transform='rotate(-20,30,35)'/%3E%3Cellipse cx='22' cy='100' rx='14' ry='25' fill='%2390c850' opacity='0.12' transform='rotate(15,22,100)'/%3E%3Cellipse cx='35' cy='165' rx='16' ry='28' fill='%2390c850' opacity='0.1' transform='rotate(-10,35,165)'/%3E%3C/svg%3E") no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}
.home-program .inner {
  position: relative;
  z-index: 1;
}

.home-domain {
  position: relative;
  overflow: hidden;
}
.home-domain::before {
  content: "";
  position: absolute;
  top: 25px;
  left: 20px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0e0a0;
  box-shadow:
    30px 30px 0 5px rgba(240,192,208,0.3),
    -15px 80px 0 4px rgba(176,208,224,0.35),
    40px 130px 0 6px rgba(240,224,160,0.25);
  pointer-events: none;
  z-index: 0;
}
.home-domain .inner {
  position: relative;
  z-index: 1;
}

.home-facility {
  position: relative;
  overflow: hidden;
}
.home-facility::after {
  content: "";
  position: absolute;
  top: 40px;
  left: -10px;
  width: 60px;
  height: 180px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='30' cy='30' rx='16' ry='28' fill='%2390c850' opacity='0.12' transform='rotate(15,30,30)'/%3E%3Cellipse cx='25' cy='90' rx='14' ry='22' fill='%2390c850' opacity='0.1' transform='rotate(-10,25,90)'/%3E%3Cellipse cx='32' cy='150' rx='15' ry='24' fill='%2390c850' opacity='0.08' transform='rotate(8,32,150)'/%3E%3C/svg%3E") no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}
.home-facility .inner {
  position: relative;
  z-index: 1;
}

.home-recruit {
  position: relative;
  overflow: hidden;
}
.home-recruit::before {
  content: "";
  position: absolute;
  top: 20px;
  right: 30px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0c0d0;
  box-shadow:
    -20px 25px 0 4px rgba(176,208,224,0.3),
    30px 60px 0 6px rgba(240,224,160,0.25);
  pointer-events: none;
  z-index: 0;
}
.home-recruit .inner {
  position: relative;
  z-index: 1;
}

.home-contact {
  position: relative;
  overflow: hidden;
}
.home-contact .inner {
  position: relative;
  z-index: 1;
}

/* --- SWITCH PAGE あしらい --- */
.switch-about {
  position: relative;
  overflow: hidden;
}
.switch-about::before {
  content: "";
  position: absolute;
  top: 40px;
  right: 25px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f0a0b0;
  box-shadow:
    -20px 30px 0 6px rgba(96,192,240,0.3),
    40px 65px 0 4px rgba(176,208,0,0.3),
    -50px 100px 0 8px rgba(240,160,176,0.2),
    60px 140px 0 5px rgba(96,192,240,0.25);
  pointer-events: none;
  z-index: 0;
}
.switch-about::after {
  content: "";
  position: absolute;
  bottom: 50px;
  left: 15px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #60c0f0;
  box-shadow:
    15px -40px 0 5px rgba(176,208,0,0.3),
    -10px -100px 0 7px rgba(240,160,176,0.2),
    25px -150px 0 4px rgba(96,192,240,0.25);
  pointer-events: none;
  z-index: 0;
}
.switch-about .inner {
  position: relative;
  z-index: 1;
}

.switch-activity {
  position: relative;
  overflow: hidden;
}
.switch-activity::after {
  content: "";
  position: absolute;
  top: 80px;
  right: -10px;
  width: 60px;
  height: 200px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 60 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cellipse cx='30' cy='40' rx='16' ry='28' fill='%2390c850' opacity='0.12' transform='rotate(20,30,40)'/%3E%3Cellipse cx='35' cy='110' rx='14' ry='24' fill='%2390c850' opacity='0.1' transform='rotate(-15,35,110)'/%3E%3Cellipse cx='25' cy='170' rx='17' ry='26' fill='%2390c850' opacity='0.08' transform='rotate(10,25,170)'/%3E%3C/svg%3E") no-repeat;
  background-size: contain;
  pointer-events: none;
  z-index: 0;
}
.switch-activity .inner {
  position: relative;
  z-index: 1;
}

.switch-policy {
  position: relative;
  overflow: hidden;
}
.switch-policy::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background:
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.18'/%3E%3C/svg%3E") 5% 20% / 22px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.12'/%3E%3C/svg%3E") 93% 25% / 16px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.15'/%3E%3C/svg%3E") 12% 75% / 18px no-repeat,
    url("data:image/svg+xml,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10,1 L12.4,7.2 L19,7.6 L14,12 L15.6,18.4 L10,15 L4.4,18.4 L6,12 L1,7.6 L7.6,7.2Z' fill='%23fff' opacity='0.1'/%3E%3C/svg%3E") 90% 70% / 14px no-repeat;
  pointer-events: none;
  z-index: 0;
}
.switch-policy .inner {
  position: relative;
  z-index: 1;
}

.switch-domain {
  position: relative;
  overflow: hidden;
}
.switch-domain::before {
  content: "";
  position: absolute;
  top: 20px;
  right: 20px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #b0d000;
  box-shadow:
    -30px 30px 0 5px rgba(240,160,176,0.3),
    20px 75px 0 3px rgba(96,192,240,0.3),
    -40px 130px 0 6px rgba(176,208,0,0.2),
    30px 190px 0 4px rgba(240,160,176,0.2),
    -20px 250px 0 7px rgba(96,192,240,0.2);
  pointer-events: none;
  z-index: 0;
}
.switch-domain .inner,
.switch-support .inner,
.switch-info .inner {
  position: relative;
  z-index: 1;
}

/* ==========================================================================
   SWITCH PAGE
   ========================================================================== */

/* --- スイッチについて --- */
.switch-about {
  padding: 6rem 15px;
}
.switch-about__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  margin-top: 4rem;
}
.switch-about__img img {
  border-radius: 14px;
  width: 100%;
  height: auto;
}
.switch-about__text .section-text {
  margin-top: 1.5rem;
}
.switch-about__text .section-text:first-child {
  margin-top: 0;
}

/* --- 活動内容 --- */
.switch-activity {
  padding: 6rem 15px;
  background-color: #eef6fb;
  background-image: linear-gradient(#60c0f033 1px, transparent 1px),
    linear-gradient(to right, #60c0f033 1px, #eef6fb 1px);
  background-size: 10px 10px;
}
.switch-activity .section-text {
  margin-top: 2rem;
}
.switch-activity__item {
  display: grid;
  grid-template-columns: 38% 1fr;
  gap: 3rem;
  align-items: center;
  margin-top: 4rem;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
}
.switch-activity__item.-reverse {
  grid-template-columns: 1fr 38%;
}
.switch-activity__item.-reverse .switch-activity__img {
  order: 2;
}
.switch-activity__item.-reverse .switch-activity__content {
  order: 1;
}
.switch-activity__img img {
  border-radius: 14px;
  width: 100%;
  height: auto;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.switch-activity__content .c-heading03 {
  margin-bottom: 1rem;
}
.switch-activity__content .section-text {
  margin-top: 1.5rem;
}

/* --- 事業方針・療育方針 --- */
.switch-policy {
  padding: 6rem 15px;
  background: #fff;
  position: relative;
}
.switch-policy__body {
  max-width: 720px;
  margin: 3rem auto 0;
  background: rgba(255,255,255,0.95);
  border-radius: 14px;
  padding: 4rem 3rem;
  text-align: center;
  line-height: 2;
  font-size: 1.6rem;
}
.switch-policy__body p + p {
  margin-top: 1.5rem;
}

/* --- 対応支援・取り組み内容 --- */
.switch-domain {
  padding: 6rem 15px;
  background-color: #f5fbe8;
  background-image: linear-gradient(#b0d00033 1px, transparent 1px),
    linear-gradient(to right, #b0d00033 1px, #f5fbe8 1px);
  background-size: 10px 10px;
}
.switch-domain .section-text {
  margin-top: 2rem;
}
.switch-domain__item {
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
  margin-top: 2.5rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.switch-domain__badge {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  color: #fff;
  padding: 0.8rem 2.5rem;
  border-radius: 50px;
  font-family: "Kiwi Maru", sans-serif;
}
.switch-domain__num {
  font-size: 2.4rem;
  font-weight: 700;
  opacity: 0.7;
}
.switch-domain__label {
  font-size: 1.8rem;
  font-weight: 600;
}
.switch-domain__body {
  margin-top: 1.5rem;
  line-height: 2;
}
.switch-domain__body p {
  margin-top: 0.8rem;
}
.switch-domain__body p:first-child {
  margin-top: 0;
}

/* --- 家族支援・移行支援・地域支援・職員の質の向上 --- */
.switch-support {
  padding: 6rem 15px;
}
.switch-support__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}
.switch-support__item {
  background: #fffcfa;
  border-radius: 14px;
  padding: 3rem;
}
.switch-support__item .c-heading03 {
  margin-bottom: 0;
}
.switch-support__item .section-text {
  margin-top: 1.5rem;
}

/* --- 施設概要 --- */
.switch-info {
  padding: 6rem 15px;
  background: #f7f3f0;
}
.switch-info__wrap {
  max-width: 800px;
  margin: 3rem auto 0;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
}
.switch-info__wrap .c-table02 {
  margin-top: 0;
}
.switch-info__map {
  margin-top: 3rem;
}

/* --- switch SP --- */
@media only screen and (max-width: 767px) {
  .switch-about__body {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .switch-policy__body {
    padding: 3rem 2rem;
    font-size: 1.4rem;
  }
  .switch-activity__item,
  .switch-activity__item.-reverse {
    grid-template-columns: 1fr;
  }
  .switch-activity__item.-reverse .switch-activity__img {
    order: 0;
  }
  .switch-activity__item.-reverse .switch-activity__content {
    order: 0;
  }
  .switch-activity__item {
    padding: 2rem;
  }
  .switch-domain__item {
    padding: 2rem;
  }
  .switch-domain__badge {
    padding: 0.6rem 1.8rem;
  }
  .switch-domain__num {
    font-size: 2rem;
  }
  .switch-domain__label {
    font-size: 1.5rem;
  }
  .switch-support__grid {
    grid-template-columns: 1fr;
  }
  .switch-info__wrap {
    padding: 2rem;
  }
}

/* ==========================================================================
   RECRUIT PAGE
   ========================================================================== */

/* --- 共通パーツ --- */
.recruit-badge {
  display: inline-block;
  padding: 0.4rem 1.4rem;
  border-radius: 50px;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  background: rgba(240,160,176,0.12);
  color: #f0a0b0;
  border: 1px solid rgba(240,160,176,0.3);
  margin-bottom: 1.5rem;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-badge.-green {
  background: rgba(176,208,0,0.12);
  color: #8aad00;
  border-color: rgba(176,208,0,0.3);
}
.recruit-badge.-yellow {
  background: rgba(240,224,160,0.3);
  color: #b89a00;
  border-color: rgba(240,224,160,0.5);
}

/* --- 導入セクション --- */
.recruit-intro {
  padding: 6rem 15px;
}
.recruit-intro__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.recruit-intro__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.recruit-intro__title {
  font-size: 3rem;
  font-weight: 800;
  line-height: 1.4;
  color: #002b4b;
  margin-bottom: 2rem;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-gradient-text {
  background: linear-gradient(90deg, #f0a0b0, #60c0f0, #b0d000);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* 図解 */
.recruit-diagram {
  position: relative;
  width: 100%;
  max-width: 340px;
  aspect-ratio: 1/1;
  margin: 0 auto;
}
.recruit-diagram__bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(240,192,208,0.2), rgba(176,208,224,0.2));
  border-radius: 50%;
  transform: scale(0.9);
}
.recruit-diagram__center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100px;
  height: 100px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.1);
  border: 3px solid #f0a0b0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.3;
  color: #002b4b;
  z-index: 2;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-diagram__node {
  position: absolute;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  z-index: 2;
  font-size: 1.2rem;
  font-weight: 700;
  color: #002b4b;
}
.recruit-diagram__node.-top { top: 5%; left: 50%; transform: translateX(-50%); }
.recruit-diagram__node.-left { bottom: 15%; left: 8%; }
.recruit-diagram__node.-right { bottom: 15%; right: 8%; }
.recruit-diagram__circle {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.recruit-diagram__circle.-pink { background: #fdf2f8; border: 3px solid #f0c0d0; }
.recruit-diagram__circle.-blue { background: #eff6ff; border: 3px solid #b0d0e0; }
.recruit-diagram__circle.-green { background: #f0fdf4; border: 3px solid #c0e8a0; }

/* --- 代表メッセージ --- */
.recruit-message {
  padding: 6rem 15px;
  background: #f7f3f0;
}
.recruit-message__grid {
  display: grid;
  grid-template-columns: 35% 1fr;
  gap: 4rem;
  align-items: start;
  margin-top: 4rem;
}
.recruit-message__img-wrap {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.08);
  border: 4px solid #fff;
  aspect-ratio: 4/5;
  background: #eee;
}
.recruit-message__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.recruit-message__name {
  background: #fff;
  padding: 1.2rem 1.5rem;
  border-radius: 10px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  margin-top: -2rem;
  margin-left: 1rem;
  position: relative;
  z-index: 1;
  display: inline-block;
}
.recruit-message__name-role {
  font-size: 1.2rem;
  font-weight: 700;
  color: #555;
}
.recruit-message__name-main {
  font-size: 1.8rem;
  font-weight: 800;
  color: #f0a0b0;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-message__body .section-text {
  margin-top: 1.5rem;
}
.recruit-message__body .section-text:first-child {
  margin-top: 0;
}

/* --- 数字で見る --- */
.recruit-numbers {
  padding: 6rem 15px;
}
.recruit-numbers__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-top: 4rem;
}
.recruit-numbers__card {
  background: #fff;
  padding: 2.5rem 1.5rem;
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  text-align: center;
  border: 1px solid #f0f0f0;
}
.recruit-numbers__icon {
  font-size: 2.4rem;
  margin-bottom: 1rem;
}
.recruit-numbers__label {
  font-size: 1.3rem;
  color: #888;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.recruit-numbers__value {
  display: flex;
  align-items: baseline;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.2rem;
}
.recruit-numbers__digit {
  font-size: 3.2rem;
  font-weight: 800;
  background: #f0a0b0;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-numbers__small {
  font-size: 1.3rem;
  font-weight: 700;
  color: #888;
}
.recruit-numbers__sub {
  font-size: 1.2rem;
  color: #aaa;
  margin-top: 0.5rem;
}

/* --- お仕事の特徴 --- */
.recruit-features {
  padding: 6rem 15px;
  /* background: #f7f3f0; */
}
.recruit-features__block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  margin-bottom: 6rem;
}
.recruit-features__block:last-child {
  margin-bottom: 0;
}
.recruit-features__block.-reverse {
  direction: rtl;
}
.recruit-features__block.-reverse > * {
  direction: ltr;
}
.recruit-features__text .section-text {
  margin-top: 1.2rem;
}
.recruit-features__media img {
  width: 100%;
  border-radius: 20px;
  aspect-ratio: 1/1;
  object-fit: cover;
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
}
.recruit-highlight {
  background: rgba(176,208,0,0.08);
  border: 1px solid rgba(176,208,0,0.2);
  border-radius: 14px;
  padding: 2rem;
  margin: 1.5rem 0;
  font-size: 1.5rem;
  line-height: 1.8;
  color: #002b4b;
}
.recruit-checklist {
  list-style: none;
  padding: 0;
  margin-top: 1.5rem;
}
.recruit-checklist li {
  position: relative;
  padding-left: 2.5rem;
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
  line-height: 1.8;
}
.recruit-checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: linear-gradient(135deg, #60c0f0, #b0d000);
}

/* --- 1日の業務の流れ --- */
.recruit-flow {
  padding: 6rem 15px;
  background-color: #fdf5f6;
  background-image: linear-gradient(#f0c0d033 1px, transparent 1px),
    linear-gradient(to right, #f0c0d033 1px, #fdf5f6 1px);
  background-size: 10px 10px;
}
.recruit-timeline {
  max-width: 800px;
  margin: 4rem auto 0;
  position: relative;
  padding-left: 5rem;
}
.recruit-timeline::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2rem;
  width: 4px;
  background: linear-gradient(180deg, #f0a0b0, #60c0f0, #b0d000);
  border-radius: 2px;
}
.recruit-timeline__item {
  position: relative;
  margin-bottom: 2.5rem;
}
.recruit-timeline__item:last-child {
  margin-bottom: 0;
}
.recruit-timeline__icon {
  position: absolute;
  left: -3rem;
  top: 0;
  width: 3.6rem;
  height: 3.6rem;
  border-radius: 50%;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
  transform: translateX(-50%);
  z-index: 2;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-timeline__content {
  background: #fff;
  padding: 2rem 2.5rem;
  border-radius: 14px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.recruit-timeline__time {
  font-size: 1.1rem;
  font-weight: 700;
  color: #f0a0b0;
  letter-spacing: 0.05em;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-timeline__title {
  font-size: 1.7rem;
  font-weight: 700;
  color: #002b4b;
  margin: 0.3rem 0 0.5rem;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-timeline__content p {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #555;
}

/* --- 大切にしていること --- */
.recruit-policy {
  padding: 6rem 15px;
  background: linear-gradient(135deg, #f0a0b0, #f8e6ff, #d5e0f4);
  position: relative;
}
.recruit-policy__body {
  max-width: 800px;
  margin: 3rem auto 0;
  background: rgba(255,255,255,0.95);
  border-radius: 14px;
  padding: 4rem 3rem;
  text-align: center;
  line-height: 2;
  font-size: 1.6rem;
}
.recruit-policy__body p {
  margin-top: 1.5rem;
}
.recruit-policy__body p:first-child {
  margin-top: 0;
}
.recruit-policy__highlight {
  padding: 2.5rem 0;
  margin: 2rem 0;
  border-top: 2px dashed rgba(240,160,176,0.4);
  border-bottom: 2px dashed rgba(96,192,240,0.4);
  font-size: 1.7rem;
}
.recruit-policy__highlight p + p {
  margin-top: 1.5rem;
}
.recruit-policy__highlight strong {
  background: linear-gradient(90deg, #f0a0b0, #60c0f0);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.recruit-policy__closing {
  font-size: 1.8rem;
  font-weight: 700;
  color: #002b4b;
}
.recruit-policy__photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  max-width: 800px;
  margin: 3rem auto 0;
}
.recruit-policy__photo img {
  width: 100%;
  border-radius: 14px;
  aspect-ratio: 3/2;
  object-fit: cover;
  box-shadow: 0 4px 16px rgba(0,0,0,0.15);
  border: 3px solid rgba(255,255,255,0.8);
}

/* --- スタッフ紹介 --- */
.recruit-staff {
  padding: 6rem 15px;
}
.recruit-staff__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
  margin-top: 4rem;
}
.recruit-staff__card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border: 1px solid #f0f0f0;
}
.recruit-staff__photo {
  height: 200px;
  overflow: hidden;
  position: relative;
}
.recruit-staff__photo.-blue { background: #eff6ff; }
.recruit-staff__photo.-pink { background: #fdf2f8; }
.recruit-staff__photo.-green { background: #f0fdf4; }
.recruit-staff__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.recruit-staff__info {
  padding: 2rem;
}
.recruit-staff__role {
  display: inline-block;
  padding: 0.3rem 1.2rem;
  background: #f7f3f0;
  border-radius: 50px;
  font-size: 1.2rem;
  font-weight: 700;
  color: #555;
  margin-bottom: 1rem;
}
.recruit-staff__title {
  font-size: 1.6rem;
  font-weight: 700;
  color: #002b4b;
  line-height: 1.5;
  margin-bottom: 1rem;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-staff__detail {
  font-size: 1.4rem;
  line-height: 1.8;
  color: #555;
}
.recruit-staff__detail p {
  margin-top: 0.5rem;
}
.recruit-staff__detail strong {
  color: #002b4b;
}

/* --- 募集要項 --- */
.recruit-req {
  padding: 6rem 15px;
  background: #f7f3f0;
}
.recruit-req__wrap {
  max-width: 800px;
  margin: 3rem auto 0;
  background: #fff;
  border-radius: 14px;
  padding: 3rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}
.recruit-req__wrap .c-table02 {
  margin-top: 0;
}

/* --- CTA --- */
.recruit-cta {
  padding: 4rem 15px 6rem;
}
.recruit-cta__box {
  background: linear-gradient(135deg, #ef6c00, #ef6c00);
  border-radius: 20px;
  padding: 4rem 3rem;
  text-align: center;
  position: relative;
  overflow: hidden;
  max-width: 800px;
  margin: 0 auto;
}
.recruit-cta__deco {
  position: absolute;
  inset: 0;
  opacity: 0.1;
  pointer-events: none;
  background:
    radial-gradient(circle at 10% 20%, #fff 60px, transparent 60px),
    radial-gradient(circle at 85% 15%, #fff 20px, transparent 20px),
    radial-gradient(circle at 30% 80%, #fff 30px, transparent 30px),
    radial-gradient(circle at 75% 70%, #fff 50px, transparent 50px);
}
.recruit-cta__title {
  color: #fff;
  font-size: 2.4rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 1;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-cta__text {
  color: rgba(255,255,255,0.9);
  font-size: 1.5rem;
  margin-bottom: 3rem;
  position: relative;
  z-index: 1;
  line-height: 1.8;
}
.recruit-cta__btns {
  display: flex;
  gap: 2rem;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.recruit-cta__btn-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 300px;
}
.recruit-cta__bubble {
  color: #fff;
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 0.8rem;
  letter-spacing: 0.05em;
}
.recruit-cta__btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  background: #fff;
  padding: 1rem 1rem 1rem 1.5rem;
  border-radius: 50px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1);
  transition: transform 0.3s;
  gap: 1rem;
}
.recruit-cta__btn:hover {
  transform: scale(1.03);
}
.recruit-cta__btn-badge {
  background: #f0e0a0;
  color: #8a6d00;
  font-size: 1.1rem;
  font-weight: 700;
  padding: 0.4rem 0.8rem;
  border-radius: 6px;
  white-space: nowrap;
}
.recruit-cta__btn-text {
  font-size: 1.7rem;
  font-weight: 700;
  color: #002b4b;
  letter-spacing: 0.03em;
  font-family: "Kiwi Maru", sans-serif;
}
.recruit-cta__btn-arrow {
  width: 3.2rem;
  height: 3.2rem;
  background: linear-gradient(135deg, #ef6c00, #ef6c00);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* --- フッター会社概要 --- */
.footer-company {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  border-radius: 20px;
  padding: 3rem 4rem;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border: 1px solid #f0f0f0;
  margin-bottom: 3rem;
  gap: 3rem;
}
.footer-company__info {
  flex: 1;
}
.footer-company__info .footer__logo {
  margin-bottom: 2rem;
}
.footer-company__dl {
  font-size: 1.5rem;
  color: #555;
  line-height: 1.8;
}
.footer-company__dl > div {
  display: flex;
  padding: 1.2rem 0;
  border-bottom: 1px solid #e8e8e8;
}
.footer-company__dl > div:last-child {
  border-bottom: none;
}
.footer-company__dl dt {
  width: 9rem;
  font-weight: 700;
  color: #002b4b;
  flex-shrink: 0;
  font-size: 1.5rem;
}
.footer-company__dl dd {
  margin: 0;
  font-size: 1.5rem;
}
.footer-company__dl a {
  color: inherit;
}
.footer-company__sns {
  flex-shrink: 0;
  align-self: center;
}
.footer-company__insta {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1.4rem 3.5rem;
  border-radius: 50px;
  color: #fff;
  font-weight: 700;
  font-size: 1.6rem;
  background: linear-gradient(to right, #a855f7, #ec4899, #f97316);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  transition: transform 0.3s;
  white-space: nowrap;
}
.footer-company__insta:hover {
  transform: scale(1.03);
}

/* --- フッターレイアウト上書き --- */
.footer-contact__inner.inner {
  display: block !important;
  flex-direction: unset !important;
}

/* --- 施設情報見出し --- */
.footer-facility__heading {
  font-size: 2rem;
  font-weight: 700;
  color: #002b4b;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-family: "Kiwi Maru", sans-serif;
}

/* --- フッター施設情報 --- */
.footer-facility {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
}
.footer-facility__card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  border: 1px solid #f0f0f0;
}
.footer-facility__info {
  padding: 2rem;
}
.footer-facility__logo {
  max-width: 180px;
  height: auto;
  display: block;
  margin-bottom: 0.5rem;
}
.footer-facility__name {
  font-size: 1.8rem;
  font-weight: 700;
  font-family: "Kiwi Maru", sans-serif;
  margin: 1rem 0 0.5rem;
}
.footer-facility__info .footer__logo {
  margin-bottom: 0.5rem;
}
.footer-facility__info .footer__address {
  font-style: normal;
  font-size: 1.4rem;
  line-height: 1.8;
}
.footer-facility__info .footer__address span {
  display: block;
  margin-top: 0.3rem;
}
.footer-facility__info .footer__address a {
  color: inherit;
}
.footer-facility__map {
  width: 100%;
  height: 220px;
  border-top: 1px solid #f0f0f0;
}
.footer-facility__map iframe {
  width: 100%;
  height: 100%;
}

/* --- recruit SP --- */
@media only screen and (max-width: 767px) {
  .recruit-intro__grid {
    grid-template-columns: 1fr;
    gap: 3rem;
  }
  .recruit-intro__title {
    font-size: 2.2rem;
  }
  .recruit-message__grid {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .recruit-message__img {
    max-width: 280px;
    margin: 0 auto;
  }
  .recruit-numbers__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
  .recruit-features__block,
  .recruit-features__block.-reverse {
    grid-template-columns: 1fr;
    direction: ltr;
  }
  .recruit-features__block {
    margin-bottom: 4rem;
  }
  .recruit-flow {
    padding: 4rem 15px;
  }
  .recruit-timeline {
    padding-left: 4rem;
  }
  .recruit-timeline__content {
    padding: 1.5rem;
  }
  .recruit-policy__body {
    padding: 3rem 2rem;
    font-size: 1.4rem;
  }
  .recruit-policy__photos {
    grid-template-columns: 1fr;
  }
  .recruit-staff__grid {
    grid-template-columns: 1fr;
  }
  .recruit-req__wrap {
    padding: 2rem;
  }
  .recruit-cta__box {
    padding: 3rem 2rem;
  }
  .recruit-cta__btns {
    flex-direction: column;
    align-items: center;
  }
  .footer-company {
    flex-direction: column;
    padding: 2.5rem 2rem;
    align-items: flex-start;
  }
  .footer-company__dl dt {
    width: 7rem;
  }
  .footer-company__sns {
    width: 100%;
  }
  .footer-company__insta {
    width: 100%;
    justify-content: center;
  }
  .footer-facility {
    grid-template-columns: 1fr;
  }
}

/* ---- CTA 3カラムカード ---- */
.footer_cta {
    position: relative;
    background: linear-gradient(135deg, #f0a0b0, #FFCC3F);
    padding: 6rem 2rem 8rem;
}
.footer_cta_heading {
    color: #fff;
    font-size: 3rem;
    font-weight: 700;
    text-align: center;
    margin-bottom: 4rem;
    line-height: 1.4;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}
.footer_cta_cards {
    display: flex;
    gap: 2.5rem;
    max-width: 1100px;
    margin: 0 auto;
    justify-content: center;
}
.footer_cta_card {
    flex: 1;
    background: #fff;
    border-radius: 1.2rem;
    text-align: center;
    padding: 5rem 2rem 3rem;
    position: relative;
    text-decoration: none;
    color: #333;
    transition: box-shadow 0.3s, transform 0.3s;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.footer_cta_card:hover {
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    transform: translateY(-4px);
}
.footer_cta_card_icon {
    position: absolute;
    top: -3rem;
    left: 50%;
    transform: translateX(-50%);
    width: 6rem;
    height: 6rem;
}
.footer_cta_card_icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.footer_cta_card_title {
    font-size: 1.8rem;
    font-weight: 700;
    color: #333;
    margin-bottom: 1.2rem;
}
.footer_cta_card_txt {
    font-size: 1.4rem;
    line-height: 1.8;
    color: #555;
    margin-bottom: 2rem;
    flex-grow: 1;
}
.footer_cta_card_btn {
    display: inline-block;
    background-image: linear-gradient(90deg, #f0a0b0 40%, #ffe6a0 100%);
    color: #fff;
    padding: 1rem 3rem;
    border-radius: 5rem;
    font-size: 1.4rem;
    font-weight: 700;
    transition: opacity 0.3s;
}
.footer_cta_card:hover .footer_cta_card_btn {
    opacity: 0.8;
}
.footer_cta_card_tel {
    font-size: 2.8rem;
    font-weight: 700;
    color: #60c0f0;
    margin-bottom: 0.5rem;
    letter-spacing: 0.05em;
}
.footer_cta_card_time {
    font-size: 1.3rem;
    color: #777;
}
@media only screen and (max-width: 767px) {
    .footer_cta {
        padding: 5rem 1.5rem 6rem;
    }
    .footer_cta_heading {
        font-size: 2.2rem;
        margin-bottom: 3.5rem;
    }
    .footer_cta_cards {
        flex-direction: column;
        gap: 4rem;
        max-width: 400px;
        margin: 0 auto;
    }
    .footer_cta_card {
        padding: 5rem 2rem 2.5rem;
    }
    .footer_cta_card_tel {
        font-size: 2.4rem;
    }
}
/* ---- /CTA 3カラムカード ---- */

@media only screen and (max-width: 767px) {
  a.btn.btn-border {
    width: 100% !important;
  }
  .recruit-timeline {
    padding-left: 5rem;
  }
}

/* --- AT ギャラリー (CSS Scroll Snap、slick不使用) --- */
.at-gallery {
  display: flex;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  border-radius: 14px;
  width: 100%;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
  gap: 0;
  scrollbar-width: thin;
  scrollbar-color: rgba(0,0,0,0.25) transparent;
}
.at-gallery img {
  flex: 0 0 100%;
  width: 100%;
  max-width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
  scroll-snap-align: start;
}
.at-gallery::-webkit-scrollbar {
  height: 6px;
}
.at-gallery::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.25);
  border-radius: 3px;
}
.at-gallery__hint {
  text-align: center;
  font-size: 1.2rem;
  color: #888;
  margin-top: 0.8rem;
}
.saicolo-activity__slider .slick-prev,
.saicolo-activity__slider .slick-next {
  z-index: 2;
  width: 36px;
  height: 36px;
}
.saicolo-activity__slider .slick-prev { left: 12px; }
.saicolo-activity__slider .slick-next { right: 12px; }
.saicolo-activity__slider .slick-prev:before,
.saicolo-activity__slider .slick-next:before {
  font-size: 28px;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
  opacity: 1;
}
.saicolo-activity__slider .slick-dots {
  bottom: 12px;
}
.saicolo-activity__slider .slick-dots li button:before {
  color: #fff;
  font-size: 10px;
  opacity: 0.7;
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.saicolo-activity__slider .slick-dots li.slick-active button:before {
  opacity: 1;
}

/* --- 支援プログラム（PDF）--- */
.saicolo-program-pdf,
.switch-program-pdf {
  padding: 6rem 15px;
}
.program-pdf__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
  margin: 3rem auto 0;
  max-width: 720px;
  text-decoration: none;
  transition: transform 0.3s ease;
  padding-right: 0;
}
.program-pdf__link[href$=".pdf"]::after {
  content: none;
  display: none;
}
.program-pdf__link:hover {
  transform: translateY(-4px);
}
.program-pdf__thumb {
  width: 100%;
  max-width: 640px;
  height: auto;
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  border: 1px solid #e0d8c7;
  background: #fff;
  display: block;
}
.program-pdf__caption {
  display: inline-block;
  padding: 1rem 2.5rem;
  background: #ef6c00;
  color: #fff;
  border-radius: 999px;
  font-weight: 700;
  font-size: 1.6rem;
  box-shadow: 0 4px 12px rgba(239,108,0,0.3);
}

/* --- 職場環境改善の見える化 アンカー対応 --- */
#workplace {
  scroll-margin-top: 100px;
}

/* --- saicolo-visible__detail 複数項目対応 --- */
.saicolo-visible__detail + .saicolo-visible__detail {
  margin-top: 1.2rem;
}
.saicolo-visible__card {
  align-self: start;
}

/* --- ペア単位ブロック (要件＋取組をひとまとまりに) --- */
.saicolo-visible__pair {
  background: #fafafa;
  border-radius: 10px;
  padding: 1.5rem 1.5rem 1.8rem;
  text-align: left;
}
.saicolo-visible__pair .saicolo-visible__detail {
  margin-top: 0;
}
.saicolo-visible__pair .saicolo-visible__detail + .saicolo-visible__detail {
  margin-top: 1.2rem;
}
.saicolo-visible__pairs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  margin-top: 1.5rem;
}
@media (min-width: 769px) {
  .saicolo-visible__pairs {
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
  }
}

@media (max-width: 768px) {
  .saicolo-activity__slider .slick-prev,
  .saicolo-activity__slider .slick-next {
    width: 28px;
    height: 28px;
  }
  .saicolo-activity__slider .slick-prev:before,
  .saicolo-activity__slider .slick-next:before {
    font-size: 22px;
  }
  .program-pdf__thumb {
    max-width: 100%;
  }
  .saicolo-program-pdf,
  .switch-program-pdf {
    padding: 4rem 15px;
  }
}
