@media only screen and (max-width: 767.98px) {
  .header-site {
    height: 60px;
    padding: 0 0.3rem;
    background: #ebebeb;
  }
  .header-site .header-logo {
    width: 85px;
  }
  .header-site .overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    z-index: 1;
    transition: 0.26s;
    opacity: 0;
    pointer-events: none;
  }
  .header-site .overlay.is-show {
    opacity: 1;
    pointer-events: auto;
  }
  .header-site .header-navigation {
    position: fixed;
    width: 2.95rem;
    height: 100vh;
    top: 0;
    right: 0;
    display: none;
    z-index: 50;
    background: #3d4145;
  }
  .header-site .navigation-inner {
    width: 100%;
    height: 100%;
    overflow-y: auto;
    padding: 0 0.4rem 0.8rem;
  }
  .header-site .navigation-list {
    display: block;
    z-index: 2;
    position: relative;
    padding: 60px 0 30px;
    font-size: 0.14rem;
    margin: 0 auto 0.42rem;
    border-bottom: 0.01rem solid rgba(255, 255, 255, 0.5);
  }
  .header-site .navigation-list .navigation-item {
    margin-bottom: 0.3rem;
  }
  .header-site .navigation-link {
    font-size: 0.14rem;
    text-align: left;
    display: inline-block;
    color: #fff;
    letter-spacing: 0.17em;
  }
  .header-site .navigation-link.is-external {
    padding-right: 0.18rem;
  }
  .header-site .navigation-link.is-external::before {
    top: 0.05rem;
    width: 0.12rem;
    height: 0.12rem;
    background-image: url(../svg/ico_external_white-2.svg);
  }
  .header-site .off {
    display: none;
  }
  .header-site .button-menu {
    width: 24px;
    height: 60px;
    display: block;
    position: absolute;
    cursor: pointer;
    z-index: 60;
    right: 0.3rem;
    top: 0;
  }
  .header-site .button-menu .humbarger-line {
    display: block;
    width: 24px;
    position: absolute;
    border-bottom: 1px solid #101010;
    left: 50%;
    -ms-transform: translateX(-50%);
        transform: translateX(-50%);
    transition: all 0.3s;
  }
  .header-site .button-menu .humbarger-line:nth-child(1) {
    top: calc(50% - 10px);
  }
  .header-site .button-menu .humbarger-line:nth-child(2) {
    top: 50%;
  }
  .header-site .button-menu .humbarger-line:nth-child(3) {
    top: calc(50% + 10px);
  }
  .header-site .button-menu.is-active .humbarger-line {
    border-bottom-color: #fff !important;
  }
  .header-site .button-menu.is-active .humbarger-line:nth-of-type(1) {
    -ms-transform: translateX(-50%) rotate(-45deg);
        transform: translateX(-50%) rotate(-45deg);
    top: 30px;
  }
  .header-site .button-menu.is-active .humbarger-line:nth-of-type(2) {
    opacity: 0;
  }
  .header-site .button-menu.is-active .humbarger-line:nth-of-type(3) {
    -ms-transform: translateX(-50%) rotate(45deg);
        transform: translateX(-50%) rotate(45deg);
    top: 30px;
  }
  .header-site .social-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
        justify-content: space-between;
    list-style-type: none;
    margin: 0 auto 0.44rem;
    padding: 0;
    width: 0.84rem;
  }
  .header-site .social-list .social-item {
    width: 0.3rem;
  }
  .header-site .social-list .social-link {
    display: block;
  }
  .header-site .social-list .social-image {
    width: 100%;
  }
  .header-site .header-detail .header-logo {
    margin: 0 auto;
    width: 0.96rem;
  }
  .is-body-site .header-site.has-background .button-menu > .humbarger-line {
    border-bottom-color: #000;
  }
  .is-body-site .header-site.has-background .off {
    display: none;
  }
  .is-body-site .header-site.has-background .on {
    display: block;
  }
  .is-body-site .header-site .button-menu > .humbarger-line {
    border-bottom-color: #fff;
  }
  .is-body-site .header-site .off {
    display: block;
  }
  .is-body-site .header-site .on {
    display: none;
  }
}
@media only screen and (max-width: 767.98px) {
  .footer-site {
    padding: 0.61rem 0 0.17rem;
  }
  .footer-site .footer-content {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    margin-bottom: 0.45rem;
  }
  .footer-site .footer-inner {
    padding-bottom: 0.45rem;
    border-bottom: 0.01rem solid #707070;
    margin-bottom: 0.4rem;
  }
  .footer-site .footer-logo {
    width: 1.02rem;
    margin: 0 auto;
  }
  .footer-site .footer-navigation {
    margin-bottom: 0.16rem;
  }
  .footer-site .footer-list {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -ms-flex-pack: justify;
        justify-content: space-between;
    margin-bottom: 0;
  }
  .footer-site .footer-list:nth-child(4) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "link_1 link_2" "link_3 .";
  }
  .footer-site .footer-list:nth-child(4) > li {
    width: 100%;
  }
  .footer-site .footer-list:nth-child(4) > li:nth-child(1) {
    grid-area: link_2;
  }
  .footer-site .footer-list:nth-child(4) > li:nth-child(2) {
    grid-area: link_1;
  }
  .footer-site .footer-list:nth-child(4) > li:nth-child(3) {
    grid-area: link_3;
  }
  .footer-site .footer-list li {
    width: 50%;
    margin-bottom: 0.26rem;
  }
  .footer-site .footer-list li.is-full {
    width: 100%;
  }
  .footer-site .footer-list a {
    font-size: 0.13rem;
  }
  .footer-site .footer-list a.is-external {
    padding-right: 0.2rem;
  }
  .footer-site .footer-list a.is-external::before {
    top: 0.05rem;
    width: 0.12rem;
    height: 0.12rem;
  }
  .is-iphone .footer-site .footer-list a.is-external::before {
    top: 0.06rem;
  }
  .footer-site .link-external {
    width: 100%;
    min-height: 0.5rem;
    padding: 0.04rem 0.04rem 0.05rem 0.1rem;
    margin: 0 auto 0.43rem;
  }
  .footer-site .link-external span {
    font-size: 0.12rem;
    padding-right: 0.21rem;
    letter-spacing: 0.17em;
  }
  .footer-site .link-external span::before, .footer-site .link-external span:after {
    top: 0.04rem;
    right: 0.04rem;
    width: 0.12rem;
    height: 0.12rem;
  }
  .footer-site .footer-social {
    width: 1.74rem;
    margin: 0 auto;
  }
  .footer-site .social-text {
    font-size: 0.13rem;
    margin-top: 0.03rem;
  }
  .footer-site .social-list {
    width: 0.73rem;
  }
  .footer-site .social-list li {
    width: 0.3rem;
  }
  .footer-site .social-list a {
    display: block;
  }
  .footer-site .social-list img {
    width: 100%;
  }
  .footer-site .footer-copyright {
    margin-left: -0.1rem;
  }
  .footer-site .footer-copyright small {
    font-size: 0.1rem;
    line-height: 2;
    display: block;
  }
  .footer-site .footer-copyright .copyright-logo {
    margin-bottom: 0.03rem;
    width: 0.38rem;
    height: 0.16rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .title-primary span {
    padding-bottom: 0.19rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .button-plus {
    width: 0.15rem;
    height: 0.15rem;
  }
  .button-plus:before, .button-plus:after {
    height: 0.08rem;
    margin: -0.04rem 0 0;
    left: 48%;
  }
  .button-primary {
    padding-left: 0.27rem;
    font-size: 0.14rem;
    line-height: 1;
  }
  .button-primary::before {
    top: 0;
    width: 0.15rem;
    height: 0.15rem;
  }
  .button-tertiary {
    width: 2.3rem;
    min-height: 0.4rem;
  }
  .button-quaternary {
    display: block;
    padding: 10px 0;
    border: 1px solid #000;
    font-size: 0.14rem;
    text-align: center;
  }
  .button-quaternary::before {
    display: none;
  }
}
@media only screen and (max-width: 767.98px) {
  .news-common .news-item {
    padding-bottom: 0.46rem;
    margin-bottom: 0.52rem;
  }
  .news-common .news-item:last-child {
    margin-bottom: 0;
  }
  .news-common .news-item-image {
    width: 2.21rem;
    height: 1.37rem;
    margin: 0 auto 0.32rem;
  }
  .news-common .news-item-title {
    font-size: 0.14rem;
    margin-bottom: 0.04rem;
  }
  .news-common .news-item-text {
    font-size: 0.14rem;
    margin-bottom: 0.05rem;
    -webkit-line-clamp: 4;
  }
  .news-common .news-item-time {
    font-size: 0.12rem;
    display: block;
  }
}
@media only screen and (max-width: 767.98px) {
  .container {
    padding: 0;
  }
  .section-top-keyvisual .keyvisual-logo {
    top: calc(50% - 210px);
    left: calc(50% - 70px);
    width: 140px;
  }
  .section-top-keyvisual .keyvisual-items {
    height: 100vh;
    -ms-transform: translateY(-96px);
        transform: translateY(-96px);
  }
  .section-top-keyvisual .keyvisual-item.o-knife {
    bottom: -62px;
    left: calc(50% - 171px);
  }
  .section-top-keyvisual .keyvisual-item.o-knife .item-image {
    width: 350px;
    height: auto;
  }
  .section-top-keyvisual .keyvisual-item.o-peeler {
    bottom: 61px;
    left: calc(50% + 33px);
  }
  .section-top-keyvisual .keyvisual-item.o-peeler .item-image {
    width: 35px;
    height: auto;
  }
  .section-top-keyvisual .keyvisual-item.o-scissors {
    bottom: 51px;
    left: calc(50% + 70px);
  }
  .section-top-keyvisual .keyvisual-item.o-scissors .item-image {
    width: 31px;
    height: auto;
  }
  .section-top-keyvisual .keyvisual-item.o-grater {
    bottom: 41px;
    left: calc(50% + 115px);
  }
  .section-top-keyvisual .keyvisual-item.o-grater .item-image {
    width: 22px;
    height: auto;
  }
  .section-top-keyvisual .keyvisual-item.o-clippers {
    bottom: 104px;
    left: calc(50% + 150px);
  }
  .section-top-keyvisual .keyvisual-item.o-clippers .item-image {
    width: 14px;
    height: auto;
  }
  .section-top-keyvisual .keyvisual-copy {
    top: calc(50% - 60px);
    font-size: 0.2rem;
  }
  .section-top-keyvisual .scroll-mark {
    height: 158px;
  }
  .o-iphone .section-top-keyvisual .scroll-mark {
    bottom: 100px;
  }
  .section-top-keyvisual .keyvisual-photo.o-mountain {
    background: url(../jpg/opening_mountain-2.jpg) center center no-repeat;
    background-size: auto;
    background-position: calc(50% + 30px) calc(50% + 4px);
  }
  .section-top-keyvisual .keyvisual-photo .shadow {
    height: 345px;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0, black 100px, black 100%);
  }
}
@media only screen and (max-width: 767.98px) {
  .section-top-intro .intro-wrapper {
    padding: 150px 0;
  }
  .section-top-intro .intro-background {
    height: 3.5rem;
  }
  .section-top-intro .intro-description {
    font-size: 0.14rem;
    line-height: 2.1428571429;
    margin-bottom: 0.72rem;
  }
  .section-top-intro .intro-description p {
    margin-bottom: 0.18rem;
  }
  .section-top-intro .intro-link {
    padding: 170px 0 0;
    background-size: 800px;
  }
  .section-top-intro .intro-link a {
    font-size: 0.13rem;
    letter-spacing: 0.06em;
    width: 2.5rem;
    min-height: 0.4rem;
    padding: 0.05rem 0.2rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .section-top-product {
    padding: 1.12rem 0 0.2rem;
  }
  .section-top-product .title-primary {
    margin-bottom: 0.65rem;
  }
  .section-top-product .title-primary span {
    height: 1.35rem;
  }
  .section-top-product .product-item {
    margin-bottom: 0.8rem;
  }
  .section-top-product .product-item-image {
    width: 3.15rem;
    height: 1.75rem;
    margin-bottom: 0.26rem;
  }
  .section-top-product .product-item-title {
    margin-bottom: 0.1rem;
  }
  .section-top-product .product-item-title .is-english {
    font-size: 0.12rem;
    margin-bottom: 0.09rem;
  }
  .section-top-product .product-item-title .is-japan {
    font-size: 0.2rem;
  }
  .section-top-product .product-item-text {
    margin-bottom: 0.2rem;
    font-size: 0.14rem;
  }
  .section-top-product .button-tertiary {
    width: 100%;
    font-size: 0.13rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .section-top-movie .video-overlay:before {
    margin: -0.23rem 0 0 -0.23rem;
    width: 0.46rem;
    height: 0.46rem;
    background: url(../svg/ico_play.svg) no-repeat center center/100% auto;
  }
}
@media only screen and (max-width: 767.98px) {
  .background-decor {
    height: 2.6rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .section-top-news {
    padding: 0.99rem 0 0.72rem;
  }
  .section-top-news .title-primary {
    margin-bottom: 0.36rem;
  }
  .section-top-news .title-primary span {
    height: 1.35rem;
  }
  .section-top-news .news-common {
    margin-bottom: 0.14rem;
  }
}
@media only screen and (max-width: 767.98px) {
  .section-top-about-us {
    padding: 0.68rem 0 0.43rem;
  }
  .section-top-about-us .about-title {
    margin: 0 -0.15rem 0.26rem;
    letter-spacing: 0.06em;
  }
  .section-top-about-us .list-button {
    width: 3.15rem;
    margin: 0 auto;
  }
  .section-top-about-us .list-button li {
    margin-bottom: 0.25rem;
  }
  .section-top-about-us .button-secondary {
    width: 100%;
    min-height: 0.54rem;
  }
  .section-top-about-us .button-secondary span {
    padding-right: 0.2rem;
    font-size: 0.15rem;
  }
  .section-top-about-us .button-secondary span::before, .section-top-about-us .button-secondary span:after {
    top: 0.06rem;
    right: 0;
    width: 0.12rem;
    height: 0.12rem;
  }
}
/*# sourceMappingURL=top.css.map */