@charset "UTF-8";
/*=========================*/
/*==　　　　変数　　　　　 ==*/
/*=========================*/
:root {
  --color_bg01:#fbfbfb;
  --color_mono01:#222;
  --color_mono02:#fff;
  --color_mono03:#707070;
  --color_mono04:#B2B2B2;
  --color_mono05:#414141;
  --color_mono06:#2d2d2d;
  --color_mono07:#c9c9c9;
  --color_mono08:#565656;
  --color_mono09:#999999;
  --color_mono10:#eeeeee;
  --color_mono11:#F6F6F6;
  --color_green01:#21A421;
  --color_blue01:#3866A1;
  --color_blue02:#0E3972;
  --color_blue03:#4177BE;
  --color_blue04:#476E91;
  --color_lightblue01:#9BB5D8;
  --color_lightblue02:#6FC9C0;
  --color_lightblue03:#E1FDFF;
  --color_lightblue04:#E6F1FF;
  --color_moskyblue01:#A4BBD9;
  --color_moskyblue02:#ABB8DC;
  --color_yellow01:#FBD146;
  --color_red01:#A84D4D;
  --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(3.5rem, -0.568rem + 7.84vw, 5.313rem);
  --f122:clamp(1rem, -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);
  --f_montserrat: "Montserrat", sans-serif;
}

picture {
  display: block;
}

p > a {
  color: var(--color_blue01);
  text-decoration: underline;
}
p > a:hover {
  text-decoration: none;
}

@media screen and (min-width: 992px) {
  body p {
    font-size: 17px;
  }
}
/*=========================*/
/*==　　　　パーツ　　　　 ==*/
/*=========================*/
.-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;
}

.loader {
  position: fixed;
  width: 100%;
  height: 100vh;
  background-color: #fff;
  z-index: 555;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

.loader .txt {
  font-size: 45px;
  font-weight: bold;
  　color: rgb(30, 50, 93);
}

.c-globalcopy {
  position: absolute;
  padding-top: clamp(3rem, 5.2083333333vw, 6.25rem);
  left: clamp(1rem, 1.3020833333vw, 1.5625rem);
  writing-mode: vertical-rl;
  font-size: 0.8rem;
}
.c-globalcopy:before {
  content: "";
  display: block;
  height: clamp(2rem, 3.6458333333vw, 4.375rem);
  width: 1px;
  margin-top: 0.5rem;
  margin-right: 0.5rem;
  position: absolute;
  top: 0;
  background-color: var(--color_mono04);
}
.c-globalcopy__jpn {
  letter-spacing: 0.25em;
}
.c-globalcopy__eng {
  color: var(--color_mono04);
  line-height: 1.3;
  font-family: var(--f_montserrat);
}

@media screen and (min-width: 768px) {
  .c-globalcopy {
    font-size: 1rem;
  }
  .c-globalcopy:before {
    margin-right: 0.75rem;
  }
  .c-globalcopy__jpn {
    margin-left: 1rem;
  }
}
.c-section-title {
  display: block;
  margin-bottom: clamp(1.5rem, 2.8645833333vw, 3.4375rem);
  text-align: center;
}
.c-section-title__jpn {
  font-size: 1.3rem;
  font-weight: 700;
}
.c-section-title__eng {
  color: var(--color_blue01);
  font-size: 0.8rem;
  font-weight: 700;
}

@media screen and (min-width: 768px) {
  .c-section-title {
    text-align: left;
  }
  .c-section-title__jpn {
    font-size: var(--f36);
  }
  .c-section-title__eng {
    font-size: var(--f16);
  }
}
.c-button__a {
  display: block;
  margin: 0.5rem 0;
  padding-top: clamp(1rem, 1.0416666667vw, 1.25rem);
  padding-bottom: clamp(1rem, 1.0416666667vw, 1.25rem);
  padding-left: clamp(1rem, 2.0833333333vw, 2.5rem);
  padding-right: clamp(1rem, 2.0833333333vw, 2.5rem);
  position: relative;
  border: 1px solid var(--color_mono04);
}
.c-button__a:before {
  content: "";
  display: block;
  width: clamp(0.75rem, 0.78125vw, 0.9375rem);
  height: calc(clamp(0.75rem, 0.78125vw, 0.9375rem) / 2 * 1.7320508076);
  position: absolute;
  top: clamp(0.1rem, 0.15625vw, 0.1875rem);
  left: clamp(0.1rem, 0.15625vw, 0.1875rem);
  clip-path: polygon(100% 0, 0 100%, 0 0);
  background: var(--color_mono04);
}

.c-button__b {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: 0;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color_mono04);
}
.c-button__b__text {
  display: block;
  width: 100%;
  padding-right: clamp(1.5rem, 3.6458333333vw, 4.375rem);
  position: relative;
  font-weight: 700;
}
.c-button__b__text:after {
  content: "";
  display: block;
  width: 1rem;
  aspect-ratio: 1/1;
  position: absolute;
  top: 50%;
  right: 0.5rem;
  transform: translateY(-50%);
  background-image: url(../img/icon-arrow.png);
  background-size: contain;
  background-repeat: no-repeat;
  transition: 0.2s;
}
.c-button__b:hover .c-button__b__text {
  color: var(--color_blue01);
}
.c-button__b:hover .c-button__b__text:after {
  right: 0.25rem;
}

.c-form__unit + .c-form__unit {
  margin-top: clamp(1rem, 1.3541666667vw, 1.625rem);
}
.c-form__label {
  display: grid;
  grid-auto-flow: column;
  justify-content: start;
  align-items: center;
}
.c-form__req {
  margin-left: 0.5rem;
  color: var(--color_red01);
  font-size: 0.8rem;
  font-weight: 700;
}
.c-form__content input[type=text],
.c-form__content input[type=email],
.c-form__content input[type=tel],
.c-form__content input[type=date],
.c-form__content textarea {
  display: block;
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--color_mono09);
}
.c-form__privacy {
  margin-top: clamp(1rem, 2.34375vw, 2.8125rem);
  margin-bottom: clamp(1rem, 2.34375vw, 2.8125rem);
  text-align: center;
}
.c-form__privacy a {
  color: var(--color_blue01);
  text-decoration: underline;
}
.c-form__privacy a:hover {
  text-decoration: none;
}
.c-form__submit {
  display: block;
  width: clamp(10rem, 15.46875vw, 18.5625rem);
  margin: auto;
  padding: clamp(0.5rem, 0.8333333333vw, 1rem);
  background-color: var(--color_mono05);
  color: var(--color_mono02);
  text-align: center;
  border-radius: 0.5rem;
  transition: 0.2s;
}
.c-form__submit:hover {
  background-color: var(--color_blue01);
}

@media screen and (min-width: 768px) {
  .c-form {
    max-width: 1024px;
  }
  .c-form__unit {
    display: grid;
    grid-auto-flow: column;
    justify-content: start;
    align-items: start;
    grid-template-columns: clamp(10rem, 15.1041666667vw, 18.125rem) 1fr;
  }
  .c-form__label {
    display: grid;
    grid-auto-flow: column;
    justify-content: space-between;
    width: clamp(10rem, 15.1041666667vw, 18.125rem);
    padding-top: 0.25rem;
    padding-right: clamp(1rem, 1.5625vw, 1.875rem);
  }
  .c-form__req {
    font-size: 1rem;
  }
}
.c-policy-section-title {
  display: grid;
  grid-auto-flow: column;
  justify-content: start;
  align-items: center;
  margin-bottom: clamp(1.5rem, 2.0833333333vw, 2.5rem);
  padding-bottom: clamp(0.5rem, 0.7291666667vw, 0.875rem);
  color: var(--color_blue03);
  font-weight: 700;
  font-size: 1.1rem;
  border-bottom: 1px solid var(--color_mono07);
}
.c-policy-section-title:before {
  content: "";
  display: block;
  width: clamp(1rem, 1.6666666667vw, 2rem);
  aspect-ratio: 28/30;
  margin-right: 0.5rem;
  clip-path: polygon(40% 0%, 100% 0%, 60% 100%, 0% 100%);
  background-color: var(--color_blue01);
}

@media screen and (min-width: 768px) {
  .c-policy-section-title {
    font-size: var(--f28);
  }
}
.c-circle-title {
  display: grid;
  grid-auto-flow: column;
  justify-content: start;
  align-items: center;
  margin-bottom: clamp(1rem, 1.8229166667vw, 2.1875rem);
  font-size: 1.1rem;
  font-weight: 700;
}
.c-circle-title:before {
  content: "";
  display: block;
  width: clamp(1rem, 1.1458333333vw, 1.375rem);
  aspect-ratio: 1/1;
  margin-right: clamp(0.5rem, 0.2604166667vw, 0.3125rem);
  background-image: url(../img/circle-title.png);
  background-size: contain;
}

@media screen and (min-width: 768px) {
  .c-circle-title {
    font-size: var(--f20);
  }
}
.c-policy-list {
  display: grid;
  grid-auto-flow: column;
  justify-content: start;
  align-items: start;
  margin-bottom: 0.25rem;
}
.c-policy-list:before {
  content: "";
  display: block;
  width: clamp(0.25rem, 0.3125vw, 0.375rem);
  aspect-ratio: 1/1.5;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  margin-top: 0.5rem;
  margin-right: 0.5rem;
  background-color: var(--color_lightblue02);
}

.c-recruit-menu {
  padding-bottom: clamp(2rem, 2.3958333333vw, 2.875rem);
}
.c-recruit-menu__list {
  position: relative;
  z-index: 1;
}
.c-recruit-menu__list + .c-recruit-menu__list {
  margin-top: 0.5rem;
}
.c-recruit-menu__list a {
  display: block;
  padding: 1rem;
  text-align: center;
  background-color: var(--color_blue03);
  color: var(--color_mono02);
}
.c-recruit-menu__list a:hover {
  background-color: var(--color_blue02);
}
.c-recruit-menu__list__eng {
  display: block;
  color: var(--color_yellow01);
  font-size: 0.8rem;
  font-weight: 700;
}
.c-recruit-menu__list__caption {
  padding-top: clamp(0.5rem, 0.6770833333vw, 0.8125rem);
  padding-bottom: clamp(0.5rem, 0.6770833333vw, 0.8125rem);
  padding-left: clamp(1rem, 2.6041666667vw, 3.125rem);
  padding-right: clamp(1rem, 2.6041666667vw, 3.125rem);
  position: absolute;
  bottom: -2rem;
  right: -0.5rem;
  background: transparent linear-gradient(89deg, #B11818 0%, #C800B4 100%) 0% 0% no-repeat padding-box;
  color: var(--color_mono02);
}

@media screen and (min-width: 768px) {
  .c-recruit-menu {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(1rem, 1.0416666667vw, 1.25rem);
    max-width: 1240px;
    margin: auto;
  }
  .c-recruit-menu__list {
    font-size: var(--f20);
  }
  .c-recruit-menu__list + .c-recruit-menu__list {
    margin-top: 0;
  }
  .c-recruit-menu__list__caption {
    bottom: calc(clamp(1.75rem, 2.0833333333vw, 2.5rem) * -1);
    font-size: var(--f14);
  }
}
@media screen and (min-width: 992px) {
  .c-recruit-menu {
    display: grid;
  }
}
.c-partner__lists {
  padding-top: clamp(1.5rem, 2.34375vw, 2.8125rem);
  padding-bottom: clamp(1.5rem, 2.34375vw, 2.8125rem);
  padding-left: clamp(1rem, 3.6458333333vw, 4.375rem);
  padding-right: clamp(1rem, 3.6458333333vw, 4.375rem);
  background-color: var(--color_lightblue03);
}
.c-partner__list a {
  text-decoration: underline;
}
.c-partner__list a:hover {
  text-decoration: none;
  color: var(--color_blue01);
}

@media screen and (min-width: 768px) {
  .c-partner__lists {
    display: flex;
    flex-wrap: wrap;
  }
  .c-partner__list {
    width: 50%;
    margin-bottom: 1rem;
  }
}

/*=========================*/
/*==　　　animation　　　 ==*/
/*=========================*/
.js-fade{
  transform: translateY(50px);
  opacity: 0;
  transition: 2s;
}
.js-fade.is-active{
  transform: translateY(0);
  opacity: 1;
}
@keyframes page-title {
  0% {
    opacity: 0;
    transform: translateX(-50px);
  }
  100% {
    opacity: 100;
    transform: translateX(0);
  }
}
@keyframes page-hero {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100% {
    opacity: 100;
    transform: translateX(0);
  }
}

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

.l-header {
  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: absolute;
  z-index: 10;
}
.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.7604166667vw, 3.3125rem);
}
.l-header__gnav__item a:hover {
  color: var(--color_blue01);
}
.l-header__gnav__contact-items {
  display: grid;
  gap: 1rem;
}
.l-header__gnav__contact-item a {
  display: grid;
  grid-auto-flow: column;
  justify-content: center;
  align-items: center;
  width: clamp(10rem, 10.6770833333vw, 12.8125rem);
  padding: 0.5rem;
  background-color: var(--color_mono05);
  color: var(--color_mono02);
  border-radius: clamp(0.25rem, 0.2604166667vw, 0.3125rem);
}
.l-header__gnav__contact-item a:before {
  content: "";
  display: block;
  height: 1.5rem;
  aspect-ratio: 1/1;
  margin-right: 0.5rem;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.l-header__gnav__contact-item a:hover {
  background-color: var(--color_blue01);
}
.l-header__gnav__contact-item.__form a:before {
  background-image: url(../img/icon-mail.png);
}
.l-header__gnav__contact-item.__tel a:before {
  background-image: url(../img/icon-tel.png);
}
.l-header.-active {
  height: 100dvh;
  position: fixed;
  top: 0;
  background-color: var(--color_mono02);
}
.l-header.-active .l-header__gnav {
  display: block;
  align-items: center;
  height: 100dvh;
  width: 100vw;
  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__gnav__contact-items {
  margin-top: 4rem;
}
.l-header.-active .l-header__gnav__contact-item {
  margin: auto;
}

@media screen and (min-width: 1300px) {
  .l-header {
    display: grid;
    grid-auto-flow: column;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    height: auto;
    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__logo {
    width: clamp(1rem, 16.25vw, 19.5rem);
    height: auto;
  }
  .l-header__gnav {
    display: flex;
    align-items: center;
  }
  .l-header__gnav__items {
    display: flex;
  }
  .l-header__gnav__contact-items {
    grid-auto-flow: column;
  }
}
.l-contact {
  margin-bottom: clamp(4rem, 6.5104166667vw, 7.8125rem);
}
.l-contact__wrapper {
  display: grid;
  margin-bottom: clamp(1rem, 1.5625vw, 1.875rem);
  background-color: var(--color_blue01);
}
.l-contact__contents {
  padding-top: clamp(2rem, 4.1666666667vw, 5rem);
  padding-bottom: clamp(2rem, 2.6041666667vw, 3.125rem);
  padding-left: 1rem;
  padding-right: 1rem;
  color: var(--color_mono02);
  order: 1;
}
.l-contact__caption {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  padding-bottom: clamp(1rem, 1.0416666667vw, 1.25rem);
  padding-left: clamp(0.5rem, 0.5208333333vw, 0.625rem);
  padding-right: clamp(0.5rem, 0.5208333333vw, 0.625rem);
  background-image: url(../img/l-contact__caption.png);
  background-size: 100% clamp(1rem, 0.8854166667vw, 1.0625rem);
  background-repeat: no-repeat;
  background-position: center bottom;
  font-weight: 400;
}
.l-contact__title {
  margin-bottom: clamp(1.5rem, 1.4583333333vw, 1.75rem);
  font-size: 1.25rem;
  text-align: center;
}
.l-contact__tel a, .l-contact__mail a {
  display: block;
  padding: 1rem;
  background-color: var(--color_mono05);
  box-shadow: 0px 0px 6px rgba(255, 255, 255, 0.5019607843);
  border-radius: clamp(0.5rem, 0.5208333333vw, 0.625rem);
  text-align: center;
  font-size: 1.1rem;
}
.l-contact__tel__text, .l-contact__mail__text {
  display: grid;
  grid-auto-flow: column;
  justify-content: center;
  align-items: center;
}
.l-contact__tel__text:before, .l-contact__mail__text:before {
  content: "";
  display: block;
  width: clamp(1rem, 1.25vw, 1.5rem);
  aspect-ratio: 1/1;
  margin-right: clamp(0.5rem, 0.6770833333vw, 0.8125rem);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.l-contact__tel__text:before {
  background-image: url(../img/icon-tel.png);
}
.l-contact__tel__opentime {
  text-align: center;
}
.l-contact__mail {
  margin-top: 1rem;
}
.l-contact__mail__text:before {
  background-image: url(../img/icon-mail.png);
}
.l-contact__mail a:hover {
  background-color: var(--color_mono01);
}
.l-contact__image {
  order: 0;
}
.l-contact__brand__lists {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  -moz-column-gap: clamp(0.75rem, 2.96875vw, 3.5625rem);
       column-gap: clamp(0.75rem, 2.96875vw, 3.5625rem);
  row-gap: clamp(0.75rem, 1.875vw, 2.25rem);
}
.l-contact__brand__list {
  height: 1.5rem;
}
.l-contact__brand__list img {
  display: block;
  height: 1.5rem;
}

@media screen and (min-width: 768px) {
  .l-contact__wrapper {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: calc(50% - clamp(1rem, 6.25vw, 7.5rem)) calc(50% + clamp(1rem, 6.25vw, 7.5rem));
  }
  .l-contact__contents {
    max-width: 650px;
  }
  .l-contact__caption {
    margin-bottom: 1rem;
    font-size: var(--f20);
  }
  .l-contact__title {
    padding-left: 0.5rem;
    font-size: var(--f30);
  }
  .l-contact__image {
    height: 100%;
  }
  .l-contact__image img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .l-contact__brand__lists {
    max-width: 1200px;
    margin: auto;
  }
  .l-contact__brand__list img {
    height: 2rem;
  }
}
@media screen and (min-width: 1300px) {
  .l-contact__contents {
    margin-left: clamp(1rem, 6.25vw, 7.5rem);
  }
  .l-contact__caption {
    margin-left: 0;
  }
  .l-contact__title {
    text-align: left;
  }
  .l-contact__ways {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: repeat(2, clamp(14rem, 15.625vw, 18.75rem));
    gap: clamp(1rem, 1.0416666667vw, 1.25rem);
  }
  .l-contact__tel__opentime {
    margin-top: 0.25rem;
    font-size: 0.9em;
  }
  .l-contact__mail {
    margin-top: 0;
  }
}
.l-footer__logo {
  width: clamp(20rem, 21.40625vw, 25.6875rem);
  margin-bottom: clamp(1rem, 4.1666666667vw, 5rem);
  margin-left: auto;
  margin-right: auto;
}
.l-footer__office__list {
  padding: 1rem 0;
}
.l-footer__office__list:not(.l-footer__office__list:last-of-type) {
  border-bottom: 1px solid var(--color_mono07);
}
.l-footer__office__list__title {
  margin-bottom: 0.25rem;
  font-weight: 700;
}
.l-footer__office__list__address {
  margin-bottom: 0.25rem;
  padding-left: clamp(1.2rem, 1.3020833333vw, 1.5625rem);
  position: relative;
}
.l-footer__office__list__address:before {
  content: "";
  display: block;
  width: clamp(1rem, 0.8854166667vw, 1.0625rem);
  aspect-ratio: 17/21;
  position: absolute;
  left: 0;
  top: 0.25rem;
  background-image: url(../img/icon-map.png);
  background-size: contain;
  background-repeat: no-repeat;
}
.l-footer__office__list__map {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 0.25rem;
  padding: 0.1rem 1.5rem;
  background-color: var(--color_mono06);
  border: 1px solid var(--color_mono03);
  border-radius: clamp(1rem, 1.0416666667vw, 1.25rem);
  color: var(--color_mono02);
  font-size: 0.8rem;
  font-weight: 700;
  text-decoration: none;
}
.l-footer__office__list__map:hover {
  background-color: #0E3972;
}
.l-footer__office__list__tel, .l-footer__office__list__fax {
  font-weight: 700;
}
.l-footer__office__list__tel a {
  text-decoration: none;
  color: inherit;
}
.l-footer__page-nav {
  padding-top: clamp(2rem, 1.5625vw, 1.875rem);
  padding-bottom: clamp(2rem, 1.9791666667vw, 2.375rem);
  border-top: 1px solid var(--color_mono04);
  background-color: var(--color_bg01);
}
.l-footer__page-nav__unit {
  color: var(--color_mono08);
}
.l-footer__page-nav__unit__title {
  position: relative;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  font-weight: 700;
  border-bottom: 1px solid var(--color_mono07);
  line-height: 1;
}
.l-footer__page-nav__unit__title:before {
  content: "";
  display: block;
  width: clamp(0.3rem, 0.3645833333vw, 0.4375rem);
  height: clamp(1rem, 0.8333333333vw, 1rem);
  position: absolute;
  left: 0;
  background-color: var(--color_mono09);
}
.l-footer__page-nav__unit + .l-footer__page-nav__unit {
  margin-top: 2rem;
}
.l-footer__page-nav__unit__page {
  position: relative;
  padding-left: 1rem;
}
.l-footer__page-nav__unit__page:before, .l-footer__page-nav__unit__page:after {
  content: "";
  display: block;
  width: 0.4rem;
  height: 1px;
  position: absolute;
  left: 0;
  background-color: var(--color_mono09);
}
.l-footer__page-nav__unit__page:before {
  transform: rotate(45deg);
  top: 0.6rem;
}
.l-footer__page-nav__unit__page:after {
  transform: rotate(-45deg);
  top: 0.8rem;
}
.l-footer__page-nav__unit__page a:hover {
  color: var(--color_blue01);
}
.l-footer__copyright {
  padding: 1.5rem 0;
  background-color: var(--color_mono05);
  color: var(--color_mono02);
  text-align: center;
}
.l-footer__copyright p {
  font-size: 0.8rem;
}

@media screen and (min-width: 768px) {
  .l-footer__office {
    padding-bottom: clamp(2rem, 3.6458333333vw, 4.375rem);
  }
  .l-footer__office__lists {
    display: grid;
    grid-template-columns: repeat(3, 33.3333333333%);
  }
  .l-footer__office__list {
    padding: 0 clamp(1rem, 1.3020833333vw, 12.5rem);
    border-right: 1px solid var(--color_mono07);
  }
  .l-footer__office__list:not(.l-footer__office__list:last-of-type) {
    border-bottom: none;
  }
  .l-footer__office__list:nth-of-type(1) {
    border-left: 1px solid var(--color_mono07);
  }
  .l-footer__office__list__title {
    margin-bottom: 1rem;
  }
  .l-footer__office__list__address {
    margin-bottom: 1rem;
    font-size: var(--f16);
  }
  .l-footer__office__list__tel, .l-footer__office__list__fax {
    padding-left: 0.5rem;
  }
  .l-footer__page-nav__wrapper {
    display: grid;
    grid-template-columns: repeat(2, calc((100% - clamp(1rem, 1.0416666667vw, 12.5rem)) / 2));
    gap: clamp(1rem, 1.0416666667vw, 12.5rem);
  }
  .l-footer__page-nav__unit + .l-footer__page-nav__unit {
    margin-top: 0;
  }
  .l-footer__page-nav__unit__title {
    margin-bottom: 1rem;
    padding-bottom: 1rem;
  }
  .l-footer__page-nav__unit__page {
    padding-left: 2rem;
  }
  .l-footer__page-nav__unit__page:before, .l-footer__page-nav__unit__page:after {
    left: 0.75rem;
  }
}
@media screen and (min-width: 992px) {
  .l-footer__page-nav__wrapper {
    grid-template-columns: repeat(4, calc((100% - clamp(3rem, 3.125vw, 12.5rem)) / 4));
  }
  .l-footer__page-nav__unit__title {
    font-size: var(--f16);
  }
  .l-footer__page-nav__unit__page {
    font-size: var(--f16);
  }
}
.l-page-header {
  background-image: url(../img/front__main-vis__bg.jpg);
  background-size: cover;
}
.l-page-header .c-globalcopy {
  display: none;
}
.l-page-header__title{
  transform: translateX(-50px);
  animation: page-title 2s 1 forwards;
}
.l-page-header__title__jpn {
  padding-left: clamp(1.5rem, 2.0833333333vw, 2.5rem);
  position: relative;
  line-height: 1;
  font-weight: 700;
}
.l-page-header__title__jpn:before {
  content: "";
  display: block;
  width: clamp(1.5rem, 1.6145833333vw, 1.9375rem);
  aspect-ratio: 31/27;
  position: absolute;
  left: -0.25rem;
  top: 50%;
  transform: translateY(-50%);
  background-image: url(../img/icon-heart.png);
  background-size: contain;
  background-position: center;
}
.l-page-header__title__eng {
  color: var(--color_blue01);
  font-weight: 700;
  font-size: 1.8rem;
}
.l-page-header.__patern-a {
  display: grid;
  position: relative;
}
.l-page-header.__patern-a:after {
  content: "";
  width: 100%;
  max-width: 1500px;
  height: clamp(1rem, 3.6458333333vw, 4.6875rem);
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  margin: auto;
  clip-path: polygon(2.5% 0, 97.5% 0, 100% 100%, 0 100%);
  background-color: var(--color_mono02);
  border-radius: 3rem 3rem 0 0;
}
.l-page-header.__patern-a .l-page-header__title {
  order: 0;
  padding: 5rem 0 1rem 2rem;
}
.l-page-header.__patern-a:before {
  content: "";
  display: block;
  width: 100%;
  height: 40dvh;
  background-size: cover;
  background-repeat: no-repeat;
  order: 1;
  opacity: 0;
  transform: translateX(20px);
  animation: page-hero 3s 1 forwards;
}
.l-page-header.__patern-b .l-page-header__title {
  border-top: 1px solid var(--color_mono04);
  padding: 4rem 1rem 2rem 2rem;
}

@media screen and (min-width: 768px) {
  .l-page-header {
    padding-top: 4.5rem;
  }
  .l-page-header.__patern-a {
    display: grid;
    grid-auto-flow: column;
    grid-template-columns: 1fr clamp(55%, 58.75vw, 70.5rem);
  }
  .l-page-header.__patern-a:before {
    height: 100%;
    background-size: cover;
  }
  .l-page-header.__patern-a .l-page-header__title {
    padding-top: clamp(4rem, 16.1458333333vw, 19.375rem);
    padding-bottom: clamp(4rem, 10.4166666667vw, 12.5rem);
    padding-left: clamp(1rem, 2.34375vw, 2.8125rem);
  }
  .l-page-header.__patern-b .l-page-header__title {
    padding-left: calc((100% - 1500px) / 2);
    padding-top: clamp(4rem, 4.1666666667vw, 19.375rem);
  }
  .l-page-header__title__jpn {
    font-size: var(--f22);
  }
  .l-page-header__title__eng {
    font-size: var(--f70);
  }
}
@media screen and (min-width: 1500px) {
  .l-page-header .c-globalcopy {
    display: inherit;
    top: clamp(1.5rem, 4.1666666667vw, 5rem);
  }
  .l-page-header.__patern-a .l-page-header__title {
    padding-left: calc((100vw - 1500px) / 2 + 7rem);
  }
  .l-page-header.__patern-a:after {
    width: calc(100% - 2rem);
  }
}
@media screen and (min-width: 1700px) {
  .l-page-header {
    padding-top: clamp(1.5rem, 4.1666666667vw, 5rem);
  }
  .l-page-header.__patern-a .l-page-header__title {
    padding-left: calc((100vw - 1500px) / 2 + clamp(1rem, 2.34375vw, 2.8125rem));
  }
}
#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_blue02);
  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: 1300px) {
  #c-hamburger {
    display: none;
  }
}/*# sourceMappingURL=common.css.map */