@charset "UTF-8";
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block;
}

ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

img {
  max-width: 100%;
  height: auto;
  font-size: 0;
  line-height: 0;
  vertical-align: bottom;
}

.u-hidden {
  display: none !important;
  visibility: hidden;
}

.u-hidden-up-sm {
  display: none !important;
  visibility: hidden;
}

.u-hidden-down-lg {
  display: none !important;
  visibility: hidden;
}

.u-mt5 {
  margin-top: 5px !important;
}

.u-pt5 {
  padding-top: 5px !important;
}

.u-mr5 {
  margin-right: 5px !important;
}

.u-pr5 {
  padding-right: 5px !important;
}

.u-mb5 {
  margin-bottom: 5px !important;
}

.u-pb5 {
  padding-bottom: 5px !important;
}

.u-ml5 {
  margin-left: 5px !important;
}

.u-pl5 {
  padding-left: 5px !important;
}

.u-mt10 {
  margin-top: 10px !important;
}

.u-pt10 {
  padding-top: 10px !important;
}

.u-mr10 {
  margin-right: 10px !important;
}

.u-pr10 {
  padding-right: 10px !important;
}

.u-mb10 {
  margin-bottom: 10px !important;
}

.u-pb10 {
  padding-bottom: 10px !important;
}

.u-ml10 {
  margin-left: 10px !important;
}

.u-pl10 {
  padding-left: 10px !important;
}

.u-mt15 {
  margin-top: 15px !important;
}

.u-pt15 {
  padding-top: 15px !important;
}

.u-mr15 {
  margin-right: 15px !important;
}

.u-pr15 {
  padding-right: 15px !important;
}

.u-mb15 {
  margin-bottom: 15px !important;
}

.u-pb15 {
  padding-bottom: 15px !important;
}

.u-ml15 {
  margin-left: 15px !important;
}

.u-pl15 {
  padding-left: 15px !important;
}

.u-mt20 {
  margin-top: 20px !important;
}

.u-pt20 {
  padding-top: 20px !important;
}

.u-mr20 {
  margin-right: 20px !important;
}

.u-pr20 {
  padding-right: 20px !important;
}

.u-mb20 {
  margin-bottom: 20px !important;
}

.u-pb20 {
  padding-bottom: 20px !important;
}

.u-ml20 {
  margin-left: 20px !important;
}

.u-pl20 {
  padding-left: 20px !important;
}

.u-mt25 {
  margin-top: 25px !important;
}

.u-pt25 {
  padding-top: 25px !important;
}

.u-mr25 {
  margin-right: 25px !important;
}

.u-pr25 {
  padding-right: 25px !important;
}

.u-mb25 {
  margin-bottom: 25px !important;
}

.u-pb25 {
  padding-bottom: 25px !important;
}

.u-ml25 {
  margin-left: 25px !important;
}

.u-pl25 {
  padding-left: 25px !important;
}

.u-mt30 {
  margin-top: 30px !important;
}

.u-pt30 {
  padding-top: 30px !important;
}

.u-mr30 {
  margin-right: 30px !important;
}

.u-pr30 {
  padding-right: 30px !important;
}

.u-mb30 {
  margin-bottom: 30px !important;
}

.u-pb30 {
  padding-bottom: 30px !important;
}

.u-ml30 {
  margin-left: 30px !important;
}

.u-pl30 {
  padding-left: 30px !important;
}

.u-mt35 {
  margin-top: 35px !important;
}

.u-pt35 {
  padding-top: 35px !important;
}

.u-mr35 {
  margin-right: 35px !important;
}

.u-pr35 {
  padding-right: 35px !important;
}

.u-mb35 {
  margin-bottom: 35px !important;
}

.u-pb35 {
  padding-bottom: 35px !important;
}

.u-ml35 {
  margin-left: 35px !important;
}

.u-pl35 {
  padding-left: 35px !important;
}

.u-mt40 {
  margin-top: 40px !important;
}

.u-pt40 {
  padding-top: 40px !important;
}

.u-mr40 {
  margin-right: 40px !important;
}

.u-pr40 {
  padding-right: 40px !important;
}

.u-mb40 {
  margin-bottom: 40px !important;
}

.u-pb40 {
  padding-bottom: 40px !important;
}

.u-ml40 {
  margin-left: 40px !important;
}

.u-pl40 {
  padding-left: 40px !important;
}

.u-mt45 {
  margin-top: 45px !important;
}

.u-pt45 {
  padding-top: 45px !important;
}

.u-mr45 {
  margin-right: 45px !important;
}

.u-pr45 {
  padding-right: 45px !important;
}

.u-mb45 {
  margin-bottom: 45px !important;
}

.u-pb45 {
  padding-bottom: 45px !important;
}

.u-ml45 {
  margin-left: 45px !important;
}

.u-pl45 {
  padding-left: 45px !important;
}

.u-mt50 {
  margin-top: 50px !important;
}

.u-pt50 {
  padding-top: 50px !important;
}

.u-mr50 {
  margin-right: 50px !important;
}

.u-pr50 {
  padding-right: 50px !important;
}

.u-mb50 {
  margin-bottom: 50px !important;
}

.u-pb50 {
  padding-bottom: 50px !important;
}

.u-ml50 {
  margin-left: 50px !important;
}

.u-pl50 {
  padding-left: 50px !important;
}

.u-mt55 {
  margin-top: 55px !important;
}

.u-pt55 {
  padding-top: 55px !important;
}

.u-mr55 {
  margin-right: 55px !important;
}

.u-pr55 {
  padding-right: 55px !important;
}

.u-mb55 {
  margin-bottom: 55px !important;
}

.u-pb55 {
  padding-bottom: 55px !important;
}

.u-ml55 {
  margin-left: 55px !important;
}

.u-pl55 {
  padding-left: 55px !important;
}

.u-mt60 {
  margin-top: 60px !important;
}

.u-pt60 {
  padding-top: 60px !important;
}

.u-mr60 {
  margin-right: 60px !important;
}

.u-pr60 {
  padding-right: 60px !important;
}

.u-mb60 {
  margin-bottom: 60px !important;
}

.u-pb60 {
  padding-bottom: 60px !important;
}

.u-ml60 {
  margin-left: 60px !important;
}

.u-pl60 {
  padding-left: 60px !important;
}

html {
  overflow-y: scroll;
}

body {
  color: #3e3a39;
  font-size: 16px;
  line-height: 1.6;
  font-family: "Poppins","MFW-PAotoGothicStdN-Regular",sans-serif;
  font-weight: 500;
  letter-spacing: .001em;
  -webkit-text-size-adjust: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

.l-wrapper {
  overflow: hidden;
}

.l-footer {
  padding: 120px 0 50px;
  text-align: center;
  background: #e2e2e2;
}

.l-footer__copyright {
  font-size: 12px;
  line-height: 1;
  margin-top: 65px;
}

.c-headingStyle1 {
  position: relative;
  line-height: 1;
  margin-bottom: 70px;
}

.c-headingStyle1 .en {
  display: block;
  opacity: .2;
  color: #797979;
  font-size: 71px;
  font-weight: bold;
}

.c-headingStyle1 .ja {
  position: absolute;
  left: 0;
  bottom: 6px;
  font-size: 25px;
  font-family: "あおとゴシック M","Aoto Gothic Medium",sans-serif;
}

#index .logo {
  line-height: 1;
  max-width: 363px;
}

#index .sec_hero {
  height: 120vh;
  background: url(/assets/img/index/bg.png) no-repeat center/cover;
}

#index .sec_hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100vh;
  height: calc(var(--vh, 1vh)*100);
}

#index .sec_hero__txt1 {
  font-size: 26px;
  font-family: "MFW-PAotoGothicStdN-Medium";
  line-height: 60px;
  margin-top: 50px;
  text-align: center;
}

#index .sec_about {
  width: 180%;
  margin: -200px -40% -6.5vw;
  padding: 250px 0 25vw;
  position: relative;
  z-index: 1;
}

#index .sec_about:before {
  z-index: -1;
  content: "";
  position: absolute;
  inset: 0;
  background: #f3f4f8;
  -webkit-filter: blur(2.5vw);
  filter: blur(2.5vw);
  background: linear-gradient(0deg, rgb(243, 244, 248) 0%, rgb(242, 243, 247) 100%);
}

#index .sec_about__txt1 {
  font-size: 22px;
  line-height: 68px;
  text-align: center;
}

#index .sec_about__txt2 {
  font-size: 22px;
  line-height: 68px;
  text-align: center;
  margin-top: 40px;
}

#index .sec_movie {
  position: relative;
}

#index .sec_movie:after {
  content: "";
  display: block;
  position: absolute;
  width: 180%;
  height: 15vw;
  left: -40%;
  z-index: 10;
  bottom: -8.5vw;
  -webkit-filter: blur(2.5vw);
  filter: blur(2.5vw);
  background: #f3f4f8;
  background: linear-gradient(0deg, rgb(243, 244, 248) 0%, rgb(242, 243, 247) 100%);
}

#index .sec_movie__inner {
  height: 58vw;
  overflow: hidden;
}

#index .sec_movie video {
  width: 140%;
  margin-left: -20%;
  margin-top: -10.5vw;
}

#index .sec_company {
  padding: 300px 0 200px;
}

#index .sec_company__inner {
  width: 1100px;
  margin: 0 auto;
}

#index .sec_company__table-row {
  padding: 15px 0;
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(69,69,69,.3);
}

#index .sec_company__table-row dt {
  width: 285px;
  font-family: "MFW-PAotoGothicStdN-Medium";
}

#index .sec_gallery {
  padding: 0 0 200px;
}

#index .sec_gallery__inner {
  width: 1100px;
  margin: 0 auto;
}

#index .sec_gallery__iframe {
  padding: 0 100px;
}

#index .sec_gallery__iframe iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 666/413;
}

#index .sec_contact {
  color: #fff;
  height: 654px;
  display: flex;
  align-items: center;
  background: #767676 url(/assets/img/index/contact_bg.png) no-repeat center/auto 100%;
}

#index .sec_contact__inner {
  width: 1100px;
  margin: 0 auto;
}

#index .sec_contact .c-headingStyle1 .en {
  color: #fff;
}

#index .sec_contact__email {
  color: #000;
  font-size: 27px;
  text-align: center;
  margin-top: 90px;
}

#index .sec_contact__email a {
  width: 394px;
  height: 94px;
  border-radius: 50px;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 1px solid #fff;
  transition: .3s;
}

#index .sec_contact__email a:hover {
  color: #fff;
  background: #767676;
}

#index .sec_contact__tel {
  font-size: 27px;
  text-align: center;
  margin-top: 20px;
}

#index .sec_contact__tel span {
  padding-bottom: 10px;
  border-bottom: 1px solid #fff;
}

@media (min-width: 768px) {
  .u-hidden-up-md {
    display: none !important;
    visibility: hidden;
  }

  a[href^="tel:"] {
    pointer-events: none;
    color: inherit;
    cursor: default;
    text-decoration: none;
  }
}

@media (min-width: 1024px) {
  .u-hidden-lg {
    display: none !important;
    visibility: hidden;
  }

  .u-hidden-up-lg {
    display: none !important;
    visibility: hidden;
  }
}

@media (max-width: 1023.98px) {
  .u-hidden-down-md {
    display: none !important;
    visibility: hidden;
  }
}

@media (max-width: 767.98px) {
  .u-hidden-sm {
    display: none !important;
    visibility: hidden;
  }

  .u-hidden-down-sm {
    display: none !important;
    visibility: hidden;
  }

  body {
    font-size: 15px;
    font-size: 4vw;
  }

  .l-footer {
    padding: 18.6666666667vw 0 5.3333333333vw;
  }

  .l-footer__logo {
    width: 48%;
    margin: 0 auto;
  }

  .l-footer__copyright {
    font-size: 12px;
    font-size: 3.2vw;
    margin-top: 10.6666666667vw;
  }

  .c-headingStyle1 {
    margin-bottom: 10.6666666667vw;
  }

  .c-headingStyle1 .en {
    font-size: 58px;
    font-size: 15.4666666667vw;
  }

  .c-headingStyle1 .ja {
    font-size: 20px;
    font-size: 5.3333333333vw;
    bottom: .5333333333vw;
  }

  #index .logo {
    max-width: 62%;
  }

  #index .sec_hero {
    height: calc(100vh + 7vw);
  }

  #index .sec_hero__txt1 {
    font-size: 22px;
    font-size: 5.8666666667vw;
    line-height: 10.6666666667vw;
    margin-top: 10.6666666667vw;
  }

  #index .sec_about {
    margin: -18vw -40% -6.5vw;
    padding: 21.3333333333vw 0 26.6666666667vw;
  }

  #index .sec_about:before {
    -webkit-filter: blur(3vw);
    filter: blur(3vw);
  }

  #index .sec_about__txt1 {
    font-size: 19px;
    font-size: 5.0666666667vw;
    line-height: 10.6666666667vw;
  }

  #index .sec_about__txt2 {
    font-size: 19px;
    font-size: 5.0666666667vw;
    line-height: 10.6666666667vw;
    margin-top: 10.6666666667vw;
  }

  #index .sec_movie__inner {
    height: 74.5vw;
  }

  #index .sec_movie video {
    width: 180%;
    margin-left: -40%;
    margin-top: -15vw;
  }

  #index .sec_company {
    padding: 29.3333333333vw 0 21.3333333333vw;
  }

  #index .sec_company__inner {
    width: 90%;
  }

  #index .sec_company__table-row {
    padding: 4vw 0;
    line-height: 5.0666666667vw;
  }

  #index .sec_company__table-row dt {
    width: 30.6666666667vw;
  }

  #index .sec_company__table-row dd {
    width: calc(100% - 30.6666666667vw);
  }

  #index .sec_gallery {
    padding: 0 0 21.3333333333vw;
  }

  #index .sec_gallery__inner {
    width: 90%;
  }

  #index .sec_gallery__iframe {
    padding: 0;
  }

  #index .sec_contact {
    height: 126.9333333333vw;
    background: #767676;
  }

  #index .sec_contact__inner {
    width: 90%;
  }

  #index .sec_contact__email {
    font-size: 20px;
    font-size: 5.3333333333vw;
    line-height: 11.7333333333vw;
    margin-top: 16vw;
  }

  #index .sec_contact__email a {
    width: 74.6666666667vw;
    height: 18.6666666667vw;
  }

  #index .sec_contact__tel_sp {
    color: #000;
    text-align: center;
    font-size: 20px;
    font-size: 5.3333333333vw;
    line-height: 11.7333333333vw;
    margin-top: 8vw;
  }

  #index .sec_contact a {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 74.6666666667vw;
    height: 18.6666666667vw;
    border-radius: 9.3333333333vw;
    background: #fff;
    border: 1px solid #fff;
  }
}

@media (min-width: 768px)and (max-width: 1023.98px) {
  .u-hidden-md {
    display: none !important;
    visibility: hidden;
  }
}

@media print {
  *,
  *::before,
  *::after {
    background: rgba(0,0,0,0) !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
  }

  a,
  a:visited {
    text-decoration: underline;
  }

  tr,
  img {
    page-break-inside: avoid;
  }

  img {
    max-width: 100% !important;
  }

  p,
  h2,
  h3 {
    orphans: 3;
    widows: 3;
  }

  h2,
  h3 {
    page-break-after: avoid;
  }
}
/*# sourceMappingURL=styles.css.map */