@charset 'UTF-8';

/**
 * Layout Settings
 * ================================================================================
 * Table of Contents:
 *
 * Header
 * Main
 * Tagline
 * Footer
 * Container
 * ================================================================================
 */



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

.l-header {
  position: relative;
  width: 160.0rem;
  height: 10.5rem;
  margin: 0 auto;
  text-align: center;
}

@media all and (max-width: 767px) {
  .l-header {
    display: none;
  }
}


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

.l-header-logo {
  position: absolute;
  top: 50%;
  left: 27.0rem;
  transform: translateY(-50%);
}

.l-header-logo > * {
  display: block;
  width: 27.0rem;
  height: 3.7rem;
}


/**
 * Header Global Navigation
 * -------------------------------
 */

.l-header-gnav {
  display: flex;
  align-items: center;
  position: absolute;
  /* right: 2.5rem; */
  left: 72.0rem;
  height: 100%;
}

.l-header-gnav-list {
  display: flex;
  align-items: center;
  height: 100%;
}

.l-header-gnav-list-item {
  display: inline-flex;
  height: 100%;
}

.l-header-gnav-list-item:nth-of-type(1) {
  width: 11.5rem;
}
.l-header-gnav-list-item:nth-of-type(2) {
  width: 9.5rem;
}
.l-header-gnav-list-item:nth-of-type(3) {
  width: 17.0rem;
}

.l-header-gnav-list-item-label {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  position: relative;
}

@media all and (min-width: 768px) {
  .l-header-gnav {
    display: flex !important;
  }
}



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

.l-main {
  position: relative;
  z-index: 1;
  min-width: 160.0rem;
  overflow-x: hidden;
  text-align: center;
}

.l-caution {
  display: none;
}

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

  .l-main img {
    display: none;
  }

  .l-caution {
    display: inline-block;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding: 2.5rem 3.5rem;
    background-color: #ff0000;
    color: #fff;
    font-weight: 700;
    font-size: 1.8rem;
  }
}


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

.l-footer {
  width: 160.0rem;
  margin: 0 auto;
  text-align: center;
}

@media all and (max-width: 767px) {
  .l-footer {
    display: none;
  }
}
