@charset "UTF-8";
/* Sass Document */
/* ----------------------------------------------------------------------------------------------------
*  基本情報
* --------------------------------------------------------------------------------------------------*/
html,
body {
  height: 100%;
}

html {
  /* font-size: min(0.78vw, 62.5%); */
  font-size: 62.5%;
  overflow-y: scroll;
  scroll-behavior: smooth;
}
@media screen and (max-width: 767.98px) {
  html {
    width: 100%;
  }
}

html.wf-loading body {
  visibility: hidden;
}

html.wf-active body {
  visibility: visible;
}

body {
  -webkit-text-size-adjust: 100%;
  width: 100%;
  color: #243675;
  min-width: 1280px;
}
@media screen and (max-width: 767.98px) {
  body {
    min-width: inherit;
  }
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
address,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
img,
form {
  margin: 0;
  padding: 0;
  border: none;
  line-height: 1.7647058824;
  list-style-type: none;
  font-family: "dnp-shuei-4go-std", sans-serif;
  font-weight: 500;
  font-style: normal;
}

* {
  box-sizing: border-box;
}

@media screen and (max-width: 767.98px) {
  html {
    font-size: 1.923vw;
  }
}
@media (min-width: 768px) {
  a[href*="tel:"] {
    text-decoration: none;
    cursor: default;
    pointer-events: none;
  }
}
p {
  font-size: 1.8rem;
  line-height: 1.8888888889;
}

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

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.l-footer {
  background-color: #243675;
  color: #fff;
  padding: 2rem 0;
}
.l-footer a {
  color: currentColor;
  text-decoration: none;
}
@media (any-hover) {
  .l-footer a {
    transition: 0.3s opacity;
  }
  .l-footer a:hover {
    opacity: 0.7;
  }
}

.l-footer__inner {
  max-width: 128rem;
  margin: 0 auto;
  padding: 0 2rem;
  box-sizing: content-box;
}

.l-footer__info {
  text-align: center;
}
.l-footer__info .c-company {
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 0.11em;
}
@media screen and (max-width: 767.98px) {
  .l-footer__info .c-company {
    font-size: 2.3rem;
  }
}
.l-footer__info .c-add {
  font-size: 2rem;
  letter-spacing: 0.11em;
}
@media screen and (max-width: 767.98px) {
  .l-footer__info .c-add {
    font-size: 1.45rem;
  }
}

.l-footer__bottom {
  width: 100%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767.98px) {
  .l-footer__bottom {
    display: block;
    text-align: center;
  }
}

.l-footer__copy p {
  font-size: 1.4rem;
}

.c-privacy {
  font-size: 1.4rem;
}

.l-header {
  height: 14.2rem;
  padding-top: 2.7rem;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.9);
  z-index: 100;
  color: #000;
  transition: 0.3s visibility, 0.3s opacity;
}
.l-header.is-front {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}
@media screen and (max-width: 767.98px) {
  .l-header {
    height: 8.5rem;
    padding-top: 2rem;
  }
}

.l-header__inner {
  max-width: 120.6rem;
  min-width: 1280px;
  padding-left: 2rem;
  padding-right: 2rem;
  box-sizing: content-box;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767.98px) {
  .l-header__inner {
    display: block;
    min-width: inherit;
    padding-left: 1.4rem;
    padding-right: 1.4rem;
  }
}

.l-header__logo {
  width: 18.7rem;
}
@media screen and (max-width: 767.98px) {
  .l-header__logo {
    width: 13.8rem;
  }
}
@media (any-hover) {
  .l-header__logo a {
    transition: 0.3s opacity;
  }
  .l-header__logo a:hover {
    opacity: 0.7;
  }
}

.l-navigation {
  height: auto;
}
@media screen and (max-width: 767.98px) {
  .l-navigation {
    height: 100dvh;
    overflow: auto;
    background-color: #000;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 5;
    color: #fff;
    padding: 15rem 1rem 15rem 6rem;
    transform: translateY(-100%);
    transition: 0.5s transform, 0.5s visibility;
    visibility: hidden;
  }
  .l-navigation.is-open {
    visibility: visible;
    transform: translateY(0);
  }
}
.l-navigation a {
  color: currentColor;
  text-decoration: none;
}
@media (any-hover) {
  .l-navigation a {
    transition: 0.3s opacity;
  }
  .l-navigation a:hover {
    opacity: 0.7;
  }
}

.l-navigation__inner {
  display: flex;
  flex-direction: column;
  flex-direction: column-reverse;
  height: 100%;
  padding-bottom: 0.3rem;
}
@media screen and (max-width: 767.98px) {
  .l-navigation__inner {
    display: block;
  }
}

.l-primary-nav__list {
  font-size: 1.4rem;
  display: flex;
  margin-left: auto;
  margin-top: auto;
  gap: 0 2.2rem;
}
@media screen and (max-width: 767.98px) {
  .l-primary-nav__list {
    font-size: 2.5rem;
    display: block;
  }
  .l-primary-nav__list a {
    display: block;
    padding: 2rem 0;
  }
}

.l-secondary-nav__list {
  font-size: 1.5rem;
  display: flex;
  margin-left: auto;
  gap: 0 2.8rem;
}
@media screen and (max-width: 767.98px) {
  .l-secondary-nav__list {
    margin-top: 5rem;
    font-size: 2.5rem;
    display: block;
  }
  .l-secondary-nav__list a {
    display: block;
    padding: 2rem 0;
  }
}

.l-secondary-nav__item:nth-of-type(2) {
  display: none;
}

/* ----------------------------------------------------------------------------------------------------
*	ハンバーガー
* --------------------------------------------------------------------------------------------------*/
.l-hamburger__wrapper {
  display: none;
}
@media screen and (max-width: 767.98px) {
  .l-hamburger__wrapper {
    width: 6rem;
    height: 6rem;
    display: block;
    position: fixed;
    z-index: 10;
    top: 1.4rem;
    right: 1.3rem;
  }
}

.l-hamburger {
  width: 100%;
  height: 100%;
  position: relative;
  border: none;
  background-color: transparent;
  cursor: pointer;
  font: inherit;
}
.l-hamburger.is-cross .l-hamburger__line {
  background-color: #fff;
}
.l-hamburger.is-cross .l-hamburger__line:first-of-type, .l-hamburger.is-cross .l-hamburger__line:last-of-type {
  top: calc(50% - 1px);
}
.l-hamburger.is-cross .l-hamburger__line:first-of-type {
  transform: rotate(-30deg);
}
.l-hamburger.is-cross .l-hamburger__line:last-of-type {
  transform: rotate(30deg);
}

.l-hamburger__line {
  position: absolute;
  height: 2px;
  width: 3.6rem;
  left: 0;
  right: 0;
  margin: 0 auto;
  background-color: #000;
  transition: 0.3s all;
}
.l-hamburger__line:first-of-type {
  top: calc(50% - 0.7rem - 1px);
}
.l-hamburger__line:last-of-type {
  top: calc(50% + 0.7rem - 1px);
}

.u-en {
  font-family: "din-2014-narrow";
}

.c-section-ttl {
  text-align: center;
  font-weight: 500;
}
.c-section-ttl .u-en {
  font-size: 5.4rem;
  color: #bf9d5a;
  display: block;
  line-height: 1.4;
  margin-bottom: 0.6rem;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767.98px) {
  .c-section-ttl .u-en {
    font-size: 5.49rem;
  }
}
.c-section-ttl .u-jp {
  font-size: 3.15rem;
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.4;
  color: #243675;
  margin-bottom: 1.4rem;
}
.c-section-ttl .u-jp.u-line {
  position: relative;
}
.c-section-ttl .u-jp.u-line::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  height: 1.1rem;
  background-color: #243675;
  top: calc(100% + 1.1rem);
}
@media screen and (max-width: 767.98px) {
  .c-section-ttl .u-jp.u-line::after {
    top: calc(100% + 0.2rem);
  }
}
.c-section-ttl .u-txtsize--m {
  font-size: 3.3rem;
}
.c-section-ttl .u-txtsize--l {
  font-size: 3.5rem;
}

.u-pc {
  display: block;
}
@media screen and (max-width: 767.98px) {
  .u-pc {
    display: none;
  }
}

.u-pcInline {
  display: inline-block;
}
@media screen and (max-width: 767.98px) {
  .u-pcInline {
    display: none;
  }
}

.u-sp {
  display: none;
}
@media screen and (max-width: 767.98px) {
  .u-sp {
    display: block;
  }
}

.l-main {
  padding-top: 14.2rem;
}
@media screen and (max-width: 767.98px) {
  .l-main {
    padding-top: 8.5rem;
  }
}

.u-bg-hexagon {
  -webkit-clip-path: polygon(calc(100% - 1.5rem) 0, 100% 50%, calc(100% - 1.5rem) 100%, 1.5rem 100%, 0% 50%, 1.5rem 0%);
          clip-path: polygon(calc(100% - 1.5rem) 0, 100% 50%, calc(100% - 1.5rem) 100%, 1.5rem 100%, 0% 50%, 1.5rem 0%);
  padding: 0 5rem;
}

.u-bgcolor--main {
  background-color: #243675;
}

.u-bgcolor--sub {
  background-color: #be9c59;
}

/* @use "layout/_sidebar"; */
/* @use "object/component/_button";
@use "object/component/_dialog";
@use "object/component/_grid";
@use "object/component/_media";
 */
/* @use "object/project/_articles";
@use "object/project/_comments";
@use "object/project/_gallery";
@use "object/project/_profile";
 */
/* @use "object/utility/_align";
@use "object/utility/_clearfix";
@use "object/utility/_margin";
@use "object/utility/_position";
@use "object/utility/_size";
@use "object/utility/_text";
 */
/*# sourceMappingURL=common.css.map */