@font-face {
  font-family: 'NotoSans-regular';
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.eot");
  src: url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.eot?#iefix") format("embedded-opentype"), url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.woff") format("woff"), url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Regular.ttf") format("truetype");
}

@font-face {
  font-family: 'NotoSans-bold';
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.eot");
  src: url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.eot?#iefix") format("embedded-opentype"), url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.woff") format("woff"), url("../fonts/NotoSansCJKjp/NotoSansCJKjp-Bold.ttf") format("truetype");
}

.clearfix {
  zoom: 1;
}

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

/* ============================================================================================
  TOP

  @date 2017-07-12
  @include _top

  memo:

  @mixin =========================================================================================== */
body {
  background-color: #ff0000;
}

#notfound-page {
  background: #ff0000 url("../img/common/bg_red.png") no-repeat center center fixed;
  background-size: auto 100%;
}

#blind {
  background-color: #ff0000;
}

.header__bg {
  background-color: #ff0000;
}

.container {
  padding: 97px 0;
}

.headline {
  width: 100%;
  position: relative;
  z-index: 0;
}

.headline__inner {
  width: 1300px;
  margin: 0 auto 40px auto;
  height: 104px;
  position: relative;
  border-bottom: #ffffff solid 2px;
}

.headline__name {
  font-size: 118px;
  line-height: 1.0em;
  color: #ffffff;
  font-family: 'Hind Vadodara', "NotoSans-bold", sans-serif;
  font-weight: 700;
  letter-spacing: -.02em;
  position: absolute;
  left: 0px;
  top: -22px;
  z-index: 0;
}

.detail {
  width: 100%;
  position: relative;
  z-index: 0;
  padding-bottom: 80px;
}

.detail__inner {
  width: 1300px;
  margin: 0 auto;
  color: #FFFFFF;
  margin-top: 105px;
  height: 300px;
  display: table;
  position: relative;
}

.detail__text {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
  color: #ffffff;
  letter-spacing: .05em;
  font-size: 24px;
}

@media screen and (max-width: 768px) {
  /* ============================================================================================
  SP TOP

  @date 2017-07-12
  @include sp/_top

  memo:
  padding: 70px
  padding: 18.66667vw
  @mixin =========================================================================================== */
  #notfound-page {
    background: none;
  }
  #notfound-page:before {
    content: '';
    display: block;
    position: fixed;
    left: 0px;
    top: 0px;
    z-index: -1;
    padding-bottom: -54px;
    padding-bottom: -14.4vw 0;
    width: 100%;
    height: 100%;
    background: #ff0000 url("../img/common/bg_red_sp.png") no-repeat center center;
    background-size: 100% auto;
  }
  #blind {
    background-color: #ff0000;
  }
  .container {
    padding: 50px 0;
    padding: 13.33333vw 0;
  }
  .headline {
    width: 100%;
    position: relative;
    z-index: 0;
    margin-bottom: 15px;
    margin-bottom: 4vw;
  }
  .headline__inner {
    width: 86.66%;
    margin: 0 auto;
    height: auto;
    position: relative;
    border-bottom: #ffffff solid 2px;
    border-bottom: #ffffff solid 0.53333vw;
  }
  .headline__name {
    font-size: 54px;
    font-size: 14.13333vw;
    margin-top: -10px;
    margin-top: -2.66667vw;
    padding-bottom: 5px;
    padding-bottom: 1.33333vw;
    line-height: 1.0em;
    color: #ffffff;
    font-family: 'Hind Vadodara', "NotoSans-bold", sans-serif;
    font-weight: 700;
    letter-spacing: -.02em;
    position: relative;
    left: auto;
    top: auto;
  }
  .detail {
    width: 100%;
    position: relative;
    z-index: 0;
    padding-bottom: 0;
  }
  .detail__inner {
    width: 92%;
    margin: 0 auto;
    color: #FFFFFF;
    margin-top: 0;
    height: 400px;
    height: 106.66667vw;
    display: table;
    position: relative;
  }
  .detail__text {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
    color: #ffffff;
    letter-spacing: .05em;
    font-size: 14px;
    font-size: 3.73333vw;
  }
}
