/*----------------------------------
	Common HTML elements and more 
------------------------------------*/
html {
  overflow-x: hidden;
}

html, html a, body {
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
}

html {
    font-size: 1rem;
    scroll-behavior: smooth;
    scroll-padding-top: calc((var(--headerHeight, 95px)) + 20px);
}

body {
  font-size: 1rem;
  color: #222324;
  line-height: 1.6;
  background-color: #fff;
  height: 100%;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-weight: 400;
  font-family: "Noto Sans JP", "sans-serif";
  line-height: 1.2;
  color: #242424;
  margin-top: 0;
  margin-bottom: .5rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-bottom: 0.75rem;
}

h1 {
  font-size: 2.5rem;
}

h2 {
  font-size: 3.45rem;
  letter-spacing: 0.01em;
  font-feature-settings: "palt";
}
h2.sub::before {
	content: attr(data-en);
	display: block;
	color: #37ba37;
	font-size: 16px;
    font-weight: 500;
    margin-bottom: 15px;
    letter-spacing: 0.02em
}

@media (max-width: 540px) {
    h2 {
      font-size: 2.5rem;
    }
    h2.sub::before {
        font-size: 14px;
    }
}

h3 {
  font-size: 1.75rem;
}

h4 {
  font-size: 1.5rem;
}

h5 {
  font-size: 1.25rem;
}

h6 {
  font-size: 1rem;
}

em,
li {
  font-size: 1rem;
  font-weight: 300;
  color: #242424;
}

em > a,
li > a {
  color: #242424;
}

em > a:hover,
li > a:hover {
    color: #13b1cd;
}

label {
  font-size: 0.8125rem;
  font-weight: 700;
  color: #242424;
  margin-bottom: .25rem;
}

i {
  line-height: 1;
}

/* Links */
a {
  color: #37ba37;
  text-decoration: none;
}

a:focus, a:hover {
  color: #13b1cd;
  text-decoration: none;
}

a:focus {
  outline: none;
}

/*----------------------------------
  global.css
------------------------------------*/
.g-container--sm {
    padding-right: .9375rem;
    padding-left: .9375rem;
    margin-right: auto;
    margin-left: auto;
}

@media (min-width: 48em) {
    .g-container--sm {
        /* width: 750px; */
        width: 850px;
    }
}

.g-padding-y-5--xs {
    padding-top: 0.3125rem;
    padding-bottom: 0.3125rem;
}

@media (min-width: 34em) {
    .g-padding-y-45--sm {
        padding-top: 2.8125rem;
        padding-bottom: 2.8125rem;
    }
}

.g-text-center--xs {
    text-align: center;
}

@media (min-width: 62em) {
    .g-promo-section__img-right--lg {
        position: absolute;
        top: 0;
        right: 0;
    }
}

@media (min-width: 48em) {
    .g-height-100-percent--md {
        /* height: 100%; */
        height: 90%;
    }
}

@media (min-width: 48em) {
    .g-hor-centered-row--md {
        width: 100%;
        display: table;
    }
}

.g-row-col--5 {
    margin-right: -.3125rem;
    margin-left: -.3125rem;
}

.g-row-col--5 > [class*="col-"] {
    padding-left: .3125rem;
    padding-right: .3125rem;
}

.g-margin-b-60--xs {
    margin-bottom: 3.75rem;
}

@media (min-width: 62em) {
    .g-display-table--lg {
        display: table;
    }
}

@media (min-width: 48em) {
    .g-margin-b-0--md {
        margin-bottom: 0rem;
    }
}

@media (min-width: 48em) {
    .g-hor-centered-row--md .g-hor-centered-row__col {
        display: table-cell;
        float: none;
        vertical-align: middle;
    }
}

@media (min-width: 48em) {
    .g-text-right--md {
        text-align: right;
    }
}

/* Swiper Wrapper */
.g-bg-position--center {
    background-size: cover !important;
    background-position: center center !important;
}
.g-fullheight--xs {
    height: 100vh;
}
.g-ver-center--xs {
    position: absolute;
    top: 50%;
    left: 5%;
    right: 0;
    -webkit-transform: translate3d(0, -50%, 0);
    transform: translate3d(0, -50%, 0);
}
.g-margin-b-30--xs {
    margin-bottom: 1.875rem;
}
.g-radius--circle {
    border-radius: 50% !important;
}
.g-color--white {
    color: #fff !important;
}
.g-padding-x-15--xs {
    padding-left: 0.9375rem;
    padding-right: 0.9375rem;
}
.g-font-size-13--xs {
    font-size: 0.8125rem !important;
}
.text-uppercase {
    text-transform: uppercase;
}

@media (min-width: 34em) {
    .g-margin-t-0--sm {
        margin-top: 0rem;
    }
}

@media (min-width: 48em) {
    .g-margin-b-70--md {
        margin-bottom: 4.375rem;
    }
}

@media (min-width: 62em) {
    .g-font-size-50--lg {
        font-size: 3.125rem !important;
    }
}

/* Grid */
/*@media (min-width: 1200px) {
    .container {
        width: 1170px;
    }
}
@media (min-width: 992px) {
    .container {
        width: 970px;
    }
}
@media (min-width: 768px) {
    .container {
        width: 750px;
    }
}*/


/*----------------------------------
  Icons
------------------------------------*/
.s-icon {
  position: relative;
  display: inline-block;
  /*text-align: center;*/
  vertical-align: middle;
  transition-duration: 300ms;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
}

.s-icon:focus, .s-icon:hover {
  text-decoration: none;
  transition-duration: 300ms;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
}

.ti-control-play:before {
    content: "\e6ad";
    position: absolute;
    top: 50%;
    left: 18px;
    transform: translateY(-50%);
}

/* Sizes
------------------------------ */
.s-icon--sm {
  width: 2.5rem;
  height: 2.5rem;
  font-size: 0.8125rem;
  padding: 0.6875rem;
}

.s-icon--md {
  width: 3.125rem;
  height: 3.125rem;
  font-size: 1.125rem;
  padding: 0.75rem;
}

.s-icon--lg {
  width: 3.5rem;
  height: 3.5rem;
  font-size: 1.625rem;
  /*padding: 0.5625rem 1rem;*/
}

/* Styles
------------------------------ */
.s-icon--white-brd {
  color: #fff;
  background: transparent;
  border-width: 0.0625rem;
  border-style: solid;
  border-color: #fff;
  line-height: 1.4;
}

.s-icon--white-brd:focus, .s-icon--white-brd:hover {
  color: #fff;
  background: #37ba37;
  border-color: #37ba37;
}

.s-icon--white-bg {
  color: #37ba37;
  background: #fff;
  border-width: 0.0625rem;
  border-style: solid;
  border-color: #fff;
  line-height: 1.4;
}

.s-icon--white-bg:focus, .s-icon--white-bg:hover {
  color: #13b1cd;
  background: #fff;
  border-color: #fff;
}

.s-icon--primary-brd {
  color: #13b1cd;
  background: transparent;
  border-width: 0.0625rem;
  border-style: solid;
  border-color: #13b1cd;
  line-height: 1.4;
}

.s-icon--primary-brd:focus, .s-icon--primary-brd:hover {
  color: #fff;
  background: #13b1cd;
  border-color: #13b1cd;
}

.s-icon--primary-bg {
  color: #fff;
  background: #13b1cd;
  line-height: 1.6;
}

/*----------------------------------
  Scroll To Section
------------------------------------*/
.s-scroll-to-section-v1--bc {
  position: absolute;
  left: 50%;
  bottom: 0.625rem;
  z-index: 1;
  -webkit-transform: translate3d(-50%, 0, 0);
  transform: translate3d(-50%, 0, 0);
  text-align: center;
}

/*----------------------------------
  Back To Top
------------------------------------*/
.s-back-to-top {
  position: fixed;
  right: 2.125rem;
  bottom: -3.125rem;
  display: block;
  width: 1.875rem;
  height: 3rem;
  z-index: 9;
  background: #13b1cd;
  border-radius: 3.125rem;
  text-align: center;
  transition-duration: 300ms;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
}

.s-back-to-top:before {
  display: block;
  font-size: 0.75rem;
  font-style: normal;
  font-family: themify;
  color: #fff;
  line-height: 3rem;
  content: "\e627";
  transition-duration: 300ms;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.7, 1, 0.7, 1);
}

.s-back-to-top:hover {
  background: #fff;
}

.s-back-to-top:hover:before {
  color: #13b1cd;
}

.s-back-to-top:focus, .s-back-to-top:hover {
  text-decoration: none;
}

/* The button becomes visible */
.s-back-to-top.-is-visible {
  bottom: 2.125rem;
  opacity: .8;
}

.s-back-to-top.-is-visible:hover {
  opacity: 1;
}

/* If the user keeps scrolling down, the button is out of focus and becomes less visible */
.s-back-to-top.-zoom-out {
  opacity: .6;
}

/*----------------------------------
  Swiper
------------------------------------*/
.s-swiper {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.s-swiper h1,
.s-swiper h2 {
    color: #fff;
    line-height: 1.4
}

/* video
------------------------------ */
.video-box {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 100vh;
}
.video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.overlay::after {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  content: "";
  background: rgba(0, 0, 0, 0.2);
}

.video-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 30%;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3) 0%, rgba(0, 0, 0, 0) 100%);
    z-index: 1
}