@charset "UTF-8";
/*=========================*/
/*==　　　　変数　　　　　 ==*/
/*=========================*/
:root {
  --color_bg01:#fbfbfb;
  --color_mono01:#000;
  --color_mono02:#fff;
  --color_mono03:#A8A8A8;
  --color_mono04:#F0F0F0;
  --color_mono05:#5E5E5E;
  --color_mono06:#F8F8F8;
  --color_lightblue01:#DEF1FF;
  --color_red01:#B83E3E;
  --f12:clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  --f14:clamp(0.625rem, 0.6rem + 0.13vw, 0.75rem);
  --f16:clamp(0.625rem, 0.55rem + 0.38vw, 1rem);
  --f18:clamp(1rem, 0.975rem + 0.13vw, 1.125rem);
  --f20:clamp(1rem, 0.95rem + 0.25vw, 1.25rem);
  --f22:clamp(1rem, 0.925rem + 0.38vw, 1.375rem);
  --f24:clamp(1.2rem, 0.9rem + 0.5vw, 1.5rem);
  --f26:clamp(1.2rem, 0.875rem + 0.63vw, 1.625rem);
  --f28:clamp(1.2rem, 0.85rem + 0.75vw, 1.75rem);
  --f30:clamp(1.2rem, 0.825rem + 0.88vw, 1.875rem);
  --f32:clamp(1rem, 0.8rem + 1vw, 2rem);
  --f34:clamp(1rem, 0.775rem + 1.13vw, 2.125rem);
  --f36:clamp(1rem, 0.75rem + 1.25vw, 2.25rem);
  --f38:clamp(1.5rem, 0.725rem + 1.38vw, 2.375rem);
  --f40:clamp(1rem, 0.7rem + 1.5vw, 2.5rem);
  --f42:clamp(1.5rem, 0.675rem + 1.63vw, 2.625rem);
  --f44:clamp(1.5rem, 0.65rem + 1.75vw, 2.75rem);
  --f48:clamp(2rem, 0.612rem + 1.94vw, 2.938rem);
  --f54:clamp(1rem, 0.136rem + 4.32vw, 3.375rem);
  --f57:clamp(2rem, 0.488rem + 2.56vw, 3.563rem);
  --f60:clamp(2rem, 5vw, 3.75rem);
  --f67:clamp(3rem, 0.362rem + 3.19vw, 4.188rem);
  --f70:clamp(3rem, 0.325rem + 3.38vw, 4.375rem);
  --f85:clamp(3rem, -0.568rem + 7.84vw, 5.313rem);
  --f100:clamp(3rem, -0.556rem + 7.78vw, 6.25rem);
  --f122:clamp(3rem, -1.409rem + 12.05vw, 7.625rem);
  --f127:clamp(4rem, -0.388rem + 6.94vw, 7.938rem);
  --f172:clamp(1rem, -0.95rem + 9.75vw, 10.75rem);
  --f240:clamp(1rem, -4.091rem + 25.45vw, 15rem);
}

a:hover {
  opacity: 0.7;
}

picture {
  display: block;
}

@media screen and (min-width: 992px) {
  body p {
    font-size: 20px;
  }
}
/*=========================*/
/*==　　　　パーツ　　　　 ==*/
/*=========================*/
.-sp_none {
  display: none;
}

@media screen and (min-width: 768px) {
  .-sp_none {
    display: block;
  }
}
.-md_none {
  display: none;
}

@media screen and (min-width: 992px) {
  .-md_none {
    display: block;
  }
}
@media screen and (min-width: 992px) {
  .-pc_none {
    display: none;
  }
}
.-small {
  font-size: 0.8em;
}

.c-scroll-up {
  position: fixed;
  bottom: 0.5rem;
  right: 0.5rem;
}

.c-section-title {
  margin-bottom: clamp(1rem, 2.34375vw, 2.8125rem);
  font-size: var(--f36);
  text-align: center;
}

.c-section-title-b {
  display: block;
  margin-bottom: clamp(1.5rem, 3.6458333333vw, 4.375rem);
  text-align: center;
}
.c-section-title-b__eng {
  color: var(--color_mono03);
  font-size: var(--f100);
  font-weight: 500;
  line-height: 1.3;
}
.c-section-title-b__jpn {
  font-size: var(--f30);
}
.c-section-title-b__jpn:before {
  content: "【";
}
.c-section-title-b__jpn:after {
  content: "】";
}

/*=========================*/
/*==　　　レイアウト　　　 ==*/
/*=========================*/
.l-container {
  width: calc(100% - 2rem);
  max-width: 1400px;
  margin: auto;
}
.l-container.-m {
  max-width: 1120px;
}

.l-header {
  width: 100%;
  height: 40px;
  padding-top: clamp(0.5rem, 1.1458333333vw, 1.375rem);
  padding-bottom: clamp(0.5rem, 1.25vw, 1.5rem);
  padding-left: clamp(0.5rem, 0.78125vw, 0.9375rem);
  padding-right: clamp(0.5rem, 1.1458333333vw, 1.375rem);
  position: fixed;
  top: 0;
  z-index: 10;
  background-color: rgba(255, 255, 255, 0.85);
}
.l-header__logo {
  height: 20px;
  aspect-ratio: 312/34;
}
.l-header__gnav {
  display: none;
  gap: clamp(1rem, 3.125vw, 3.75rem);
}
.l-header__gnav__items {
  gap: clamp(1rem, 2.34375vw, 3.3125rem);
}
.l-header__gnav__item a:hover {
  color: var(--color_blue01);
}
.l-header__tel {
  display: none;
}
.l-header__tel__number {
  display: flex;
  align-items: baseline;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 1rem;
  font-weight: 900;
  font-size: var(--f30);
}
.l-header__tel__number:before {
  content: "";
  display: block;
  width: clamp(1.5rem, 1.3541666667vw, 1.625rem);
  aspect-ratio: 1/1;
  margin-right: 0.5rem;
  background-image: url(../img/tel-icon.png);
  background-size: contain;
  background-position: bottom left;
}
.l-header.-active {
  height: 100dvh;
  position: fixed;
  top: 0;
  background-color: var(--color_mono02);
}
.l-header.-active .l-header__gnav {
  display: block;
  margin-bottom: 3rem;
  align-items: center;
  padding-top: 20%;
}
.l-header.-active .l-header__gnav__items {
  width: 100%;
}
.l-header.-active .l-header__gnav__item {
  width: 100%;
  margin-bottom: 1.5rem;
}
.l-header.-active .l-header__gnav__item a {
  display: block;
  text-align: center;
  font-size: 4vw;
}
.l-header.-active .l-header__tel {
  display: block;
}

@media screen and (min-width: 992px) {
  .l-header {
    width: 100%;
    height: clamp(4rem, 4.6875vw, 120rem);
    padding-top: clamp(1rem, 1.1458333333vw, 1.375rem);
    padding-bottom: clamp(1rem, 1.25vw, 1.5rem);
    padding-left: clamp(1rem, 0.78125vw, 0.9375rem);
    padding-right: clamp(1rem, 1.1458333333vw, 1.375rem);
  }
  .l-header__inner {
    display: grid;
    grid-auto-flow: column;
    justify-content: space-between;
    align-items: center;
    max-width: 1510px;
    margin: auto;
  }
  .l-header__logo {
    width: clamp(1rem, 16.25vw, 19.5rem);
    height: auto;
  }
  .l-header__gnav {
    display: flex;
    align-items: center;
    margin-bottom: 0;
  }
  .l-header__gnav__items {
    display: flex;
  }
  .l-header__gnav__contact-items {
    grid-auto-flow: column;
  }
  .l-header__tel {
    display: flex;
  }
}
.l-contents {
  margin-top: 40px;
}

@media screen and (min-width: 992px) {
  .l-contents {
    margin-top: clamp(4rem, 4.6875vw, 120rem);
  }
}
.l-footer {
  margin-top: clamp(4rem, 8.8541666667vw, 10.625rem);
  padding: clamp(4rem, 5.2083333333vw, 6.25rem) 0;
  background-image: url(../img/footer__bg.jpg);
  color: var(--color_mono02);
}
.l-footer__map {
  margin: 1rem 0 2rem;
}
.l-footer__copyright {
  text-align: center;
}

@media screen and (min-width: 992px) {
  .l-footer__inner {
    display: grid;
    grid-template-columns: 1fr clamp(50%, 44.0104166667vw, 52.8125rem);
    grid-template-areas: "info map" "copy map";
    gap: 1.5rem;
  }
  .l-footer__info {
    grid-area: info;
  }
  .l-footer__map {
    grid-area: map;
    margin: 0;
  }
  .l-footer__copyright {
    grid-area: copy;
    text-align: left;
    align-self: self-end;
  }
}
.l-page-header {
  margin-bottom: clamp(2rem, 5.7291666667vw, 6.875rem);
  background-image: url(../img/page-header__bg.png);
}
.l-page-header__title {
  display: block;
  padding-top: clamp(2rem, 5.2083333333vw, 6.25rem);
  padding-bottom: clamp(2rem, 4.1666666667vw, 5rem);
  color: var(--color_mono02);
  text-align: center;
}
.l-page-header__title__jpn {
  font-size: var(--f30);
}
.l-page-header__title__eng {
  font-weight: 300;
}

.l-contact {
  padding-top: clamp(4rem, 15.625vw, 18.75rem);
}
.l-contact__cards {
  display: grid;
  gap: clamp(1.5rem, 3.5416666667vw, 4.25rem);
}
.l-contact__card {
  border: 1px solid var(--color_mono01);
  border-radius: clamp(1rem, 1.5625vw, 1.875rem);
  overflow: hidden;
}
.l-contact__card a {
  display: block;
  height: 100%;
}
.l-contact__card__header {
  padding-top: clamp(4rem, 5.2083333333vw, 6.25rem);
  background-size: cover;
  background-position: center;
}
.l-contact__card__title {
  padding: clamp(0.5rem, 0.46875vw, 0.5625rem);
  background-color: rgba(0, 0, 0, 0.35);
  color: var(--color_mono02);
  text-align: center;
  font-size: var(--f30);
}
.l-contact__card.__tel .l-contact__card__header {
  background-image: url(../img/lower-contact__card__tel.jpg);
}
.l-contact__card.__form .l-contact__card__header {
  background-image: url(../img/lower-contact__card__form.jpg);
}
.l-contact__card__item {
  margin-bottom: 0.5rem;
  text-align: center;
}
.l-contact__card__number {
  font-size: 1.8em;
  line-height: 1;
}
.l-contact__card__label {
  display: block;
  font-size: 0.8em;
}
.l-contact__card__text {
  padding: 0.5rem 1rem;
}
.l-contact__card__more {
  margin-top: 1rem;
  text-align: right;
}

@media screen and (min-width: 768px) {
  .l-contact__cards {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
  .l-contact__card__text {
    text-align: center;
  }
  .l-contact__card__more {
    font-size: var(--f16);
    align-self: self-end;
  }
}
#c-hamburger {
  display: block;
  width: 2rem;
  height: -moz-fit-content;
  height: fit-content;
  position: fixed;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 999;
}
#c-hamburger span {
  display: block;
  width: 2rem;
  height: 2px;
  position: absolute;
  background-color: var(--color_mono01);
  border-radius: 4px;
  transition: 0.3s;
}
#c-hamburger span:nth-of-type(1) {
  top: 0;
}
#c-hamburger span:nth-of-type(2) {
  top: 0.5rem;
}
#c-hamburger span:nth-of-type(3) {
  top: 1rem;
}
#c-hamburger.-active span:nth-of-type(1) {
  top: 0.5rem;
  transform: rotate(45deg);
}
#c-hamburger.-active span:nth-of-type(2) {
  opacity: 0;
}
#c-hamburger.-active span:nth-of-type(3) {
  top: 0.5rem;
  transform: rotate(-45deg);
}

@media screen and (min-width: 992px) {
  #c-hamburger {
    display: none;
  }
}/*# sourceMappingURL=common.css.map */