@charset 'UTF-8';

/**
 * Layout Settings
 * ================================================================================
 * Table of Contents:
 *
 * Wrapper
 * Main
 * Header
 * Footer
 * Container
 * Loading
 * Floating
 * ================================================================================
 */



/**
 * ================================================================================
 * Wrapper
 * ================================================================================
 */

.l-wrapper {
  min-width: 1280px;
  overflow-x: hidden;
}

@media all and (max-width: 767px) {
  .l-wrapper {
    min-width: 100%;
  }
}



/**
 * ================================================================================
 * Header
 * ================================================================================
 */

.l-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  min-width: 1280px;
}

.l-header-container {
  height: 100%;
}

@media all and (max-width: 767px) {
  .l-header {
    min-width: 100%;
  }
}


/**
 * Header Logo
 * -------------------------------
 */

.l-header-logo {
  position: absolute;
  top: 3.7rem;
  left: 3.7rem;
}

.l-header-logo img {
  width: 30.0rem;
}

@media all and (max-width: 767px) {
  .l-header-logo {
    top: calc(3.7rem * 0.5);
    left: calc(3.7rem * 0.5);
  }

  .l-header-logo img {
    width: calc(30.0rem * 0.4);
  }
}


/**
 * Header Contact
 * -------------------------------
 */

.l-header-contact {
  display: flex;
  position: absolute;
  top: 3.7rem;
  right: 3.7rem;
}

.l-header-contact-item {
  margin-left: 1.6rem;
}

.l-header-contact-item > * {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 31.5rem;
  height: 7.2rem;
  border-radius: 1.2rem;
}

.l-header-contact-item > * > span {
  display: inline-block;
  position: relative;
  padding-left: 5.8rem;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 1.2;
}

.l-header-contact-item > * > span::before {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 3.5rem;
  height: 2.4rem;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  content: '';
}

/* -- .l-header-contact-download -- */
.l-header-contact-download > * {
  background: linear-gradient(90deg, rgba(219,231,233,1) 10%, rgba(191,220,224,1) 100%);
}

.l-header-contact-download > * > span::before {
  background-image: url('../../../assets/common/img/icon_check_grad_gr.svg');
}

/* -- .l-header-contact-inquiry -- */
.l-header-contact-inquiry > * {
  background: linear-gradient(90deg, rgba(157,219,217,1) 0%, rgba(89,188,203,1) 100%);
}

.l-header-contact-inquiry > * > span::before {
  background-image: url('../../../assets/common/img/icon_check_wh.svg');
}

@media all and (max-width: 767px) {
  .l-header-contact {
    top: calc(3.7rem * 0.5);
    right: calc(3.7rem * 0.5);
  }

  .l-header-contact-item {
    margin-left: calc(1.6rem * 0.45);
  }

  .l-header-contact-item > * {
    width: calc(31.5rem * 0.5);
    height: calc(7.2rem * 0.5);
    border-radius: calc(1.2rem * 0.5);
  }

  .l-header-contact-item > * > span {
    padding-left: calc(5.8rem * 0.5);
    font-size: calc(2.6rem * 0.5);
  }

  .l-header-contact-item > * > span::before {
    width: calc(3.5rem * 0.5);
    height: calc(2.4rem * 0.5);
  }
}



/**
 * ================================================================================
 * Main
 * ================================================================================
 */

.l-main {
  position: relative;
  z-index: 1;
  padding-top: 30.0rem;
  padding-bottom: 20.0rem;
}

@media all and (max-width: 767px) {
  .l-main {
    padding-top: calc(30.0rem * 0.4);
    padding-bottom: calc(20.0rem * 0.4);
  }
}



/**
 * ================================================================================
 * Footer
 * ================================================================================
 */

.l-footer {
  padding-top: 8.0rem;
  background-color: #eceded;
}

.l-footer .l-container {
  display: flex;
  padding: 12.0rem 13.0rem 17.5rem 13.0rem;
}

.l-footer-container > * {
  flex: 0 0 auto;
  width: auto;
}

@media all and (max-width: 767px) {
  .l-footer {
    padding-top: 0;
  }

  .l-footer .l-container {
    display: block;
    padding: calc(12.0rem * 0.6) 3.0rem calc(17.5rem * 0.45) 3.0rem;
  }
}


/**
 * Footer Company
 * -------------------------------
 */

.l-footer-company-logo > a {
  display: block;
  width: 42.4rem;
}

.l-footer-company-info {
  margin-top: 5.0rem;
  font-size: 2.2rem;
  letter-spacing: 0.2em;
}

.l-footer-company-info .c-comments {
  margin-top: 2.0rem;
  font-size: 1.8rem;
  letter-spacing: 0.15em;
}

@media all and (max-width: 767px) {
  .l-footer-company-logo > a {
    width: calc(42.4rem * 0.45);
  }

  .l-footer-company-info {
    margin-top: calc(5.0rem * 0.45);
    font-size: calc(2.2rem * 0.65);
  }

  .l-footer-company-info .c-comments {
    margin-top: calc(2.0rem * 0.55);
    font-size: calc(1.8rem * 0.65);
  }
}


/**
 * Footer Other
 * -------------------------------
 */

.l-footer-other {
  margin-left: auto;
}

.l-footer-other-inner {
  display: flex;
  height: 100%;
  flex-direction: column;
}

/* -- .l-footer-contact -- */
.l-footer-contact > a {
  display: inline-block;
  position: relative;
  padding-right: 8.0rem;
  font-size: 3.0rem;
  letter-spacing: 0.15em;
  line-height: 1.4;
}

.l-footer-contact > a::after {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 8.8rem;
  height: 8.8rem;
  background-image: url('../../../assets/common/img/footer_contact_icon.svg');
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  content: '';
}

.l-footer-business {
  margin-top: auto;
  line-height: 1.2;
}

.l-footer-business-head {
  display: block;
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 0.2em;
}

.l-footer-business-body {
  display: flex;
  margin-top: 3.0rem;
}

.l-footer-business-list {
  width: 50%;
}

.l-footer-business-list-item {
  position: relative;
  padding-left: 3.5rem;
  margin-top: 2.0rem;
  font-size: 2.2rem;
  letter-spacing: 0.15em;
}

.l-footer-business-list-item:nth-of-type(1) {
  margin-top: 0;
}

.l-footer-business-list-item::before {
  position: absolute;
  top: 0.6em;
  left: 0;
  width: 1.1rem;
  height: 0.3rem;
  background-color: #000;
  content: '';
}

@media all and (max-width: 767px) {
  .l-footer-other {
    margin-left: 0;
    margin-top: 4.0rem;
  }

  .l-footer-other-inner {
    display: block;
    height: auto;
  }

  /* -- .l-footer-contact -- */
  .l-footer-contact > a {
    padding-right: calc(8.0rem * 0.55);
    font-size: calc(3.0rem * 0.55);
  }

  .l-footer-contact > a::after {
    width: calc(8.8rem * 0.55);
    height: calc(8.8rem * 0.55);
  }

  .l-footer-business {
    margin-top: 4.0rem;
  }

  .l-footer-business-head {
    font-size: calc(3.2rem * 0.5);
  }

  .l-footer-business-body {
    margin-top: calc(3.0rem * 0.5);
  }

  .l-footer-business-list-item {
    padding-left: calc(3.5rem * 0.5);
    margin-top: calc(2.0rem * 0.5);
    font-size: calc(2.2rem * 0.5);
  }

  .l-footer-business-list-item::before {
    width: calc(1.1rem * 0.5);
    height: calc(0.3rem * 0.5);
  }
}



/**
 * ================================================================================
 * Container
 * ================================================================================
 */

.l-container {
  position: relative;
  width: 100%;
  max-width: 192.0rem;
  margin-right: auto;
  margin-left: auto;
  padding-left: 10.0rem;
  padding-right: 10.0rem;
}

.l-container.is-clear {
  max-width: 100%;
  padding-left: 0;
  padding-right: 0;
}

@media all and (max-width: 767px) {
  .l-container {
    min-width: 100%;
    padding-left: 3.0rem;
    padding-right: 3.0rem;
  }
}

