@charset "UTF-8";
/* フェードアップアニメーション */
.fade-up.is-hidden {
  opacity: 0;
  transform: translateY(30px);
}

.fade-up.is-show {
  opacity: 1;
  transform: translateY(0);
}

.fade-up {
  transition: opacity 0.9s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.9s cubic-bezier(0.165, 0.84, 0.44, 1);
  transition-delay: var(--delay-sp, 0s);
}

@media (min-width: 780) {
  .fade-up {
    transition-delay: var(--delay-pc, 0s);
  }
}
/* 　全体で共通　　*/
.only-sp {
  display: block;
}

.only-pc {
  display: none;
}

.uc {
  pointer-events: none;
  opacity: 0.4;
}

@media (min-width: 781px) {
  .only-sp {
    display: none;
  }
  .only-pc {
    display: block;
  }
}
.texture {
  background-image: url("../images/common/texture.png");
  background-repeat: repeat;
  background-position: left top;
  background-size: 200px;
}

/* deco */
.highlight {
  background: linear-gradient(transparent 50%, #fff6b4 50%);
}

.deco {
  position: absolute;
}

img,
source {
  width: 100%;
  height: 100%;
}

/* 　　 SP版　　　　*/
body {
  line-height: 1;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 3.59vw;
  color: #666;
  font-weight: 300;
  background-color: #f9f6ef;
}

@media (max-width: 780px) {
  .site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: #f9f6ef;
  }
  .site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 14.103vw;
    margin: 0 auto;
    padding: 4.487vw 3.846vw;
  }
  .site-header__logo {
    display: inline-block;
    z-index: 109;
  }
  .site-header__logo img {
    display: block;
    width: 30.769vw;
    height: auto;
  }
  .site-header__menu-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    z-index: 1000;
    width: 7.179vw;
    height: 7.179vw;
    padding: 0;
    border: 0;
    background: transparent;
    color: #666;
    cursor: pointer;
  }
  .site-header__menu-btn span, .site-header__menu-btn::before, .site-header__menu-btn::after {
    content: "";
    display: block;
    width: 5.385vw;
    height: 0.256vw;
    background-color: currentColor;
    border-radius: 128.077vw;
    transition: transform 0.3s ease, opacity 0.3s ease;
    position: absolute;
    top: 50%;
    left: 50%;
  }
  .site-header__menu-btn span {
    transform: translate(-50%, -50%);
  }
  .site-header__menu-btn::before {
    transform: translate(-50%, calc(-50% - 1.538vw));
  }
  .site-header__menu-btn::after {
    transform: translate(-50%, calc(-50% + 1.538vw));
  }
  .site-header__right {
    pointer-events: none;
    opacity: 0;
    position: fixed;
    z-index: 110;
    inset: 0;
    overflow-y: scroll;
    width: 100%;
    transition: opacity 0.3s ease;
  }
  .site-header__right::before {
    content: "";
    position: absolute;
    inset: 0;
    display: block;
    background-color: rgba(0, 0, 0, 0.3);
    z-index: -1;
  }
  .sp-nav__top-bg {
    padding: 4.487vw 3.846vw 7.692vw;
    background-color: #f9f6ef;
  }
  .site-header__nav-logo {
    width: 30.769vw;
    height: auto;
  }
  .site-header__nav {
    margin: 10.256vw 0 0 10.256vw;
  }
  .site-header__nav-list {
    display: grid;
    gap: 5.897vw;
  }
  .site-header__nav-list > li > a, .site-header__nav-list > li > span {
    display: inline-flex;
    align-items: center;
    gap: 3.846vw;
    color: #666;
    font-size: 4.615vw;
    font-weight: 500;
  }
  .site-header__nav-list > li > a::before, .site-header__nav-list > li > span::before {
    content: "";
    width: 0;
    height: 0;
    border-top: 0.897vw solid transparent;
    border-bottom: 0.897vw solid transparent;
    border-left: 1.41vw solid #72a230;
    flex-shrink: 0;
  }
  .site-header__nav-item--has-child > span {
    margin-bottom: 5.128vw;
  }
  .site-header__sub-nav {
    display: grid;
    gap: 3.205vw;
    padding-left: 4.487vw;
  }
  .site-header__sub-nav a {
    display: inline-flex;
    align-items: center;
    gap: 3.205vw;
    color: #666;
    font-size: 3.59vw;
    font-weight: 300;
  }
  .site-header__sub-nav a::before {
    content: "";
    width: 1.282vw;
    height: 0.256vw;
    background-color: #72a230;
    flex-shrink: 0;
  }
  .sp-nav__btns-bg {
    background-color: #efeadc;
    padding: 7.692vw 0;
  }
  .site-header__right .site-btn__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.795vw;
  }
  .site-header__right .site-btn__actions .site-btn__item {
    width: 35.897vw;
    padding: 2.179vw 0;
    font-size: 3.718vw;
    font-weight: 700;
  }
  .site-header__right .site-btn__actions .site-btn__item::before {
    margin-right: 1.923vw;
  }
  .site-header__right .site-btn__actions .site-btn__item--outline {
    color: #72a230;
    background-color: #fff;
    border-color: #fff;
  }
  .site-header__right .site-btn__actions .site-btn__item--outline::before {
    background-color: #72a230;
  }
  .site-header__sns {
    margin-top: 5.128vw;
    display: flex;
    justify-content: center;
    gap: 3.59vw;
  }
  .site-header__sns a {
    display: block;
    width: 7.692vw;
    height: 7.692vw;
  }
  .site-header.is-menu-open .site-header__menu-btn span {
    opacity: 0;
  }
  .site-header.is-menu-open .site-header__menu-btn::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }
  .site-header.is-menu-open .site-header__menu-btn::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  .site-header.is-menu-open .site-header__right {
    pointer-events: auto;
    opacity: 1;
  }
  body.is-menu-open {
    overflow: hidden;
  }
  .site-btn__item {
    width: 50%;
    min-height: 7.692vw;
    border-width: 0.128vw;
    border-radius: 128.077vw;
    padding: 2.179vw 0;
    font-size: 2.308vw;
    line-height: 1.2;
  }
  .site-btn__item::before {
    width: 1.282vw;
    height: 1.282vw;
    margin: 0.256vw 1.026vw 0 0;
  }
  /* footer */
  .site-footer__main {
    background-color: #edefe6;
    padding: 10.256vw 8.333vw;
  }
  .site-footer__logo {
    margin: 0 auto;
    width: 51.282vw;
    height: auto;
  }
  .site-footer__nav {
    margin-top: 10.256vw;
    display: grid;
    grid-template-columns: 32.051vw 1fr;
  }
  .site-footer__links {
    font-size: 3.077vw;
    font-weight: 500;
    display: grid;
    gap: 3.846vw;
  }
  .site-footer__links:has(.site-footer__links--child) {
    gap: 2.564vw;
  }
  .site-footer__links--child {
    display: grid;
    gap: 3.205vw;
  }
  .site-footer__links--child li {
    font-size: 3.077vw;
    font-weight: 300;
  }
  .site-footer__links--child li a {
    display: inline-flex;
    align-items: center;
    gap: 3.205vw;
    color: #666;
  }
  .site-footer__links--child li a::before {
    content: "";
    width: 1.282vw;
    height: 0.256vw;
    background-color: #72a230;
    flex-shrink: 0;
  }
  .site-footer__sns {
    margin-top: 7.692vw;
    grid-column: 1/-1;
    display: flex;
    gap: 3.846vw;
    justify-content: center;
    align-items: center;
  }
  .site-footer__sns li {
    width: 7.692vw;
    height: 7.692vw;
  }
  .site-footer__col--right {
    margin-top: 5.769vw;
    grid-column: 1/-1;
  }
  .site-footer__copyright {
    background-color: #4d5a3c;
    color: #fff;
    font-size: 2.308vw;
    text-align: center;
    padding: 3.462vw;
  }
}
/* bottom-cv */
.bottom-cv {
  padding: 16.667vw 0 15.385vw;
}

.bottom-cv__inner {
  padding: 0 8.333vw;
  display: flex;
  flex-direction: column;
  gap: 7.692vw;
}

.bottom-cv__contact,
.bottom-cv__member {
  border-radius: 3.846vw;
  overflow: hidden;
  height: 57.692vw;
  padding: 7.692vw 0;
  text-align: center;
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.bottom-cv__contact p,
.bottom-cv__member p {
  color: #fff;
  font-size: 4.103vw;
  line-height: 2;
}
.bottom-cv__contact .site-btn__actions,
.bottom-cv__member .site-btn__actions {
  margin-top: 5.769vw;
  justify-content: center;
}
.bottom-cv__contact .site-btn__actions .site-btn__item,
.bottom-cv__member .site-btn__actions .site-btn__item {
  background-color: #fff;
  color: #72a230;
  border-color: #fff;
  padding: 2.179vw 0;
  width: 50vw;
  font-size: 4.103vw;
}
.bottom-cv__contact .site-btn__actions .site-btn__item::before,
.bottom-cv__member .site-btn__actions .site-btn__item::before {
  background-color: #72a230;
  width: 2.179vw;
  height: 2.179vw;
  margin-right: 2.564vw;
}

.bottom-cv__contact {
  background-image: url(../images/common/bottom_cv_contact_bg.png);
}

.bottom-cv__member {
  background-image: url(../images/common/bottom_cv_member_bg.png);
}

/* text */
.site-title__h2 {
  text-align: center;
  letter-spacing: 0.8vw;
  display: flex;
  flex-direction: column;
  gap: 1.923vw;
  justify-content: center;
  align-items: center;
}
.site-title__h2 span {
  font-size: 4.103vw;
  color: #854023;
}
.site-title__h2 p {
  font-size: 13.333vw;
  font-family: "Outfit", sans-serif;
  background: linear-gradient(110deg, #fbde00 0%, #ed6c00 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
}

.link-text {
  text-decoration: underline;
}
.link-text:has(:hover) {
  text-decoration: none;
}

/* btn */
.site-btn__actions {
  display: flex;
  align-items: center;
  margin-left: auto;
  gap: 1.282vw;
}
.site-btn__actions .site-btn__item--outline {
  display: inline-flex;
  color: #72a230;
  background-color: transparent;
}
.site-btn__actions .site-btn__item--outline::before {
  background-color: #72a230;
}

.site-btn__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 4.872vw;
  padding: 0.769vw 0;
  width: 19.615vw;
  border: 0.128vw solid #72a230;
  color: #fff;
  background-color: #72a230;
  border-radius: 128.077vw;
  font-size: 2.051vw;
  font-weight: 700;
  transition: opacity 0.3s ease;
}
.site-btn__item::before {
  content: "";
  display: block;
  clip-path: polygon(100% 50%, 20% 0, 20% 100%);
  background-color: #fff;
  width: 2.179vw;
  height: 2.179vw;
  margin: 0.256vw 0.641vw 0 0;
}
@media (hover: hover) {
  .site-btn__item:hover {
    opacity: 0.75;
  }
}

.page__top-btn-cont {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5.128vw;
}
.page__top-btn-cont .page__top-btn-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: -moz-fit-content;
  width: fit-content;
  padding: 1.923vw 7.051vw;
  border: 0.128vw solid #854023;
  color: #fff;
  background-color: #854023;
  border-radius: 128.077vw;
  font-size: 3.59vw;
  font-weight: 600;
  transition: opacity 0.3s ease;
}
.page__top-btn-cont .page__top-btn-item::before {
  content: "";
  display: block;
  clip-path: polygon(50% 100%, 0 20%, 100% 20%);
  background-color: #fff;
  width: 1.538vw;
  height: 1.538vw;
  margin: 0.256vw 1.923vw 0 0;
}
.page__top-btn-cont .page__top-btn-item.yoyaku::before {
  clip-path: none;
  background-color: transparent;
  background-image: url("../images/common/link_icon.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 2.821vw;
  width: 2.821vw;
  height: 2.821vw;
  margin: 0.256vw 1.923vw 0 0;
}
@media (hover: hover) {
  .page__top-btn-cont .page__top-btn-item:hover {
    opacity: 0.75;
  }
}

/* list */
.page__dot-list,
.page__line-list {
  margin-top: 3.846vw;
  padding-left: 1.923vw;
  line-height: 2;
}
.page__dot-list > li,
.page__line-list > li {
  position: relative;
  padding-left: 3.846vw;
  margin-top: 1.923vw;
}

.page__dot-list > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 2.949vw;
  width: 1.795vw;
  height: 1.795vw;
  border-radius: 128.077vw;
  background-color: #72a230;
}

.page__line-list > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 3.462vw;
  width: 1.538vw;
  height: 0.385vw;
  background-color: #72a230;
}

/* 　  PC版　　　　*/
@media (min-width: 781px) {
  body {
    font-size: 1.111vw;
  }
  /* header */
  .site-header__inner {
    background-color: #f9f6ef;
    display: flex;
    justify-content: space-between;
    height: 7.639vw;
    align-items: center;
    max-width: 100vw;
    min-height: 5.694vw;
    padding: 0.903vw 2.083vw 0;
  }
  .site-header__logo img {
    width: 13.194vw;
  }
  .site-header__right {
    display: flex;
    font-family: "Zen Maru Gothic", sans-serif;
    align-items: center;
    gap: 2.083vw;
  }
  .sp-nav__top-bg {
    background-image: none;
  }
  .site-header__menu-btn {
    visibility: hidden;
  }
  .site-header__nav-list {
    display: flex;
    align-items: center;
    gap: 2.083vw;
    position: relative;
  }
  .site-header__nav-list > li > a, .site-header__nav-list > li > span {
    color: #666;
    font-size: 1.111vw;
    font-weight: 500;
    white-space: nowrap;
    transition: opacity 0.3s ease;
  }
  .site-header__nav-list > li > a:hover, .site-header__nav-list > li > span:hover {
    opacity: 0.7;
  }
  .site-header__nav-item {
    position: relative;
  }
  .site-header__nav-item--has-child > span {
    line-height: 4;
  }
  .site-header__sub-nav {
    position: absolute;
    top: calc(100% + 0.833vw);
    left: 0;
    min-width: 19.444vw;
    padding: 0.694vw 0;
    border-radius: 0.556vw;
    background-color: #fff;
    box-shadow: 0 0.556vw 1.667vw rgba(0, 0, 0, 0.12);
    z-index: 20;
    opacity: 0;
    visibility: hidden;
    transform: translateY(0.556vw);
    pointer-events: none;
    transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
  }
  .site-header__sub-nav li {
    margin: 0;
  }
  .site-header__sub-nav a {
    display: block;
    padding: 0.694vw 1.111vw;
    font-size: 0.972vw;
    font-weight: 500;
    white-space: nowrap;
  }
  .site-header__sub-nav a:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0.04);
  }
}
@media (min-width: 781px) and (hover: hover) {
  .site-header__nav-item--has-child:hover > .site-header__sub-nav {
    opacity: 1;
    visibility: visible;
    transform: translateY(-10%);
    pointer-events: auto;
  }
}
@media (min-width: 781px) {
  .site-header__nav-item--has-child:focus-within > .site-header__sub-nav {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }
  .sp-nav__btns-bg {
    display: contents;
  }
  .site-header__sns {
    visibility: visible;
    opacity: 1;
    display: flex;
    align-items: center;
    gap: 1.389vw;
  }
  .site-header__sns a {
    display: block;
    width: 2.083vw;
    height: 2.083vw;
  }
}
@media (min-width: 781px) {
  /* footer */
  .site-footer {
    color: #666;
  }
  .site-footer__main {
    background-color: #edefe6;
  }
  .site-footer__inner {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    padding: 4.861vw 8.333vw;
  }
  .site-footer__logo img {
    display: block;
    width: 16.667vw;
    height: auto;
  }
  .site-footer__nav {
    display: flex;
    gap: 5.556vw;
  }
  .site-footer__links {
    display: grid;
    gap: 0.833vw;
  }
  .site-footer__links a,
  .site-footer__links span {
    color: #666;
    font-size: 0.972vw;
    font-weight: 600;
    transition: 0.3s ease;
  }
  .site-footer__links a:hover {
    opacity: 0.7;
  }
  .site-footer__links:has(.site-footer__links--child) {
    gap: 0.833vw;
  }
  .site-footer__links--child a,
  .site-footer__links--child span {
    font-size: 0.972vw;
    font-weight: 300;
    position: relative;
    padding-left: 1.181vw;
  }
  .site-footer__links--child a::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: 0.347vw;
    height: 0.069vw;
    background-color: #72a230;
    transform: translateY(-50%);
  }
  .site-footer__col--right {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: space-between;
  }
  .site-footer__sns {
    display: flex;
    align-items: center;
    gap: 1.042vw;
    margin-top: 2.778vw;
  }
  .site-footer__sns img {
    display: block;
    width: 2.083vw;
    height: 2.083vw;
  }
  .site-footer__copyright {
    display: grid;
    place-items: center;
    height: 3.472vw;
    background-color: #4d5a3c;
    color: #fff;
  }
  .site-footer__copyright small {
    font-family: "Outfit", sans-serif;
    font-size: 0.833vw;
    font-weight: 300;
  }
  /* bottom-cv */
  .bottom-cv {
    padding: 8.333vw 0;
  }
  .bottom-cv__inner {
    padding: 0;
    flex-direction: row;
    gap: 0;
    /* justify-content: space-between; */
    justify-content: center;
    max-width: 83.333vw;
    margin: 0 auto;
  }
  .bottom-cv__contact,
  .bottom-cv__member {
    border-radius: 1.111vw;
    height: 21.528vw;
    width: 40.278vw;
    padding: 4.861vw 0;
  }
  .bottom-cv__contact p,
  .bottom-cv__member p {
    line-height: 2;
    font-size: 1.25vw;
  }
  .bottom-cv__contact .site-btn__actions,
  .bottom-cv__member .site-btn__actions {
    margin-top: 2.778vw;
  }
  .bottom-cv__contact .site-btn__actions .site-btn__item,
  .bottom-cv__member .site-btn__actions .site-btn__item {
    padding: 0.833vw 0;
    width: 18.264vw;
    font-size: 1.458vw;
  }
  .bottom-cv__contact .site-btn__actions .site-btn__item::before,
  .bottom-cv__member .site-btn__actions .site-btn__item::before {
    background-color: #72a230;
    margin-right: 1.042vw;
    width: 0.833vw;
    height: 0.833vw;
  }
  .bottom-cv__contact {
    background-image: url(../images/common/bottom_cv_contact_bg@pc.png);
  }
  .bottom-cv__member {
    background-image: url(../images/common/bottom_cv_member_bg@pc.png);
  }
  /* text */
  .site-title__h2 {
    gap: 1.389vw;
    letter-spacing: 0.5vw;
  }
  .site-title__h2 span {
    font-size: 1.389vw;
    color: #854023;
    letter-spacing: 0.2vw;
  }
  .site-title__h2 p {
    font-size: 4.514vw;
  }
  /* btn */
  .site-btn__actions {
    visibility: visible;
    opacity: 1;
    display: flex;
    align-items: center;
    margin-left: auto;
    gap: 0.694vw;
  }
  .site-btn__actions .site-btn__item--outline {
    display: inline-flex;
    color: #72a230;
    background-color: transparent;
  }
  .site-btn__actions .site-btn__item--outline::before {
    background-color: #72a230;
  }
  .site-btn__item {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.639vw;
    padding: 0.417vw 0;
    width: 10.625vw;
    border: 0.069vw solid #72a230;
    color: #fff;
    background-color: #72a230;
    border-radius: 69.375vw;
    font-size: 1.111vw;
    font-weight: 700;
    transition: opacity 0.3s ease;
  }
  .site-btn__item::before {
    content: "";
    display: block;
    clip-path: polygon(100% 50%, 20% 0, 20% 100%);
    background-color: #fff;
    width: 0.556vw;
    height: 0.556vw;
    margin: 0.139vw 0.347vw 0 0;
  }
  .site-btn__item:hover {
    opacity: 0.75;
  }
  .page__top-btn-cont {
    flex-direction: row;
    justify-content: center;
    gap: 2.778vw;
  }
  .page__top-btn-cont .page__top-btn-item {
    padding: 0.833vw 2.917vw;
    border: 0.069vw solid #854023;
    border-radius: 69.375vw;
    font-size: 1.25vw;
  }
  .page__top-btn-cont .page__top-btn-item::before {
    width: 0.694vw;
    height: 0.694vw;
    margin: 0.139vw 1.042vw 0 0;
  }
  .page__top-btn-cont .page__top-btn-item.yoyaku::before {
    background-size: 0.833vw;
    width: 0.833vw;
    height: 0.833vw;
    margin: 0.139vw 0.694vw 0 0;
  }
  /* list */
  .page__dot-list,
  .page__line-list {
    margin-top: 2.083vw;
    padding-left: 1.389vw;
    line-height: 2;
  }
  .page__dot-list > li,
  .page__line-list > li {
    position: relative;
    padding-left: 1.389vw;
    margin-top: 0.694vw;
  }
  .page__dot-list > li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.833vw;
    width: 0.625vw;
    height: 0.625vw;
    border-radius: 69.375vw;
    background-color: #72a230;
  }
  .page__line-list {
    margin-top: 0;
    padding-left: 0;
  }
  .page__line-list > li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 1.181vw;
    width: 0.556vw;
    height: 0.139vw;
    background-color: #72a230;
  }
}/*# sourceMappingURL=common.css.map */