@charset "UTF-8";
/* Theme Name: custom */
*, *::before, *::after {
  box-sizing: border-box;
}

article, aside, footer, header, nav, section, figcaption, figure, main, canvas, time {
  display: block;
}

button, input, optgroup, select, textarea, figure {
  margin: 0;
}

button, input {
  overflow: visible;
}

button, select {
  text-transform: none;
}

button {
  border: none;
  background: none;
  cursor: pointer;
}
button:focus {
  outline: none;
}

progress {
  display: inline-block;
  vertical-align: baseline;
}

textarea {
  overflow: auto;
  resize: none;
}

[type=checkbox], [type=radio] {
  padding: 0;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
  outline-offset: -2px;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  appearance: button;
  font: inherit;
}

[hidden] {
  display: none;
}

body, h1, h2, h3, h4, h5, h6, ul, ol, dl, dd, p, blockquote, figure {
  margin: 0;
}

body {
  width: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  color: #333;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}
body.home {
  background-color: #fcfbf2;
}

body,
button {
  font-family: "Zen Kaku Gothic New", sans-serif;
}

#wrapper {
  overflow-x: hidden;
}

#wrapperFixed {
  width: 100%;
  padding-bottom: 40px;
}
@media screen and (min-width: 960px) {
  #wrapperFixed {
    padding-bottom: 0;
  }
}

.bgFixed {
  position: fixed;
  height: 100%;
}

a,
button {
  color: inherit;
  text-decoration: none;
  transition: 0.3s;
}
a:hover,
button:hover {
  opacity: 0.7;
}

.btn {
  text-align: center;
}
.btn a {
  display: inline-block;
  color: #fff;
  background-color: #333;
  text-decoration: none;
}

figure {
  text-align: center;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

table {
  width: 100%;
  border-collapse: collapse;
}
table th,
table td {
  border: 1px solid #333;
}

.header {
  width: 100%;
  height: 60px;
  padding-inline: 2.6666666667vw;
  position: fixed;
  top: 0;
  z-index: 5;
}
@media screen and (min-width: 960px) {
  .header {
    height: auto;
    padding-inline: 30px;
  }
}

.header-row {
  display: grid;
  align-items: center;
  grid-template-columns: 118px 1fr;
  column-gap: 20px;
  height: 100%;
  padding-block: 10px;
}
@media screen and (min-width: 960px) {
  .header-row {
    grid-template-columns: 265px 1fr;
    column-gap: 40px;
    max-width: 1340px;
    margin-inline: auto;
  }
}

.header-logo {
  line-height: 0;
  position: relative;
  z-index: 1;
}

.header-wrap {
  display: grid;
  justify-content: end;
  row-gap: 20px;
}

.header-contact {
  display: grid;
  grid-template-columns: repeat(3, auto);
  width: 100%;
  position: fixed;
  left: 0;
  bottom: 0;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .header-contact {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 20px;
    position: static;
  }
}
.header-contact .header-btn {
  display: grid;
  justify-content: center;
  align-items: center;
  grid-template-columns: auto auto;
  column-gap: 4px;
  min-height: 40px;
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  border-radius: 5px 5px 0 0;
  padding: 5px 10px;
  line-height: 1.2;
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn {
    column-gap: 8px;
    min-height: 50px;
    font-size: min(1.4285714286vw, 20px);
    border-radius: 9999px;
    padding: 5px 20px;
  }
}
.header-contact .header-btn::before {
  content: "";
  display: inline-block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.header-contact .header-btn.tel {
  background-image: linear-gradient(0deg, #f36f95 20%, #efc3d3 100%);
}
.header-contact .header-btn.tel:hover {
  background-image: linear-gradient(180deg, #f36f95 20%, #efc3d3 100%);
  opacity: 1;
}
.header-contact .header-btn.tel::before {
  width: 14px;
  aspect-ratio: 7/9;
  background-image: url(img/icon-tel.svg);
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.tel::before {
    width: 1.05em;
  }
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.tel .text {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    column-gap: 10px;
  }
}
.header-contact .header-btn.tel .num {
  display: none;
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.tel .num {
    display: inline;
    font-size: 28px;
    font-size: min(2vw, 28px);
  }
}
.header-contact .header-btn.tel .txt {
  font-size: 15px;
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.tel .txt {
    font-size: 18px;
    font-size: min(1.2857142857vw, 18px);
  }
}
.header-contact .header-btn.email {
  background-image: linear-gradient(0deg, #3db07a 20%, #bbd9c7 100%);
}
.header-contact .header-btn.email:hover {
  background-image: linear-gradient(180deg, #3db07a 20%, #bbd9c7 100%);
  opacity: 1;
}
.header-contact .header-btn.email::before {
  width: 19px;
  aspect-ratio: 5/4;
  background-image: url(img/icon-email.svg);
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.email::before {
    width: 1.2em;
  }
}
.header-contact .header-btn.line {
  background-image: linear-gradient(0deg, #42c041 20%, #bbd7b7 100%);
}
.header-contact .header-btn.line:hover {
  background-image: linear-gradient(180deg, #42c041 20%, #bbd7b7 100%);
  opacity: 1;
}
.header-contact .header-btn.line::before {
  width: 24px;
  aspect-ratio: 75/58;
  background-image: url(img/icon-line.svg);
}
@media screen and (min-width: 960px) {
  .header-contact .header-btn.line::before {
    width: 1.55em;
  }
}

.header-gnav {
  display: none;
}
@media screen and (min-width: 960px) {
  .header-gnav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px 1em;
    font-size: min(1.2857142857vw, 18px);
    list-style: none;
    padding-inline: 10px;
  }
}

@media screen and (min-width: 960px) {
  .header-nav {
    display: none;
  }
}

.header-nav-btn {
  display: grid;
  align-content: center;
  row-gap: 5px;
  width: 40px;
  aspect-ratio: 1;
  color: #48b381;
  font-size: 10px;
  font-weight: bold;
  padding: 0;
  line-height: 1;
  position: relative;
  z-index: 3;
  cursor: pointer;
}
.header-nav-btn::before, .header-nav-btn::after {
  content: "";
  display: block;
  width: 100%;
  height: 5px;
  border-radius: 9999px;
  order: -1;
  transition: 0.3s;
}
.header-nav-btn::before {
  background-color: #f36f95;
}
.header-nav-btn::after {
  background-color: #48b381;
}
.header-nav-btn.active {
  color: transparent;
}
.header-nav-btn.active::before, .header-nav-btn.active::after {
  position: absolute;
  top: 50%;
  left: 0;
}
.header-nav-btn.active::before {
  transform: translateY(-50%) rotate(-45deg);
}
.header-nav-btn.active::after {
  transform: translateY(-50%) rotate(45deg);
}

.header-menu {
  width: 100%;
  height: 100vh; /* dvhに対応してないブラウザ用 */
  height: 100dvh;
  background: linear-gradient(0deg, #333 0%, #333 100%) no-repeat center top 59px/100% 1px;
  background-color: #fff;
  padding-block: 60px;
  list-style: none;
  position: absolute;
  top: 0;
  right: 0;
  overflow-y: scroll;
  opacity: 0;
  visibility: hidden;
  transition: 0.4s;
}
.header-menu.open {
  opacity: 1;
  visibility: visible;
}

.header-menu-cat {
  padding-inline: 2.6666666667vw;
}

.header-menu-name {
  font-size: 19px;
  font-weight: bold;
  background: linear-gradient(0deg, #333 0%, #333 100%) no-repeat center bottom/100% 1px;
  padding-block: 11px;
  line-height: 2;
  position: relative;
}

.header-menu-acc {
  width: 50px;
  height: 25px;
  background-color: #f36f95;
  border-radius: 9999px;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
.header-menu-acc::before, .header-menu-acc::after {
  content: "";
  display: block;
  width: 15px;
  height: 2px;
  background-color: #fff;
  border-radius: 1px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.header-menu-acc::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.header-menu-acc[aria-expanded=true]::after {
  transform: translate(-50%, -50%);
}

.header-menu-list {
  display: grid;
  row-gap: 12px;
  height: 0;
  background: linear-gradient(0deg, #333 0%, #333 100%) no-repeat center bottom/100% 1px;
  font-size: 17px;
  list-style: none;
  padding-inline: 10px;
  line-height: 2;
  overflow: hidden;
}
@media screen and (min-width: 960px) {
  .header-menu-list {
    row-gap: 0;
    font-size: 18px;
  }
}
.header-menu-list.open {
  height: auto;
  padding-block: 21px;
}
.header-menu-list li {
  padding-left: 14px;
  position: relative;
}
.header-menu-list li a::before {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1;
  background-color: #3db07a;
  border-radius: 50%;
  position: absolute;
  top: 14px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .header-menu-list li a::before {
    top: 15px;
  }
}

.top-frame {
  max-width: 1400px;
  margin-inline: auto;
}

.top-mv {
  width: 97.3333333333%;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 640px) {
  .top-mv {
    width: 95.7142857143%;
    margin-inline: auto;
  }
}
.top-mv .cts-illust {
  width: 65.7534246575%;
  position: absolute;
  right: -1.9%;
  bottom: 0;
  transform: translateY(42%);
}
@media screen and (min-width: 640px) {
  .top-mv .cts-illust {
    width: 65.2985074627%;
    right: 2.4%;
    transform: translateY(35%);
  }
}
.top-mv .cts-txt {
  font-size: 13px;
  font-weight: bold;
  line-height: 1.7692307692;
  position: absolute;
  top: 100%;
  left: 5.5%;
  transform: translateY(-80%);
}
@media screen and (min-width: 640px) {
  .top-mv .cts-txt {
    font-size: min(1.7142857143vw, 24px);
    line-height: 2.0416666667;
    left: 4.25%;
  }
  .top-mv .cts-txt br.only-sp {
    display: none;
  }
}

.top-bg {
  padding-inline: 2.6666666667vw;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .top-bg {
    padding-inline: 40px;
  }
}
.top-bg::before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 125/1414;
  background-image: url(img/bg-road-sp.png);
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100%;
  margin-top: -0.375%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
@media screen and (min-width: 640px) {
  .top-bg::before {
    aspect-ratio: 7/19;
    background-image: url(img/bg-road-pc.png);
  }
}

.top-intro {
  max-width: 810px;
  margin-inline: auto;
  padding-top: 150px;
}
@media screen and (min-width: 960px) {
  .top-intro {
    padding-top: 285px;
  }
}
.top-intro .cts-title {
  font-size: 31px;
  font-weight: bold;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .top-intro .cts-title {
    font-size: 48px;
  }
}
.top-intro .cts-txt {
  font-size: 19px;
  font-weight: 500;
  padding-inline: min(4vw, 40px);
  margin-top: 20px;
  line-height: 2.1578947368;
}
@media screen and (min-width: 960px) {
  .top-intro .cts-txt {
    font-size: 24px;
    margin-top: 40px;
    line-height: 2.5;
  }
}
.top-intro .cts-txt mark {
  background: #fff;
  border-radius: 10px;
  padding: 3.75px 10px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone; /* Safari対応 */
}
@media screen and (min-width: 960px) {
  .top-intro .cts-txt mark {
    border-radius: 20px;
    padding: 7.5px 15px;
  }
}
.top-intro .cts-illust {
  width: 86.1971830986%;
  margin-top: 30px;
  margin-inline: auto;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .top-intro .cts-illust {
    width: 100%;
    margin-top: 60px;
  }
}

.top-about .cts-link,
.top-main .cts-link,
.top-faq .cts-link {
  display: block;
  position: relative;
  transition: none;
}
.top-about .cts-link:hover,
.top-main .cts-link:hover,
.top-faq .cts-link:hover {
  opacity: 1;
}
.top-about .cts-link .cts-ttl,
.top-main .cts-link .cts-ttl,
.top-faq .cts-link .cts-ttl {
  display: grid;
  justify-items: center;
  align-content: center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
@media screen and (min-width: 640px) {
  .top-about .cts-box,
  .top-main .cts-box,
  .top-faq .cts-box {
    border-radius: 20px;
    padding: 20px;
    transition: 0.3s;
  }
  .top-about .cts-box:has(a:hover),
  .top-main .cts-box:has(a:hover),
  .top-faq .cts-box:has(a:hover) {
    color: #fff;
    background-color: #f36f95;
  }
}

.top-about {
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(auto-fill, 275px);
  gap: 30px;
  margin-top: 75px;
}
@media screen and (min-width: 640px) {
  .top-about {
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
  }
}
@media screen and (min-width: 960px) {
  .top-about {
    grid-template-columns: repeat(3, 1fr);
    margin-top: 12.1212121212%;
  }
}
.top-about .cts-ttl {
  width: 63.6363636364%;
  aspect-ratio: 35/8;
  font-size: 19px;
  font-weight: 500;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .top-about .cts-ttl {
    width: 50%;
    aspect-ratio: 2.5;
    font-size: min(1.7142857143vw, 24px);
    font-weight: bold;
  }
}
.top-about .cts-bg {
  aspect-ratio: 55/36;
  mask-image: url(img/mask-sm-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
  background-image: linear-gradient(0deg, #f5c3d7 0%, #faecf4 46.6666666667%);
}
@media screen and (min-width: 960px) {
  .top-about .cts-bg {
    aspect-ratio: 10/9;
    mask-image: url(img/mask-sm-pc.svg);
  }
}
.top-about .cts-bg::before {
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: 56%;
  left: 50%;
}
.top-about .cts-bg.icon-service::before {
  width: 77.5px;
  aspect-ratio: 31/27;
  background-image: url(img/icon-service.png);
  transform: translate(-42%, -50%);
}
@media screen and (min-width: 960px) {
  .top-about .cts-bg.icon-service::before {
    width: 155px;
  }
}
.top-about .cts-bg.icon-introduction::before {
  width: 100px;
  aspect-ratio: 100/59;
  background-image: url(img/icon-introduction.png);
  transform: translate(-40%, -50%);
}
@media screen and (min-width: 960px) {
  .top-about .cts-bg.icon-introduction::before {
    width: 200px;
  }
}
.top-about .cts-bg.icon-guidance::before {
  width: 101.5px;
  aspect-ratio: 29/18;
  background-image: url(img/icon-guidance.png);
  transform: translate(-27%, -50%);
}
@media screen and (min-width: 960px) {
  .top-about .cts-bg.icon-guidance::before {
    width: 203px;
  }
}
.top-about .cts-slug {
  width: 100%;
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.06em;
  position: absolute;
  left: 0;
  bottom: 10px;
}
@media screen and (min-width: 960px) {
  .top-about .cts-slug {
    font-size: min(3vw, 42px);
    bottom: 20px;
  }
}

.top-main {
  display: grid;
  row-gap: 30px;
  margin-top: 50px;
}
@media screen and (min-width: 640px) {
  .top-main {
    grid-template-columns: repeat(auto-fill, 395px);
  }
}
@media screen and (min-width: 960px) {
  .top-main {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 20px;
    margin-top: 60px;
  }
}
.top-main .cts-ttl {
  width: 74.6478873239%;
  aspect-ratio: 53/11;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
}
@media screen and (min-width: 960px) {
  .top-main .cts-ttl {
    width: 67.2131147541%;
    aspect-ratio: 41/9;
    font-size: min(1.4285714286vw, 21px);
  }
}
.top-main .cts-ttl span {
  font-size: 1.5em;
  font-weight: bold;
}
@media screen and (min-width: 960px) {
  .top-main .cts-ttl span {
    font-size: 1.7em;
  }
}
.top-main .cts-thumb {
  aspect-ratio: 71/57;
  mask-image: url(img/mask-md-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
@media screen and (min-width: 960px) {
  .top-main .cts-thumb {
    aspect-ratio: 61/55;
    mask-image: url(img/mask-md-pc.svg);
  }
}
.top-main .cts-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.top-faq {
  margin-top: 50px;
}
@media screen and (min-width: 960px) {
  .top-faq {
    margin-top: 60px;
  }
}
.top-faq .cts-ttl {
  width: 47.8873239437%;
  aspect-ratio: 34/9;
  font-size: 21px;
  font-weight: bold;
  line-height: 1;
}
@media screen and (min-width: 960px) {
  .top-faq .cts-ttl {
    width: 21.875%;
    aspect-ratio: 28/9;
    font-size: min(2.2857142857vw, 32px);
  }
}
.top-faq .cts-thumb {
  aspect-ratio: 71/42;
  mask-image: url(img/mask-lg-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
@media screen and (min-width: 960px) {
  .top-faq .cts-thumb {
    aspect-ratio: 128/31;
    mask-image: url(img/mask-lg-pc.svg);
  }
}
.top-faq .cts-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

body:not(.home) #wrapperFixed {
  padding-top: 60px;
}
@media screen and (min-width: 960px) {
  body:not(.home) #wrapperFixed {
    padding-top: 130px;
  }
}
body:not(.home) .main {
  position: relative;
  z-index: 2;
}
body:not(.home) .footer {
  background-color: #fcfbf2;
  margin-top: 90px;
}
@media screen and (min-width: 960px) {
  body:not(.home) .footer {
    margin-top: min(17.8571428571%, 250px);
  }
}
body:not(.home) .footer::before {
  content: "";
  display: block;
  width: 640px;
  aspect-ratio: 175/113;
  background-image: url(img/bg-footer.jpg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  top: -11%;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
}
@media screen and (min-width: 640px) {
  body:not(.home) .footer::before {
    width: 100%;
    top: -30.3571428571vw;
  }
}

.page-frame {
  max-width: 1400px;
  margin-inline: auto;
  padding-inline: 2.6666666667vw;
}
@media screen and (min-width: 960px) {
  .page-frame {
    padding-inline: 30px;
  }
}

.page-thumb {
  aspect-ratio: 71/60;
  mask-image: url(img/mask-mv-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
}
.page-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 75% center;
}

.page-head {
  display: grid;
  grid-template-rows: auto 1fr;
  row-gap: 4px;
  width: 54.9295774648%;
  aspect-ratio: 1.95;
  padding-inline: 2.8169014085%;
  margin-top: -28.1690140845%;
  position: relative;
}

@media screen and (min-width: 640px) {
  .page-thumb {
    aspect-ratio: 67/30;
    mask-image: url(img/mask-mv-pc.svg);
  }
  .page-head {
    width: 41.7910447761%;
    aspect-ratio: 2.8;
    padding-inline: 3.7313432836%;
    margin-top: -14.9253731343%;
  }
}
.breadcrumb {
  color: #999;
  font-size: 10px;
  padding-top: 8px;
}
@media screen and (min-width: 960px) {
  .breadcrumb {
    font-size: 16px;
    padding-top: 12px;
  }
}
.breadcrumb > span {
  display: flex;
  flex-wrap: wrap;
  column-gap: 1em;
}
.breadcrumb span.breadcrumb_last {
  color: #333;
}

.page-title {
  display: flex;
  align-items: center;
  font-size: 26px;
  font-weight: 900;
}
@media screen and (min-width: 960px) {
  .page-title {
    font-size: min(3.4285714286vw, 48px);
  }
}

.page-content {
  padding-inline: min(4vw, 40px);
  margin-top: 35px;
}
@media screen and (min-width: 960px) {
  .page-content {
    margin-top: 128px;
    margin-top: 95px;
  }
}
.page-content .cmn-slug {
  font-size: 46px;
  font-weight: 900;
  text-align: center;
  line-height: 1;
  letter-spacing: 0.06em;
  word-break: break-all;
  text-wrap: balance;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-slug {
    font-size: 92px;
  }
}
.page-content .cmn-slug span {
  display: inline-block;
  background-image: linear-gradient(0deg, #fce386 0%, #f8f2be 60%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.page-content .cmn-slug-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-40%, -50%);
  pointer-events: none;
}
.page-content .cmn-frame {
  max-width: 700px;
  margin-inline: auto;
}
.page-content .cmn-intro {
  font-size: 17px;
  margin-top: 2em;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-intro {
    font-size: 24px;
  }
}
.page-content .cmn-txt {
  font-size: 18px;
  margin-top: 2em;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-txt {
    font-size: 20px;
  }
}
.page-content .cmn-txt:first-child {
  margin-top: 0;
}
.page-content .cmn-btn {
  display: grid;
  align-items: center;
  grid-template-columns: auto 1fr auto;
  color: #fff;
  background: linear-gradient(180deg, #bbd9c7 0%, #3db07a 80%);
  font-size: 21px;
  font-weight: bold;
  border-radius: 9999px;
  padding: 9px 20px;
  margin-inline: auto;
  text-align: center;
  line-height: 2;
  max-width: 305px;
  margin-top: 40px;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-btn {
    font-size: 26px;
    padding: 14px 30px;
  }
}
.page-content .cmn-btn:hover {
  background: linear-gradient(0deg, #bbd9c7 0%, #3db07a 80%);
  opacity: 1;
}
.page-content .cmn-btn::before {
  content: "";
  display: block;
  width: 11.25px;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-btn::before {
    width: 12.5px;
  }
}
.page-content .cmn-btn::after {
  content: "";
  display: block;
  width: 45px;
  aspect-ratio: 9/5;
  background-image: url(img/btn-arrow.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px;
  background-color: #fff;
  border-radius: 9999px;
}
@media screen and (min-width: 960px) {
  .page-content .cmn-btn::after {
    width: 50px;
    aspect-ratio: 5/3;
    background-size: 22px;
  }
}
@media screen and (min-width: 960px) {
  .page-content .cmn-btn {
    max-width: 320px;
    margin-top: 68px;
  }
}

.tpl-mono .cmn-title {
  display: grid;
  justify-content: center;
  font-size: 21px;
  font-weight: bold;
  margin-top: 45px;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .tpl-mono .cmn-title {
    font-size: 34px;
    line-height: 2.1176470588;
    margin-top: 68px;
  }
}

.tpl-dual .cmn-row {
  display: grid;
  row-gap: 18px;
  margin-top: 40px;
}
@media screen and (min-width: 960px) {
  .tpl-dual .cmn-row {
    grid-template-columns: 0.4166666667fr 0.5833333333fr;
    column-gap: 60px;
    margin-top: 75px;
  }
}
.tpl-dual .cmn-row:first-child {
  margin-top: 0;
}
.tpl-dual .cmn-div {
  border-top: 1px solid #f0f0f0;
  padding-top: 45px;
  margin-top: 50px;
}
@media screen and (min-width: 960px) {
  .tpl-dual .cmn-div {
    padding-top: 85px;
    margin-top: 90px;
  }
}
.tpl-dual .cmn-title {
  font-size: 21px;
  font-weight: 900;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .tpl-dual .cmn-title {
    font-size: 38px;
  }
}
.tpl-dual .cmn-title-sub {
  font-size: 16px;
  font-weight: 900;
  margin-top: 16px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .tpl-dual .cmn-title-sub {
    font-size: 28px;
    margin-top: 38px;
  }
}
.tpl-dual .cmn-title-sub:first-child {
  margin-top: 0;
}

/* 会社情報 */
.page-company {
  padding-bottom: 90px;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-company {
    padding-bottom: 24px;
  }
}
.page-company::before {
  content: "";
  display: block;
  width: 180%;
  aspect-ratio: 1400/1093;
  background-image: url(img/bg-company.png);
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  bottom: -3%;
  left: 50%;
  transform: translateX(-40%);
  z-index: -1;
}
@media screen and (min-width: 640px) {
  .page-company::before {
    width: 125%;
  }
}
@media screen and (min-width: 960px) {
  .page-company::before {
    width: 1400px;
    bottom: -12px;
    transform: translateX(-50%);
  }
}
.page-company .cts-info {
  max-width: 480px;
  margin: 40px auto 0;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-company .cts-info {
    margin-top: 70px;
  }
}
.page-company .cts-info img {
  width: 158px;
  position: absolute;
  top: 100%;
  right: 100%;
  transform: translate(92%, -15px);
}
@media screen and (min-width: 960px) {
  .page-company .cts-info img {
    width: 316px;
    top: 25px;
    transform: translateX(27px);
  }
}
.page-company .cts-box {
  color: #48b381;
  border: 3px solid;
  border-bottom: none;
  border-radius: 20px 20px 0 0;
  padding: 26px 20px;
}
@media screen and (min-width: 960px) {
  .page-company .cts-box {
    border-width: 6px;
    border-radius: 40px 40px 0 0;
    padding: 42px 40px 28px;
  }
}
.page-company .cts-addr {
  font-size: 18px;
  font-style: normal;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-company .cts-addr {
    font-size: 20px;
  }
}
.page-company .cts-addr span {
  display: inline-block;
}
.page-company .cts-tel {
  font-size: 37px;
  font-weight: 900;
  margin-top: 4px;
  text-align: center;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 960px) {
  .page-company .cts-tel {
    font-size: 42px;
  }
}
.page-company .cts-tel svg {
  width: 27px;
  margin-right: 4px;
  vertical-align: -8px;
}
@media screen and (min-width: 960px) {
  .page-company .cts-tel svg {
    width: 31px;
    margin-right: 8px;
  }
}
.page-company .cts-ttl {
  color: #fff;
  background-color: #48b381;
  font-size: 21px;
  border-radius: 0 0 20px 20px;
  padding: 6px 1em;
  text-align: center;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 960px) {
  .page-company .cts-ttl {
    font-size: 24px;
    border-radius: 0 0 40px 40px;
  }
}

/* 会社概要 */
.page-profile .cts-def {
  font-size: 18px;
  border-bottom: 1px solid #333;
}
@media screen and (min-width: 960px) {
  .page-profile .cts-def {
    font-size: 20px;
  }
}
.page-profile .cts-def dt {
  font-weight: bold;
  border-top: 1px solid #333;
  padding-top: 24px;
}
.page-profile .cts-def dt:first-of-type {
  border-top: none;
  padding-top: 0;
}
.page-profile .cts-def dd {
  padding-bottom: 18px;
  margin-top: 11px;
  line-height: 2;
}

/* サービス内容 */
.page-service {
  padding-bottom: 60px;
}
@media screen and (min-width: 640px) {
  .page-service {
    padding-bottom: 0;
  }
}
.page-service .cmn-slug-icon {
  width: 93px;
}
@media screen and (min-width: 960px) {
  .page-service .cmn-slug-icon {
    width: 155px;
  }
}
.page-service .cts-box {
  max-width: 480px;
  color: #fff;
  background-color: #48b381;
  font-size: 20px;
  font-weight: bold;
  border-radius: 20px;
  margin-top: 40px;
  margin-inline: auto;
  padding: 28px 18px;
  text-align: center;
  line-height: 2;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-service .cts-box {
    font-size: 24px;
    border-radius: 40px;
    padding: 38px;
    margin-top: 50px;
  }
}
.page-service .cts-box img {
  width: 121px;
  position: absolute;
  top: 100%;
  right: 100%;
  transform: translate(108%, -25px);
  pointer-events: none;
}
@media screen and (min-width: 640px) {
  .page-service .cts-box img {
    width: 164px;
    top: auto;
    bottom: -20px;
    transform: translateX(100px);
  }
}
@media screen and (min-width: 960px) {
  .page-service .cts-box img {
    width: 242px;
    bottom: -2px;
  }
}

.page-introduction .cmn-slug-icon {
  width: 100px;
}
@media screen and (min-width: 960px) {
  .page-introduction .cmn-slug-icon {
    width: 200px;
  }
}
.page-introduction .cts-section {
  padding-top: 40px;
  padding-bottom: 50px;
  margin-top: 40px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 640px) {
  .page-introduction .cts-section {
    padding-left: 5.3571428571%;
  }
}
@media screen and (min-width: 960px) {
  .page-introduction .cts-section {
    max-width: 1200px;
    padding-top: 60px;
    padding-bottom: 100px;
    padding-left: 10.7142857143%;
    margin: 110px auto 100px;
  }
}
.page-introduction .cts-section::before {
  content: "";
  display: block;
  width: 80vw;
  height: 100%;
  background-image: linear-gradient(0deg, #fce386 0%, #f8f2be 60%);
  border-radius: 0 10px 10px 0;
  position: absolute;
  top: 0;
  left: -6.6666666667vw;
  z-index: -1;
}
@media screen and (min-width: 640px) {
  .page-introduction .cts-section::before {
    width: min(60%, 450px);
    border-radius: 10px;
    left: -15px;
  }
}
@media screen and (min-width: 960px) {
  .page-introduction .cts-section::before {
    width: 700px;
    border-radius: 20px;
    left: -30px;
  }
}
.page-introduction .cts-title {
  justify-content: start;
  margin-top: 0;
  text-align: left;
}
.page-introduction .cts-row {
  display: grid;
  row-gap: 20px;
  padding-inline: min(2.6666666667vw, 30px);
  margin-top: 40px;
}
@media screen and (min-width: 640px) {
  .page-introduction .cts-row {
    align-items: center;
    grid-template-columns: 0.4134615385fr 0.5865384615fr;
    column-gap: 25px;
    padding: 0;
  }
}
@media screen and (min-width: 960px) {
  .page-introduction .cts-row {
    margin-top: 60px;
  }
  .page-introduction .cts-row:first-of-type {
    margin-top: 30px;
  }
}
.page-introduction .cts-txt {
  font-size: 17px;
  font-weight: bold;
  line-height: 2.1176470588;
}
@media screen and (min-width: 960px) {
  .page-introduction .cts-txt {
    font-size: 24px;
    line-height: 2;
  }
}
.page-introduction .cts-img img {
  border-radius: 10px;
}
@media screen and (min-width: 960px) {
  .page-introduction .cts-img img {
    border-radius: 20px;
  }
}

.page-parent-introduction .cmn-list {
  display: grid;
  row-gap: 9px;
  font-size: 18px;
  border: 3px solid #48b381;
  border-radius: 20px;
  list-style: none;
  padding: 27px 24px;
  margin-top: 30px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-parent-introduction .cmn-list {
    row-gap: 10px;
    font-size: 20px;
    border-width: 6px;
    border-radius: 40px;
    padding: 45px 60px;
    margin-top: 48px;
  }
}
.page-parent-introduction .cmn-list li {
  padding-left: 1.5em;
  position: relative;
}
.page-parent-introduction .cmn-list li::before {
  content: "";
  display: inline-block;
  width: 19px;
  aspect-ratio: 1.7320508076/2;
  background-color: #48b381;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  position: absolute;
  top: 8px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .page-parent-introduction .cmn-list li::before {
    width: 21px;
  }
}
.page-parent-introduction .cmn-gallery {
  display: grid;
  gap: 30px;
  margin-top: 50px;
  text-align: center;
}
@media screen and (min-width: 640px) {
  .page-parent-introduction .cmn-gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 960px) {
  .page-parent-introduction .cmn-gallery {
    display: flex;
    margin-top: 100px;
  }
}
.page-parent-introduction .cmn-gallery-img img {
  border-radius: 10px;
}
@media screen and (min-width: 960px) {
  .page-parent-introduction .cmn-gallery-img img {
    border-radius: 20px;
  }
}

/* ご利用案内 */
.page-guide .cmn-slug-icon {
  width: 99px;
  transform: translate(-31%, -50%);
}
@media screen and (min-width: 960px) {
  .page-guide .cmn-slug-icon {
    width: 198px;
  }
}

.page-parent-guide .cts-def {
  margin-top: 30px;
}
@media screen and (min-width: 960px) {
  .page-parent-guide .cts-def {
    margin-top: 40px;
  }
}
.page-parent-guide .cts-def:first-child {
  margin-top: 10px;
}
.page-parent-guide .cts-def dt, .page-parent-guide .cts-def dd {
  padding-inline: 25px;
}
@media screen and (min-width: 640px) {
  .page-parent-guide .cts-def dt, .page-parent-guide .cts-def dd {
    padding-inline: 60px;
  }
}
.page-parent-guide .cts-def dt {
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  border-top-right-radius: 25px;
  padding-block: 17px;
  line-height: 1.7142857143;
}
@media screen and (min-width: 960px) {
  .page-parent-guide .cts-def dt {
    font-size: 24px;
    border-top-right-radius: 50px;
    padding-block: 20px;
    line-height: 1.6666666667;
  }
}
.page-parent-guide .cts-def dd {
  display: grid;
  row-gap: 5px;
  background-image: linear-gradient(0deg, #f4f5bd 0%, #fffbd9 100%);
  font-size: 18px;
  border-bottom-left-radius: 25px;
  padding-block: 12.5px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-parent-guide .cts-def dd {
    font-size: 20px;
    border-bottom-left-radius: 50px;
    padding-block: 27.5px;
  }
}
.page-parent-guide .cts-row {
  display: grid;
  row-gap: 15px;
  padding-bottom: 12.5px;
}
@media screen and (min-width: 640px) {
  .page-parent-guide .cts-row {
    align-items: center;
    grid-template-columns: 1fr 200px;
    column-gap: 50px;
    padding-block: 12.5px;
  }
}
.page-parent-guide .cts-txt span {
  display: inline-block;
  font-size: 15px;
  line-height: 1.5;
}
@media screen and (min-width: 960px) {
  .page-parent-guide .cts-txt span {
    font-size: 16px;
  }
}
.page-parent-guide .cts-price {
  font-size: 30px;
  font-weight: 900;
  border-radius: 10px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .page-parent-guide .cts-price {
    font-size: 36px;
    border-radius: 20px;
    padding-block: 4px;
  }
}
.page-parent-guide .cts-price span {
  font-size: 0.8em;
}
.page-parent-guide .cts-color-g .cts-title {
  color: #48b381;
}
.page-parent-guide .cts-color-g .cts-title::before {
  background-color: #48b381;
}
.page-parent-guide .cts-color-g .cts-def dt {
  background-color: #48b381;
}
.page-parent-guide .cts-color-g .cts-price {
  color: #48b381;
  background-color: #d5f1e1;
}
.page-parent-guide .cts-color-p .cts-title {
  color: #f36f95;
}
.page-parent-guide .cts-color-p .cts-title::before {
  background-color: #f36f95;
}
.page-parent-guide .cts-color-p .cts-def dt {
  background-color: #f36f95;
}
.page-parent-guide .cts-color-p .cts-price {
  color: #f36f95;
  background-color: #faecf4;
}

/* ご利用の流れ */
.page-flow .cmn-title {
  text-align: center;
}
.page-flow .cts-section {
  padding-top: 40px;
  padding-bottom: 50px;
  margin-top: 40px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 640px) {
  .page-flow .cts-section {
    padding-left: 5.5555555556%;
  }
}
@media screen and (min-width: 960px) {
  .page-flow .cts-section {
    max-width: 1200px;
    padding-top: 60px;
    padding-bottom: 100px;
    padding-right: 0;
    margin: 110px auto 100px;
  }
}
.page-flow .cts-section::before {
  content: "";
  display: block;
  width: 80vw;
  height: 100%;
  background-image: linear-gradient(0deg, #fce386 0%, #f8f2be 60%);
  border-radius: 0 10px 10px 0;
  position: absolute;
  top: 0;
  left: -6.6666666667vw;
  z-index: -1;
}
@media screen and (min-width: 640px) {
  .page-flow .cts-section::before {
    width: min(60%, 450px);
    border-radius: 10px;
    left: -15px;
  }
}
@media screen and (min-width: 960px) {
  .page-flow .cts-section::before {
    width: 700px;
    border-radius: 20px;
    left: -30px;
  }
}
.page-flow .cts-row {
  display: grid;
  row-gap: 24px;
  padding-left: 28.5px;
  margin-top: 44px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-row {
    align-items: center;
    grid-template-columns: 0.4601769912fr 0.5398230088fr;
    padding: 0;
    margin-top: 100px;
  }
}
.page-flow .cts-row:first-of-type {
  margin-top: 30px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-row:first-of-type {
    margin-top: 50px;
  }
}
@media screen and (min-width: 960px) {
  .page-flow .cts-text {
    padding-left: 9.6153846154%;
    padding-right: 13.4615384615%;
  }
}
.page-flow .cts-title {
  display: grid;
  color: #48b381;
  row-gap: 14px;
  position: relative;
}
.page-flow .cts-title .en {
  font-size: 19px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-title .en {
    font-size: 34px;
    font-weight: 900;
  }
}
.page-flow .cts-title .ja {
  font-size: 18px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-title .ja {
    font-size: 28px;
    font-weight: bold;
  }
}
.page-flow .cts-title::before {
  content: "";
  display: inline-block;
  width: 17px;
  aspect-ratio: 1.7320508076/2;
  background-color: #48b381;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  position: absolute;
  top: 6px;
  left: -28.5px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-title::before {
    width: 31px;
    top: 10px;
    left: -50px;
  }
}
.page-flow .cts-txt {
  font-size: 16px;
  margin-top: 2em;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-txt {
    font-size: 20px;
  }
}
.page-flow .cmn-btn {
  margin-top: 20px;
}
@media screen and (min-width: 960px) {
  .page-flow .cmn-btn {
    margin-top: 30px;
  }
}
.page-flow .cmn-btn:first-of-type {
  margin-top: 32px;
}
.page-flow .cmn-btn:last-child {
  margin-bottom: 16px;
}
@media screen and (min-width: 960px) {
  .page-flow .cmn-btn:last-child {
    margin-bottom: 0;
  }
}
.page-flow .cts-img img {
  border-radius: 10px;
}
@media screen and (min-width: 960px) {
  .page-flow .cts-img img {
    border-radius: 20px;
  }
}

/* ご利用料金 */
.page-price .cts-title {
  font-size: 19px;
  font-weight: 900;
  padding-left: 1.5em;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-price .cts-title {
    font-size: 34px;
  }
}
.page-price .cts-title::before {
  content: "";
  display: inline-block;
  width: 17px;
  aspect-ratio: 1.7320508076/2;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  position: absolute;
  top: 6px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .page-price .cts-title::before {
    width: 31px;
    top: 8px;
  }
}

/* ご利用地域一覧 */
.page-area .cts-bg {
  max-width: 920px;
  margin-top: 70px;
  margin-inline: auto;
  padding-bottom: 300px;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-area .cts-bg {
    margin-top: 200px;
    padding-bottom: 275px;
  }
}
.page-area .cts-bg .cts-map {
  width: 480px;
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-175px);
  z-index: -1;
}
@media screen and (min-width: 960px) {
  .page-area .cts-bg .cts-map {
    width: 801px;
    transform: translateX(-220px);
  }
}
.page-area .cts-title {
  font-size: 21px;
  font-weight: bold;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-area .cts-title {
    font-size: 34px;
    line-height: 2.1176470588;
  }
}
.page-area .cts-title span {
  display: inline-block;
}
.page-area .cts-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 9px 20px;
  max-width: 300px;
  font-size: 18px;
  list-style: none;
  padding-left: 0;
  margin-top: 40px;
  margin-inline: auto;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-area .cts-list {
    row-gap: 11px;
    max-width: 420px;
    font-size: 20px;
    margin-top: 100px;
    margin-left: 0;
  }
}
.page-area .cts-list li {
  padding-left: 1.5em;
  position: relative;
}
.page-area .cts-list li::before {
  content: "";
  display: inline-block;
  width: 19px;
  aspect-ratio: 1.7320508076/2;
  background-color: #48b381;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  position: absolute;
  top: 8px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .page-area .cts-list li::before {
    width: 21px;
  }
}
.page-area .cts-list li:nth-of-type(even) {
  margin-top: -0.5em;
}

/* お問い合わせ・ご予約 */
.page-contact .cts-txt {
  display: grid;
  justify-content: center;
  font-size: 20px;
  font-weight: bold;
  margin-top: 50px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-contact .cts-txt {
    font-size: 24px;
    margin-top: 75px;
  }
}

/* よくある質問 */
.page-faq .cts-intro {
  font-size: 21px;
  font-weight: bold;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-intro {
    font-size: 28px;
  }
}
.page-faq .cts-def {
  margin-top: 45px;
}
.page-faq .cts-def:first-child {
  margin-top: 0;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def {
    margin-top: 60px;
  }
}
.page-faq .cts-def dt, .page-faq .cts-def dd {
  padding-left: 60px;
  padding-right: 25px;
  position: relative;
}
@media screen and (min-width: 640px) {
  .page-faq .cts-def dt, .page-faq .cts-def dd {
    padding-left: 90px;
    padding-right: 50px;
  }
}
.page-faq .cts-def dt::before, .page-faq .cts-def dd::before {
  font-size: 40px;
  font-weight: 900;
  line-height: 1;
  position: absolute;
  left: 30px;
  transform: translateX(-50%);
}
@media screen and (min-width: 640px) {
  .page-faq .cts-def dt::before, .page-faq .cts-def dd::before {
    left: 55px;
  }
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def dt::before, .page-faq .cts-def dd::before {
    font-size: 50px;
  }
}
.page-faq .cts-def dt {
  background-image: linear-gradient(0deg, #f5c3d7 0%, #faecf4 60%);
  font-size: 21px;
  font-weight: bold;
  border-top-right-radius: 25px;
  padding-block: 22px;
  line-height: 1.7142857143;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def dt {
    font-size: 24px;
    border-top-right-radius: 50px;
    padding-block: 40px;
    line-height: 1.6666666667;
  }
}
.page-faq .cts-def dt::before {
  content: "Q";
  top: 18px;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def dt::before {
    top: 32px;
  }
}
.page-faq .cts-def dd {
  background-image: linear-gradient(0deg, #f4f5bd 0%, #fffbd9 100%);
  font-size: 18px;
  border-bottom-left-radius: 25px;
  padding-block: 20.5px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def dd {
    font-size: 20px;
    border-bottom-left-radius: 50px;
    padding-block: 47.5px;
  }
}
.page-faq .cts-def dd::before {
  content: "A";
  top: 22px;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-def dd::before {
    top: 48px;
  }
}
.page-faq .cts-txt {
  display: grid;
  justify-content: center;
  font-size: 20px;
  font-weight: bold;
  margin-top: 60px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-faq .cts-txt {
    font-size: 24px;
    margin-top: 88px;
  }
}

.page-parent-recruitment .cmn-slug {
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 960px) {
  .page-parent-recruitment .cmn-slug {
    column-gap: 10px;
  }
}
.page-parent-recruitment .cmn-slug::before, .page-parent-recruitment .cmn-slug::after {
  content: "";
  display: block;
  width: 50.5px;
  aspect-ratio: 101/102;
  background-image: url(img/icon-gear.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
@media screen and (min-width: 960px) {
  .page-parent-recruitment .cmn-slug::before, .page-parent-recruitment .cmn-slug::after {
    width: 101px;
  }
}
.page-parent-recruitment .cmn-slug span {
  flex-shrink: 0;
}

/* 採用情報 */
.page-recruit .cmn-slug-icon {
  width: 104px;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 960px) {
  .page-recruit .cmn-slug-icon {
    width: 209px;
  }
}
.page-recruit .cts-intro {
  font-size: 16px;
  font-weight: bold;
  margin-top: 40px;
  text-align: center;
  text-wrap: balance;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-intro {
    font-size: 26px;
    margin-top: 68px;
  }
}
.page-recruit .cts-intro span {
  display: inline-block;
}
.page-recruit .cts-section {
  padding-block: 40px;
  margin-top: 40px;
  margin-bottom: 35px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 640px) {
  .page-recruit .cts-section {
    padding-left: 5.3571428571%;
  }
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-section {
    max-width: 1200px;
    padding-block: 60px;
    padding-left: 10.7142857143%;
    margin: 85px auto 75px;
  }
}
.page-recruit .cts-section::before {
  content: "";
  display: block;
  width: 80vw;
  height: 100%;
  background-image: linear-gradient(0deg, #fce386 0%, #f8f2be 60%);
  border-radius: 0 10px 10px 0;
  position: absolute;
  top: 0;
  left: -6.6666666667vw;
  z-index: -1;
}
@media screen and (min-width: 640px) {
  .page-recruit .cts-section::before {
    width: min(60%, 450px);
    border-radius: 10px;
    left: -15px;
  }
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-section::before {
    width: 700px;
    border-radius: 20px;
    left: -30px;
  }
}
.page-recruit .cts-section + .cmn-title {
  text-align: center;
}
.page-recruit .cts-row {
  display: grid;
  row-gap: 20px;
  padding-inline: min(2.6666666667vw, 30px);
  margin-top: 40px;
}
@media screen and (min-width: 640px) {
  .page-recruit .cts-row {
    align-items: center;
    grid-template-columns: 0.4134615385fr 0.5865384615fr;
    column-gap: 25px;
    padding: 0;
  }
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-row {
    margin-top: 60px;
  }
}
.page-recruit .cts-row:first-of-type {
  margin-top: 0;
}
.page-recruit .cts-ttl {
  font-size: 17px;
  font-weight: bold;
  line-height: 2.1176470588;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-ttl {
    font-size: 24px;
    line-height: 2;
  }
}
.page-recruit .cts-img img {
  border-radius: 10px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-img img {
    border-radius: 20px;
  }
}
.page-recruit .cts-def {
  margin-top: 30px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-def {
    margin-top: 40px;
  }
}
.page-recruit .cts-def:first-child {
  margin-top: 10px;
}
.page-recruit .cts-def dt, .page-recruit .cts-def dd {
  padding-inline: 25px;
}
@media screen and (min-width: 640px) {
  .page-recruit .cts-def dt, .page-recruit .cts-def dd {
    padding-inline: 60px;
  }
}
.page-recruit .cts-def dt {
  color: #fff;
  background-color: #48b381;
  font-size: 21px;
  font-weight: bold;
  border-top-right-radius: 25px;
  padding-block: 17px;
  line-height: 1.7142857143;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-def dt {
    font-size: 24px;
    border-top-right-radius: 50px;
    padding-block: 20px;
    line-height: 1.6666666667;
  }
}
.page-recruit .cts-def dd {
  display: grid;
  row-gap: 5px;
  background-image: linear-gradient(0deg, #f4f5bd 0%, #fffbd9 100%);
  font-size: 18px;
  border-bottom-left-radius: 25px;
  border-bottom-right-radius: 25px;
  padding-block: 12.5px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-def dd {
    font-size: 20px;
    border-bottom-left-radius: 50px;
    border-bottom-right-radius: 50px;
    padding-block: 27.5px;
  }
}
.page-recruit .cts-txt {
  margin-top: 16px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-txt {
    margin-top: 20px;
  }
}
.page-recruit .cts-txt:first-child {
  margin-top: 0;
}
.page-recruit .cts-list-hexa {
  display: grid;
  font-size: 18px;
  list-style: none;
  padding-left: 0;
  margin-top: 18px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-list-hexa {
    font-size: 20px;
  }
}
.page-recruit .cts-list-hexa:first-child {
  margin-top: 0;
}
.page-recruit .cts-list-hexa + .cts-list-hexa {
  padding-top: 18px;
  position: relative;
}
.page-recruit .cts-list-hexa + .cts-list-hexa::before {
  content: "";
  display: block;
  width: calc(100% + 20px);
  height: 1px;
  background-color: #48b381;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.page-recruit .cts-list-hexa li {
  padding-left: 1.5em;
  position: relative;
}
.page-recruit .cts-list-hexa li::before {
  content: "";
  display: inline-block;
  width: 19px;
  aspect-ratio: 1.7320508076/2;
  background-color: #48b381;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  position: absolute;
  top: 8px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-list-hexa li::before {
    width: 21px;
  }
}
.page-recruit .cts-list-hexa.has-num li {
  counter-increment: hexaNum;
  padding-left: 2em;
}
.page-recruit .cts-list-hexa.has-num li::before {
  content: counter(hexaNum);
  display: flex;
  justify-content: center;
  align-items: center;
  width: 29px;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  top: 2px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-list-hexa.has-num li::before {
    width: 31px;
    font-size: 22px;
  }
}
.page-recruit .cts-box {
  background-color: #d5f1e1;
  border-radius: 10px;
  padding: 17.5px 25px;
  margin-top: 16px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-box {
    border-radius: 20px;
    padding: 35px 50px;
    margin-top: 24px;
  }
}
.page-recruit .cts-box:last-child {
  margin-bottom: 12.5px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-box:last-child {
    margin-bottom: 22.5px;
  }
}
.page-recruit .cts-grid {
  display: grid;
  align-items: start;
  grid-template-columns: auto 1fr;
  column-gap: 10px;
  margin-top: 16px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-grid {
    margin-top: 20px;
  }
}
.page-recruit .cts-grid:first-child {
  margin-top: 0;
}
.page-recruit .cts-grid .numbers {
  display: flex;
  justify-content: flex-end;
  column-gap: 5px;
  margin-top: 3px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-grid .numbers {
    column-gap: 10px;
    margin-top: 0;
  }
}
.page-recruit .cts-grid .numbers .num {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 29px;
  aspect-ratio: 1.7320508076/2;
  color: #fff;
  background-color: #48b381;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%, 0 25%);
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  top: 2px;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-grid .numbers .num {
    width: 31px;
    font-size: 22px;
  }
}
.page-recruit .cts-summary {
  font-size: 21px;
  font-weight: bold;
  margin-top: 70px;
  text-align: center;
  line-height: 1.7142857143;
}
@media screen and (min-width: 960px) {
  .page-recruit .cts-summary {
    font-size: 28px;
    margin-top: 140px;
  }
}
.page-recruit .cts-summary span {
  display: inline-block;
}

/* フランチャイズ募集 */
.page-franchise .cmn-slug-icon {
  width: 65px;
  transform: translate(-50%, -50%);
}
@media screen and (min-width: 960px) {
  .page-franchise .cmn-slug-icon {
    width: 130px;
  }
}
.page-franchise .cmn-title {
  display: grid;
  justify-content: center;
  margin-top: 40px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cmn-title {
    margin-top: 52px;
  }
}
.page-franchise .cts-txt {
  font-size: 16px;
  margin-top: 4px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-txt {
    font-size: 26px;
    margin-top: 15px;
  }
}
.page-franchise .cts-list {
  display: grid;
  row-gap: 20px;
  max-width: 325px;
  margin: 35px auto 28px;
  position: relative;
}
@media screen and (min-width: 640px) {
  .page-franchise .cts-list {
    max-width: 780px;
    align-items: start;
    grid-template-areas: "a b" "c b";
    gap: 80px 30px;
    margin-top: 150px;
    margin-bottom: 56px;
  }
}
.page-franchise .cts-box {
  display: grid;
  justify-content: center;
  width: 250px;
  font-size: 18px;
  background-image: linear-gradient(0deg, #f4f5bd 0%, #fffbd9);
  border-radius: 25px 0 25px 25px;
  padding: 20px 25px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-box {
    font-size: 20px;
    border-radius: 50px 0 50px 50px;
    line-height: 2;
  }
}
.page-franchise .cts-box:nth-of-type(1) {
  width: 240px;
  margin-left: 25px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-box:nth-of-type(1) {
    grid-area: a;
    width: 300px;
    margin-left: 0;
  }
}
.page-franchise .cts-box:nth-of-type(2) {
  margin-left: -15px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-box:nth-of-type(2) {
    grid-area: b;
    width: 360px;
    padding-block: 40px;
    margin-top: 32px;
    margin-left: 0;
    margin-right: 15px;
  }
}
.page-franchise .cts-box:nth-of-type(3) {
  border-top-left-radius: 0px;
  border-top-right-radius: 25px;
  margin-left: 5px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-box:nth-of-type(3) {
    grid-area: c;
    width: 360px;
    border-top-right-radius: 50px;
    margin-left: 10px;
  }
}
.page-franchise .cts-img {
  width: 134px;
  position: absolute;
  left: 205px;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (min-width: 960px) {
  .page-franchise .cts-img {
    width: 172px;
    left: 50%;
    transform: translate(-70%, -65%);
  }
}
.page-franchise .cmn-frame {
  margin-top: 70px;
}
@media screen and (min-width: 960px) {
  .page-franchise .cmn-frame {
    margin-top: 105px;
  }
}
.page-franchise h3.cmn-title-sub {
  display: grid;
  justify-content: center;
}
.page-franchise p.cmn-title-sub {
  text-align: center;
}

/* フォーム */
.snow-monkey-form {
  max-width: 900px;
  margin-inline: auto;
}
.snow-monkey-form .smf-item {
  margin-top: 30px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-item {
    margin-top: 40px;
  }
}
.snow-monkey-form .smf-item-group {
  display: grid;
  align-items: start;
  row-gap: 20px;
}
@media screen and (min-width: 640px) {
  .snow-monkey-form .smf-item-group {
    grid-template-columns: 220px 1fr;
  }
}
.snow-monkey-form .smf-item__label {
  display: flex;
  align-items: center;
  column-gap: 20px;
  padding-inline: 7.5px;
  font-size: 20px;
  font-weight: bold;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-item__label {
    font-size: 24px;
    padding-inline: 15px;
  }
}
.snow-monkey-form .smf-item__label a {
  border-bottom: 1px solid #999;
}
.snow-monkey-form .smf-item-group .smf-item__col--controls .smf-item__label {
  font-size: 17px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-item-group .smf-item__col--controls .smf-item__label {
    font-size: 20px;
  }
}
.snow-monkey-form .smf-item-group .smf-item__col--controls .smf-item__label:not(:first-of-type) {
  margin-top: 20px;
}
.snow-monkey-form .smf-item-required .smf-item__label::after,
.snow-monkey-form .smf-item-group .smf-item__col--controls .smf-item__label:first-of-type:after {
  content: "必須";
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  aspect-ratio: 2;
  color: #fff;
  background-color: #f36f95;
  font-size: 14px;
  font-weight: bold;
  border-radius: 9999px;
  margin: 0;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-item-required .smf-item__label::after,
  .snow-monkey-form .smf-item-group .smf-item__col--controls .smf-item__label:first-of-type:after {
    width: 80px;
    font-size: 16px;
  }
}
.snow-monkey-form .smf-placeholder {
  margin-top: 10px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-placeholder {
    margin-top: 20px;
  }
}
.snow-monkey-form .smf-select-control {
  display: block;
  max-width: 200px;
  position: relative;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-select-control {
    max-width: 300px;
  }
}
.snow-monkey-form .smf-select-control::after {
  content: "";
  display: block;
  width: 18px;
  aspect-ratio: 1;
  border-bottom: 3px solid #333;
  border-right: 3px solid #333;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-75%) rotate(45deg) skew(3deg, 3deg);
  z-index: 1;
  pointer-events: none;
}
.snow-monkey-form .smf-text-control__control,
.snow-monkey-form .smf-textarea-control__control,
.snow-monkey-form .smf-select-control__control, .snow-monkey-form[data-screen=confirm] .smf-placeholder {
  width: 100%;
  background-color: #fffbd9;
  font-size: 16px;
  border: none;
  border-radius: 10px;
  padding: 14px 20px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-text-control__control,
  .snow-monkey-form .smf-textarea-control__control,
  .snow-monkey-form .smf-select-control__control, .snow-monkey-form[data-screen=confirm] .smf-placeholder {
    font-size: 18px;
    border-radius: 20px;
    padding: 22px 40px;
  }
}
.snow-monkey-form ::placeholder {
  color: #333;
}
.snow-monkey-form .smf-radio-buttons-control__control,
.snow-monkey-form .smf-checkboxes-control__control {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 40px;
  padding-inline: 7.5px;
  padding-bottom: 10px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-radio-buttons-control__control,
  .snow-monkey-form .smf-checkboxes-control__control {
    padding-inline: 15px;
  }
}
.snow-monkey-form .smf-radio-buttons-control__control .smf-label,
.snow-monkey-form .smf-checkboxes-control__control .smf-label {
  min-width: 110px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-radio-buttons-control__control .smf-label,
  .snow-monkey-form .smf-checkboxes-control__control .smf-label {
    min-width: 150px;
  }
}
.snow-monkey-form .smf-radio-button-control,
.snow-monkey-form .smf-checkbox-control {
  display: flex;
}
.snow-monkey-form .smf-radio-button-control__control,
.snow-monkey-form .smf-checkbox-control__control {
  width: 32px;
  height: auto;
  aspect-ratio: 1;
  background-color: #fffbd9;
  border: 2px solid #999;
  margin-top: 0;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-radio-button-control__control,
  .snow-monkey-form .smf-checkbox-control__control {
    width: 40px;
  }
}
.snow-monkey-form .smf-checkbox-control__control {
  border-radius: 5px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-checkbox-control__control {
    border-radius: 10px;
  }
}
.snow-monkey-form .smf-radio-button-control__label,
.snow-monkey-form .smf-checkbox-control__label {
  font-size: 16px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-radio-button-control__label,
  .snow-monkey-form .smf-checkbox-control__label {
    font-size: 20px;
  }
}
.snow-monkey-form .p-country-name {
  display: none;
}
.snow-monkey-form .smf-action {
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(auto-fit, 260px);
  gap: 20px;
  margin-top: 50px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-action {
    grid-template-columns: repeat(auto-fit, 340px);
    margin-top: 95px;
  }
}
.snow-monkey-form .smf-action .smf-button-control + .smf-button-control {
  margin-left: 0;
}
.snow-monkey-form .smf-action .smf-button-control__control {
  display: grid;
  align-items: center;
  grid-template-columns: auto 1fr auto;
  color: #fff;
  background: linear-gradient(180deg, #bbd9c7 0%, #3db07a 80%);
  font-size: 21px;
  font-weight: bold;
  border-radius: 9999px;
  padding: 9px 20px;
  margin-inline: auto;
  text-align: center;
  line-height: 2;
  width: 100%;
  border: none;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-action .smf-button-control__control {
    font-size: 26px;
    padding: 14px 30px;
  }
}
.snow-monkey-form .smf-action .smf-button-control__control:hover {
  background: linear-gradient(0deg, #bbd9c7 0%, #3db07a 80%);
  opacity: 1;
}
.snow-monkey-form .smf-action .smf-button-control__control::before {
  content: "";
  display: block;
  width: 11.25px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-action .smf-button-control__control::before {
    width: 12.5px;
  }
}
.snow-monkey-form .smf-action .smf-button-control__control::after {
  content: "";
  display: block;
  width: 45px;
  aspect-ratio: 9/5;
  background-image: url(img/btn-arrow.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 18px;
  background-color: #fff;
  border-radius: 9999px;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-action .smf-button-control__control::after {
    width: 50px;
    aspect-ratio: 5/3;
    background-size: 22px;
  }
}
.snow-monkey-form .smf-action .smf-button-control__control[data-action=back] {
  grid-template-columns: auto;
  background: linear-gradient(180deg, #ccc 0%, #999 80%);
}
.snow-monkey-form .smf-action .smf-button-control__control[data-action=back]:hover {
  background: linear-gradient(0deg, #ccc 0%, #999 80%);
}
.snow-monkey-form .smf-action .smf-button-control__control[data-action=back]::before, .snow-monkey-form .smf-action .smf-button-control__control[data-action=back]::after {
  content: none;
}
.snow-monkey-form .smf-action .smf-sending {
  display: none;
}
.snow-monkey-form .smf-confirm-txt {
  display: none;
  font-size: 18px;
  margin-top: 2em;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-confirm-txt {
    font-size: 20px;
  }
}
.snow-monkey-form .smf-confirm-txt:first-child {
  margin-top: 0;
}
.snow-monkey-form[data-screen=confirm] .smf-confirm-txt {
  display: grid;
  justify-content: center;
}
.snow-monkey-form .smf-complete-content p {
  font-size: 18px;
  margin-top: 2em;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .snow-monkey-form .smf-complete-content p {
    font-size: 20px;
  }
}
.snow-monkey-form .smf-complete-content p:first-child {
  margin-top: 0;
}

.reCAPTCHA,
.reCAPTCHA a {
  color: #999;
}

.reCAPTCHA {
  font-size: 12px;
  margin-top: 50px;
  text-align: center;
}

.grecaptcha-badge {
  visibility: hidden !important;
}

.page-privacy .cts-def {
  max-width: 900px;
  margin-top: 30px;
  margin-inline: auto;
  counter-increment: num;
}
.page-privacy .cts-def:first-of-type {
  margin-top: 0;
}
@media screen and (min-width: 960px) {
  .page-privacy .cts-def {
    margin-top: 40px;
  }
}
.page-privacy .cts-def dt, .page-privacy .cts-def dd {
  background-image: linear-gradient(0deg, #f4f5bd 0%, #fffbd9 100%);
  padding-left: 60px;
  padding-right: 25px;
}
@media screen and (min-width: 640px) {
  .page-privacy .cts-def dt, .page-privacy .cts-def dd {
    padding-left: 90px;
    padding-right: 50px;
  }
}
.page-privacy .cts-def dt {
  font-size: 21px;
  font-weight: bold;
  border-top-right-radius: 25px;
  padding-block: 19.5px;
  line-height: 1.7142857143;
  position: relative;
}
@media screen and (min-width: 960px) {
  .page-privacy .cts-def dt {
    font-size: 24px;
    border-top-right-radius: 50px;
    padding-block: 30px;
    line-height: 1.6666666667;
  }
}
.page-privacy .cts-def dt::before {
  content: counter(num);
  font-size: 40px;
  font-weight: 900;
  line-height: 1;
  position: absolute;
  top: 15px;
  left: 30px;
  transform: translateX(-50%);
}
@media screen and (min-width: 640px) {
  .page-privacy .cts-def dt::before {
    left: 55px;
  }
}
@media screen and (min-width: 960px) {
  .page-privacy .cts-def dt::before {
    top: 22px;
    font-size: 50px;
  }
}
.page-privacy .cts-def dd {
  font-size: 18px;
  border-bottom-left-radius: 25px;
  padding-block: 19.5px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .page-privacy .cts-def dd {
    font-size: 20px;
    border-bottom-left-radius: 50px;
    padding-block: 27.5px;
  }
}

.aside-contact {
  display: grid;
  justify-content: center;
  grid-template-columns: repeat(auto-fill, 300px);
  gap: 40px 20px;
  margin-top: 30px;
  padding-inline: 7.3333333333vw;
}
@media screen and (min-width: 640px) {
  .aside-contact {
    gap: 0;
    padding-inline: 0;
  }
}
@media screen and (min-width: 960px) {
  .aside-contact {
    grid-template-columns: repeat(3, 1fr);
    max-width: 1320px;
    margin-inline: auto;
  }
}

@media screen and (min-width: 640px) {
  .aside-contact-box {
    padding: 10px;
  }
}
@media screen and (min-width: 960px) {
  .aside-contact-box {
    border-radius: 20px;
    padding: 20px;
    transition: 0.3s;
  }
}
@media screen and (min-width: 960px) {
  .aside-contact-box.email:has(a:hover) {
    background-color: #b9d8c6;
  }
}
.aside-contact-box.email .aside-contact-bg {
  background-image: linear-gradient(180deg, #bbd9c7 0%, #3db07a 60%);
}
@media screen and (min-width: 640px) {
  .aside-contact-box.email .aside-contact-bg {
    background-image: linear-gradient(180deg, #bbd9c7 0%, #3db07a 62.2222222222%);
  }
}
.aside-contact-box.email .aside-contact-bg::before {
  background-image: url(img/icon-email.svg);
}
.aside-contact-box.email .aside-contact-ttl {
  font-size: 24px;
}
@media screen and (min-width: 960px) {
  .aside-contact-box.email .aside-contact-ttl {
    font-size: min(2.2857142857vw, 32px);
  }
}
.aside-contact-box.email .aside-contact-btn {
  background-color: #3db07a;
}
@media screen and (min-width: 960px) {
  .aside-contact-box.line:has(a:hover) {
    background-color: #bbd7b7;
  }
}
.aside-contact-box.line .aside-contact-bg {
  background-image: linear-gradient(180deg, #bbd7b7 0%, #42c041 60%);
}
@media screen and (min-width: 640px) {
  .aside-contact-box.line .aside-contact-bg {
    background-image: linear-gradient(180deg, #bbd7b7 0%, #42c041 62.2222222222%);
  }
}
.aside-contact-box.line .aside-contact-bg::before {
  background-image: url(img/icon-line.svg);
}
.aside-contact-box.line .aside-contact-ttl {
  font-size: 37px;
}
@media screen and (min-width: 960px) {
  .aside-contact-box.line .aside-contact-ttl {
    font-size: min(3.5714285714vw, 50px);
  }
}
.aside-contact-box.line .aside-contact-btn {
  background-color: #42c041;
}
@media screen and (min-width: 960px) {
  .aside-contact-box.tel:has(a:hover) {
    background-color: #efc2d3;
  }
}
.aside-contact-box.tel .aside-contact-bg {
  background-image: linear-gradient(180deg, #efc3d3 0%, #f36f95 60%);
  padding: 10% 5% 20%;
}
@media screen and (min-width: 640px) {
  .aside-contact-box.tel .aside-contact-bg {
    background-image: linear-gradient(180deg, #efc3d3 0%, #f36f95 62.2222222222%);
  }
}
.aside-contact-box.tel .aside-contact-bg::before {
  background-image: url(img/icon-tel.svg);
}
.aside-contact-box.tel .aside-contact-ttl {
  font-size: 21px;
}
@media screen and (min-width: 960px) {
  .aside-contact-box.tel .aside-contact-ttl {
    font-size: min(2vw, 28px);
  }
}
.aside-contact-box.tel .aside-contact-ttl .num {
  font-size: 1.7142857143em;
  font-weight: 900;
}
.aside-contact-box.tel .aside-contact-btn {
  background-color: #f36f95;
}

.aside-contact-link {
  position: relative;
  transition: none;
}
.aside-contact-link:hover {
  opacity: 1;
}

.aside-contact-bg {
  display: grid;
  justify-items: center;
  grid-template-rows: auto 1fr;
  aspect-ratio: 1.25;
  color: #fff;
  mask-image: url(img/mask-contact-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
  padding: 14% 5% 28%;
}
@media screen and (min-width: 640px) {
  .aside-contact-bg {
    aspect-ratio: 10/9;
    mask-image: url(img/mask-contact-pc.svg);
    padding: 15% 5% 20% !important;
  }
}
.aside-contact-bg::before {
  content: "";
  display: block;
  width: 56px;
  aspect-ratio: 28/25;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
@media screen and (min-width: 640px) {
  .aside-contact-bg::before {
    width: min(20.8333333333%, 75px);
    aspect-ratio: 25/21;
    background-position: center bottom;
  }
}

.aside-contact-ttl {
  display: grid;
  align-content: center;
  font-weight: bold;
  text-align: center;
  line-height: 1.35;
  letter-spacing: 0.04em;
}

.aside-contact-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 20%;
  aspect-ratio: 2;
  border-radius: 9999px;
  position: absolute;
  right: 17.5%;
  bottom: 12.5%;
  transform: translate(50%, 50%);
  transition: backgroud-color 0.3s;
}
@media screen and (min-width: 640px) {
  .aside-contact-btn {
    right: 17.5%;
    bottom: 11.1111111111%;
  }
}
.aside-contact-btn svg {
  width: 26%;
}
.aside-contact-btn path {
  transition: fill 0.3s;
}

.page-lower {
  display: grid;
  row-gap: 30px;
  padding-inline: 6.6666666667vw;
  margin-top: 65px;
}
@media screen and (min-width: 640px) {
  .page-lower {
    gap: 20px;
    padding-inline: 20px;
  }
}
@media screen and (min-width: 960px) {
  .page-lower {
    max-width: 1400px;
    margin-inline: auto;
    margin-top: 100px;
    padding-inline: 40px;
  }
}

@media screen and (min-width: 640px) {
  .page-lower-box {
    padding: 10px;
  }
}
@media screen and (min-width: 960px) {
  .page-lower-box {
    border-radius: 20px;
    padding: 20px;
    transition: 0.3s;
  }
}
@media screen and (min-width: 960px) {
  .page-lower-box:has(a:hover) {
    background-color: #f36f95;
  }
}

.page-lower-link {
  position: relative;
  transition: none;
}
.page-lower-link:hover {
  opacity: 1;
}
.page-lower-link:hover .page-lower-num {
  color: #fff;
}
.page-lower-link:hover .page-lower-btn {
  background-color: #fff;
}
.page-lower-link:hover .page-lower-btn path {
  fill: #f36f95;
}

.page-lower-bg {
  display: grid;
  grid-template-rows: 1fr auto;
  aspect-ratio: 650/783;
  background-image: linear-gradient(180deg, #faecf4 33.0501930502%, #f5c3d7 82.6254826255%);
  mask-image: url(img/mask-archive-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
  padding: 6.9230769231%;
  padding-bottom: 20%;
}
@media screen and (min-width: 640px) {
  .page-lower-bg {
    align-items: center;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 5.0847457627%;
    aspect-ratio: 64/23;
    mask-image: url(img/mask-archive-pc.svg);
    padding: 3.90625%;
  }
}

.page-lower-text {
  display: grid;
  align-content: center;
  row-gap: 4px;
}
@media screen and (min-width: 640px) {
  .page-lower-text {
    width: 100%;
    margin-bottom: 17%;
  }
}
@media screen and (min-width: 960px) {
  .page-lower-text {
    row-gap: 24px;
    padding-inline: 8.9285714286%;
  }
}

.page-lower-ttl {
  font-size: 21px;
  font-weight: bold;
  text-wrap: balance;
}
@media screen and (min-width: 960px) {
  .page-lower-ttl {
    font-size: min(2.4285714286vw, 34px);
    line-height: 1.5;
  }
}

.page-lower-txt {
  font-size: 17px;
}
@media screen and (min-width: 960px) {
  .page-lower-txt {
    font-size: 18px;
    line-height: 2;
  }
}

.page-lower-thumb {
  width: 100%;
  aspect-ratio: 14/9;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (min-width: 960px) {
  .page-lower-thumb {
    border-radius: 20px;
  }
}
.page-lower-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-lower-num {
  color: #f36f95;
  font-size: 24px;
  font-weight: 900;
  position: absolute;
  left: 6.1538461538%;
  bottom: 5.7471264368%;
  letter-spacing: 0.1em;
  transform: translate(-50%, 50%);
  transition: color 0.3s;
}
@media screen and (min-width: 640px) {
  .page-lower-num {
    left: 7.03125%;
    bottom: 9.7826086957%;
  }
}
@media screen and (min-width: 960px) {
  .page-lower-num {
    font-size: min(3.4285714286vw, 48px);
  }
}

.page-lower-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15.3846153846%;
  aspect-ratio: 2;
  background-color: #f36f95;
  border-radius: 9999px;
  position: absolute;
  left: 24.6153846154%;
  bottom: 5.7471264368%;
  transform: translate(-50%, 50%);
  transition: backgroud-color 0.3s;
}
@media screen and (min-width: 640px) {
  .page-lower-btn {
    width: 7.8125%;
    left: 15.625%;
    bottom: 9.7826086957%;
  }
}
.page-lower-btn svg {
  width: 26%;
}
.page-lower-btn path {
  transition: fill 0.3s;
}

.page-sibling {
  display: grid;
  row-gap: 25px;
  padding-inline: 6.6666666667vw;
  margin-top: 65px;
}
@media screen and (min-width: 640px) {
  .page-sibling {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding-inline: 20px;
  }
}
@media screen and (min-width: 960px) {
  .page-sibling {
    gap: 20px;
    max-width: 1400px;
    margin-inline: auto;
    margin-top: 110px;
    padding-inline: 40px;
  }
}

@media screen and (min-width: 640px) {
  .page-sibling-box {
    padding: 10px;
  }
}
@media screen and (min-width: 960px) {
  .page-sibling-box {
    border-radius: 20px;
    padding: 20px;
    transition: 0.3s;
  }
}
@media screen and (min-width: 960px) {
  .page-sibling-box:has(a:hover) {
    background-color: #f36f95;
  }
}

.page-sibling-link {
  position: relative;
  transition: none;
}
.page-sibling-link:hover {
  opacity: 1;
}
.page-sibling-link:hover .page-sibling-btn {
  background-color: #fff;
}
.page-sibling-link:hover .page-sibling-btn path {
  fill: #f36f95;
}

.page-sibling-bg {
  aspect-ratio: 65/53;
  background-image: linear-gradient(180deg, #faecf4 33.0501930502%, #f5c3d7 82.6254826255%);
  mask-image: url(img/mask-sibling-sp.svg);
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: 100%;
  padding: 6.9230769231%;
  padding-bottom: 0 !important;
}
@media screen and (min-width: 640px) {
  .page-sibling-bg {
    aspect-ratio: 305/259;
    mask-image: url(img/mask-sibling-pc.svg);
    padding: 8.1967213115%;
  }
}

.page-sibling-thumb {
  width: 100%;
  aspect-ratio: 14/9;
  border-radius: 10px;
  overflow: hidden;
}
@media screen and (min-width: 640px) {
  .page-sibling-thumb {
    aspect-ratio: 170/109;
  }
}
@media screen and (min-width: 960px) {
  .page-sibling-thumb {
    border-radius: 20px;
  }
}
.page-sibling-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.page-sibling-ttl {
  display: flex;
  align-items: center;
  width: 79.4642857143%;
  aspect-ratio: 89/25;
  font-size: 17px;
  font-weight: bold;
  padding-right: 8.0357142857%;
}
@media screen and (min-width: 640px) {
  .page-sibling-ttl {
    width: 72.5490196078%;
    aspect-ratio: 37/14;
    padding-right: 9.8039215686%;
    font-size: min(2vw, 28px);
  }
}

.page-sibling-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15.3846153846%;
  aspect-ratio: 2.5;
  background-color: #f36f95;
  border-radius: 9999px;
  position: absolute;
  right: 12.3076923077%;
  bottom: 8.4905660377%;
  transform: translate(50%, 50%);
  transition: backgroud-color 0.3s;
}
@media screen and (min-width: 640px) {
  .page-sibling-btn {
    width: 16.393442623%;
    right: 15.5737704918%;
    bottom: 8.6872586873%;
  }
}
.page-sibling-btn svg {
  width: 26%;
}
.page-sibling-btn path {
  transition: fill 0.3s;
}

.prevNextPost {
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.pgn {
  display: flex;
  justify-content: center;
}
.pgn .current,
.pgn a {
  width: 36px;
  aspect-ratio: 1;
  flex-shrink: 0;
  color: #fff;
  background-color: #333;
  text-align: center;
  margin: 0 5px;
  padding-top: 10px;
}
.pgn .current,
.pgn a:hover {
  background-color: #999;
}
.pgn a {
  text-decoration: none;
}
.pgn .next,
.pgn .prev {
  background-image: url(img/arrow-right-white.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 5px auto;
}
.pgn .prev,
.pgn .first {
  transform: rotate(180deg);
}
.pgn .last,
.pgn .first {
  background-image: url(img/arrow-right-white.svg), url(img/arrow-right-white.svg);
  background-repeat: no-repeat, no-repeat;
  background-position: left 13px center, left 20px center;
  background-size: 5px auto, 5px auto;
}

@media screen and (min-width: 640px) {
  .pgn .current,
  .pgn a {
    width: 48px;
    padding-top: 15px;
    font-size: 16px;
  }
  .pgn .next,
  .pgn .prev {
    background-size: 6px auto;
  }
  .pgn .prev,
  .pgn .first {
    transform: rotate(180deg);
  }
  .pgn .last,
  .pgn .first {
    background-position: left 18px center, left 27px center;
    background-size: 6px auto, 6px auto;
  }
}
.footer {
  padding-inline: 2.6666666667vw;
  margin-top: 80px;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .footer {
    padding-inline: 40px;
    margin-top: 98px;
  }
}

@media screen and (min-width: 960px) {
  .footer-frame {
    max-width: 1100px;
    margin-inline: auto;
  }
}

.footer-row {
  display: grid;
  row-gap: 50px;
}
@media screen and (min-width: 960px) {
  .footer-row {
    justify-content: space-between;
    grid-template-columns: 400px minmax(auto, 600px);
    column-gap: 50px;
  }
}

.footer-info {
  display: grid;
  justify-items: center;
}

.footer-logo {
  width: 240px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .footer-logo {
    width: 320px;
  }
}

.footer-title {
  color: #48b381;
  font-size: 30px;
  font-weight: bold;
  margin-top: 15px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .footer-title {
    font-size: 40px;
  }
}

.footer-ttl {
  color: #fff;
  background-color: #48b381;
  width: 100%;
  max-width: 295px;
  font-size: 18px;
  font-weight: 500;
  border-radius: 15px;
  padding: 2px;
  margin-top: 8px;
  text-align: center;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 960px) {
  .footer-ttl {
    max-width: 390px;
    font-size: 24px;
    border-radius: 20px;
    margin-top: 12px;
  }
}

.footer-addr {
  color: #48b381;
  font-size: 15px;
  font-style: normal;
  font-weight: 500;
  margin-top: 6px;
  text-align: center;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .footer-addr {
    font-size: 20px;
    margin-top: 10px;
  }
}

.footer-contact {
  display: grid;
  row-gap: 20px;
}
@media screen and (min-width: 960px) {
  .footer-contact {
    row-gap: 30px;
  }
}

.footer-btn {
  display: grid;
  align-items: center;
  grid-template-columns: 37.5px 1fr;
  min-height: 80px;
  color: #fff;
  font-size: 21px;
  font-weight: bold;
  border-radius: 10px;
  padding: 10px 25px;
  line-height: 1.2;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .footer-btn {
    grid-template-columns: 50px 1fr;
    min-height: 100px;
    font-size: 28px;
    border-radius: 20px;
    padding-inline: 60px;
  }
}
.footer-btn::before {
  content: "";
  display: inline-block;
  width: 37.5px;
  height: 34px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-right: 8px;
}
@media screen and (min-width: 960px) {
  .footer-btn::before {
    width: 50px;
    height: 45px;
  }
}
.footer-btn.email {
  background-image: linear-gradient(0deg, #3db07a 20%, #bbd9c7 100%);
}
.footer-btn.email:hover {
  background-image: linear-gradient(180deg, #3db07a 20%, #bbd9c7 100%);
  opacity: 1;
}
.footer-btn.email::before {
  background-image: url(img/icon-email.svg);
}
.footer-btn.line {
  background-image: linear-gradient(0deg, #42c041 20%, #bbd7b7 100%);
  font-size: 37.5px;
}
@media screen and (min-width: 960px) {
  .footer-btn.line {
    font-size: 50px;
  }
}
.footer-btn.line:hover {
  background-image: linear-gradient(180deg, #42c041 20%, #bbd7b7 100%);
  opacity: 1;
}
.footer-btn.line::before {
  background-image: url(img/icon-line.svg);
}
.footer-btn.tel {
  background-image: linear-gradient(0deg, #f36f95 20%, #efc3d3 100%);
}
.footer-btn.tel:hover {
  background-image: linear-gradient(180deg, #f36f95 20%, #efc3d3 100%);
  opacity: 1;
}
.footer-btn.tel::before {
  background-image: url(img/icon-tel.svg);
}
.footer-btn.tel .text {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 10px;
}
@media screen and (min-width: 960px) {
  .footer-btn.tel .text {
    column-gap: 20px;
  }
}
.footer-btn.tel .num {
  font-size: 28.5px;
}
@media screen and (min-width: 960px) {
  .footer-btn.tel .num {
    font-size: 38px;
  }
}

.footer-menu {
  display: grid;
  row-gap: 34px;
  padding-inline: 10px;
  margin-top: 62px;
}
@media screen and (min-width: 640px) {
  .footer-menu {
    justify-content: space-between;
    grid-template-columns: repeat(2, auto);
  }
}
@media screen and (min-width: 960px) {
  .footer-menu {
    grid-template-columns: repeat(3, auto);
    gap: 64px 32px;
    margin-top: 112px;
  }
}

.footer-menu-name {
  font-size: 26px;
  font-weight: bold;
}
.footer-menu-name + .footer-menu-name {
  margin-top: 30px;
}

.footer-menu-list {
  display: grid;
  row-gap: 7px;
  font-size: 17px;
  list-style: none;
  padding-left: 0;
  margin-top: 15px;
  line-height: 2;
}
@media screen and (min-width: 960px) {
  .footer-menu-list {
    row-gap: 0;
    font-size: 18px;
    margin-top: 12px;
  }
}
.footer-menu-list li {
  padding-left: 14px;
  position: relative;
}
.footer-menu-list li a::before {
  content: "";
  display: inline-block;
  width: 8px;
  aspect-ratio: 1;
  background-color: #3db07a;
  border-radius: 50%;
  position: absolute;
  top: 14px;
  left: 0;
}
@media screen and (min-width: 960px) {
  .footer-menu-list li a::before {
    top: 15px;
  }
}

.footer-other {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid #333;
  padding-block: 25px;
  margin-top: 44px;
}
@media screen and (min-width: 960px) {
  .footer-other {
    max-width: 1320px;
    margin-inline: auto;
    padding: 28px 20px;
  }
}

.footer-other-link {
  font-size: 15px;
  font-weight: 500;
}
@media screen and (min-width: 960px) {
  .footer-other-link {
    font-size: 16px;
  }
}

.footer-copy {
  font-size: 10px;
  font-weight: 500;
}
@media screen and (min-width: 960px) {
  .footer-copy {
    font-size: 14px;
  }
}/*# sourceMappingURL=style.css.map */