@media only print {
html,body {
    font-family: 'Noto Sans JP', Arial, Verdana, 游ゴシック, YuGothic,'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', メイリオ, Meiryo, sans-serif;
}
.nothome .u-inner {
    margin: 0 80px;
    width: auto;
}
.archive-content .main {
    float: none;
    width: auto;
}
.archive-content .side {
    float: none;
    margin-top: 50px;
    width: auto;
}
.col-right {
    float: none;
}
.col-left {
    float: none;
}
.col-img {
    text-align: center;
}
.page-about .block01 .col-txt {
    width: auto;
}
.schedule-list .col-txt {
    float: none;
    width: auto;
}
.schedule-list dd::before {
    bottom: 0;
}
.schedule-list .col-img {
    float: none;
    margin: 0 -5px -5px;
    width: auto;
}
.schedule-list .col-img img {
    height: auto;
    margin: 0.5%;
    min-width: 275px;
    width: 32%;
}
.page-about .block02 .col-txt {
    width: auto;
}
.page-about .block03 .col-txt {
    width: auto;
}
.activity-list {
    margin: 0 -2%;
}
.activity-list li {
    float: left;
    margin: 0 2% 2%;
    text-align: center;
    width: 46%;
}
.activity-list li img {
    height: auto;
    width: 100%;
}
.construction-list {
    margin: -2%;
}
.construction-list li {
    margin: 2%;
    width: 46%;
}
.construction-list li:nth-child(2n+1) {
    clear: left;
}
.construction-list li a img {
    height: auto;
    width: 100%;
}
.side-widget-wrap {
    box-sizing: border-box;
    float: left;
    width: 48%;
}
.side-widget-wrap + .side-widget-wrap {
    margin-left: 4%;
}
.side-widget-wrap + .side-widget {
    box-sizing: border-box;
    float: left;
    margin-left: 4%;
    width: 48%;
}
.outline-list li a {
    display: table;
    width: 100%;
}
.outline-list li a .num {
    display: table-cell;
    float: none;
    padding: 0;
    text-align: center;
    width: 2.5em;
}
.outline-list li a .ttl {
    display: table-cell;
    float: none;
    white-space: nowrap;
}
.outline-list li a .company {
    display: table-cell;
    float: none;
    width: 11em;
}
.btn-gearthpro img {
    height: auto;
    max-width: 100%;
}
.archive-blog .txt-data {
    width: 520px;
}
}

@supports (-webkit-touch-callout: none) {
body {
    height: -webkit-fill-available;
}
}

@media only screen and (max-width: 1189px) {
.nothome .u-inner {
    margin: 0 80px;
    width: auto;
}
.archive-content .main {
    float: none;
    width: auto;
}
.archive-content .side {
    float: none;
    margin-top: 50px;
    width: auto;
}
.col-right {
    float: none;
}
.col-left {
    float: none;
}
.col-img {
    text-align: center;
}
.page-about .block01 .col-txt {
    width: auto;
}
.schedule-list .col-txt {
    float: none;
    width: auto;
}
.schedule-list dd::before {
    bottom: 0;
}
.schedule-list .col-img {
    float: none;
    margin: 0 -5px -5px;
    width: auto;
}
.schedule-list .col-img img {
    height: auto;
    margin: 0.5%;
    min-width: 275px;
    width: 32%;
}
/*--追加--*/
.about-slide {
    max-width: 550px;
    width: 100%;
    margin: 0 auto 5px;
}
.about.block01 {
    display: block;
}
/*-------*/
.page-about .block02 .col-txt {
    width: auto;
}
.page-about .block03 .col-txt {
    width: auto;
}
.activity-list {
    margin: 0 -2%;
}
.activity-list li {
    float: left;
    margin: 0 2% 2%;
    text-align: center;
    width: 46%;
}
.activity-list li img {
    height: auto;
    width: 100%;
}
.construction-list {
    margin: -2%;
}
.construction-list li {
    margin: 2%;
    width: 46%;
}
.construction-list li:nth-child(2n+1) {
    clear: left;
}
.construction-list li a img {
    height: auto;
    width: 100%;
}
.side-widget-wrap {
    box-sizing: border-box;
    float: left;
    width: 48%;
}
.side-widget-wrap2 {
    box-sizing: border-box;
    float: right;
    width: 48%;
}
.side-widget-wrap3 {
    box-sizing: border-box;
    float: right;
    width: 48%;
}
.side-widget-wrap + .side-widget-wrap {
    margin-left: 4%;
}
.side-widget-wrap + .side-widget {
    box-sizing: border-box;
    float: left;
    margin-left: 4%;
    width: 48%;
}
.outline-list li a {
    display: table;
    width: 100%;
}
.outline-list li a .num {
    display: table-cell;
    float: none;
    padding: 0;
    text-align: center;
    width: 2.5em;
}
.outline-list li a .ttl {
    display: table-cell;
    float: none;
    white-space: nowrap;
}
.outline-list li a .company {
    display: table-cell;
    float: none;
    width: 11em;
}
.btn-gearthpro img {
    height: auto;
    max-width: 100%;
}
.archive-blog .txt-data {
    width: 520px;
}
}

@media only screen and (max-width: 1023px) {
/*.home .container-head {
    height: 100vh;
    position: relative;
}*/
.home .container-body {
    position: relative;
    top: 110vh;
    width: auto;
    z-index: 100;
    background-color: rgba(41,85,157,0.5);
}
.site-catch-wrap {
    bottom: 0;
    height: 100vh;
    left: 100px;
    position: relative;
    top: 0;
    width: 332px;
}
.show-container {
    display: none;
}
.home-content {
    height: 100vh;
    margin: 0;
    padding: 0;
}
.home .btn span {
    position: relative;
    z-index: 1;
}
.home-content .u-inner {
    left: 120px;
    right: 120px;
}
.home #about figure {
    margin: 0 auto .8em;
    width: 350px;
}
.archive-blog .txt-data {
    width: calc(100% - 320px);
}
.site-nav .nav-list li {
    margin: 0 10px;
}
}

@media only screen and (max-width: 959px) {
.site-tag {
    display: none;
}
}

@media only screen and (max-width: 767px) {
html {
    font-size: 56.25%;
}
.header {
    width: 100%;
    z-index: 1001;
}
.site-copy {
    background-color: transparent;
    color: #FFF;
}
.site-nav {
    background-color: transparent;
    bottom: 0;
    height: auto;
    left: 0;
    padding: 0;
    -webkit-perspective: 100px;
            perspective: 100px;
    pointer-events: none;
    right: 0;
    top: 70px;
    z-index: 500;
}
.site-nav .nav-list {
    display: block;
}
.site-ttl {
    background-color: #000;
    bottom: auto;
    box-sizing: border-box;
    color: #FFF;
    display: block;
    height: 70px;
    padding-top: 16px;
    text-align: center;
    top: 0;
}
.site-ttl i {
    display: block;
    height: 8px;
}
.site-ttl span {
    display: block;
    font-size: 12px;
    line-height: 1;
    text-indent: .1em;
}
.site-ttl strong {
    display: block;
    font-size: 19px;
    line-height: 1;
    text-indent: .1em;
}
.site-tag {
    display: none;
}
.site-desc {
    background-color: transparent;
    color: #FFF;
    width: auto;
}
.site-desc div {
    -webkit-writing-mode: unset;
    -moz-writing-mode: unset;
    -ms-writing-mode: unset;
    -ms-writing-mode: unset;
    writing-mode: unset;
    width: auto;
}
.site-desc .num {
    -webkit-transform: rotate(0deg) translate(0,0);
            transform: rotate(0deg) translate(0,0);
}
.scroll {
    height: 100px;
    right: 50%;
    margin-right: -16px;
    position: absolute;
    top: calc(100vh - 100px);
    top: calc(var(--vh, 1vh) * 100 - 100px);
}
.mobilesafari .scroll {
    top: calc(100vh - 175px);
}
.home .container-head {
    position: relative;
}
.home .container-body {
    top: 0;
    background-color: #fff;
}
/*追加*/
/* .container-head {
    animation-name:fadeInAnime;
    animation-duration: 6s;
    animation-fill-mode:forwards;
    opacity:0;
}  
@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
} */

.fix-contents {
    position: absolute;
    width: 100%;
}
.site-desc {
    left: 20px;
    margin-top: -200px;
    position: absolute;
    top: 46vh;/* 50vh*/
    pointer-events: none;
}
.site-ttl-en strong {
    font-size: 46px;
    line-height: 1;
    pointer-events: none;
}

/*追加*/
.site-ttl-en-100 {
    margin-bottom: 10px;
}
.site-ttl-en-100 strong {
    display: block;
    font-size: 36px;
    pointer-events: none;
    margin-bottom: 10px;
}
.site-ttl-en-100 span {
    font-size: 18px;
    pointer-events: none;
}

.site-ttl-en {
    margin-bottom: 20px;
    pointer-events: none;
}
.location {
    margin-bottom: 40px;
}
.site-catch-wrap {
    left: 20px;
    -webkit-transform: matrix(1,0,0,1,0,0) !important;
            transform: matrix(1,0,0,1,0,0) !important;
}
/*追加*/
.site-catch {
    pointer-events: none;
}
.site-ttl-en-100 {
    pointer-events: none;
}

.home-nav {
    display: none;
}
.bg {
    -webkit-transform: matrix(1,0,0,1,0,0) !important;
            transform: matrix(1,0,0,1,0,0) !important;
}
.bg::after {
    background-color: rgba(0,40,0,0.5);
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}
/*追加*/
.bg-video {
    -webkit-transform: matrix(1,0,0,1,0,0) !important;
            transform: matrix(1,0,0,1,0,0) !important;
}
.bg-video::after {
    /* background-color: rgba(0,40,0,0.5); */
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    pointer-events: none;
}

.site-copy {
    height: 100vh;
    position: absolute;
    right: 0;
    top: 0;
}
.site-main-copy {
    bottom: 120px;
    position: absolute;
    right: 50%;
    text-align: center;
    -webkit-transform: translateX(50%);
            transform: translateX(50%);
    pointer-events: none
}
.site-main-copy span {
    font-size: 2.1rem;
}
.site-main-copy em {
    font-size: 3.2rem;
}
.home-content .u-inner {
    bottom: 0;
    left: 0;
    padding: 20px 20px 30px;
    position: relative;
    right: 0;
    top: 0;
    width: auto;
}
.home .container-body {
    background-color: #FFF;
}
.home-content {
    color: #000;
    height: auto;
}
.home .copyright {
    color: #b2b2b2;
    left: 0;
    right: 0;
    text-align: center;
}
.home .hdr {
    text-align: center;
}
.home-list a {
    color: #000;
}
.home-list .label {
    background-color: #b2b2b2;
    color: #FFF;
}
.home .btn-wrap {
    text-align: center;
}
.home .btn {
    background-color: #000;
    border: 1px solid #000;
}
.home .btn::before {
    display: none;
}
.home #construction,
.home #about {
    border-top: 1px solid #e6e6e6;
}
.home #about .flex-inner {
    padding-bottom: 100px;
}
.home-list .ttl span::after {
    display: none;
}
.home figcaption {
    color: #FFF;
}
.scroll-wheel {
    -webkit-animation: sdb2 2.4s infinite;
            animation: sdb2 2.4s infinite;
    border-radius: 4px;
    height: 28px;
    left: 12px;
    top: 5px;
    width: 7px;
}
.scroll-txt {
    bottom: 0;
}
.home .container-head .bg {
    background-position: center 60px;
    background-repeat: no-repeat;
}
/*追加*/
.home .container-head .bg-video video {
    background-position: center 60px;
    background-repeat: no-repeat;
}

.home.mobilesafari .container-head .bg {
    height: calc(100vh - 75px) !important;
}
/*追加*/
.home.mobilesafari .container-head .bg-video {
    /* height: calc(100vh - 75px) !important; */
    height: 100vh !important;
}
.home.mobilesafari .container-head .bg-video video {
    /* height: calc(100vh - 75px) !important; */
    height: 100vh !important;
}

.site-catch-wrap {
    padding-bottom: 0;
    width: 300px;
    pointer-events: none;
}
.nothome .site-desc {
    display: none;
}
.nothome .site-copy {
    display: none;
}
.nothome .container {
    padding: 70px 0 0px;
}
.nothome .site-ttl {
    display: block;
}
.nothome .site-ttl a {
    color: #FFF;
    text-decoration: none;
}
.nothome .u-inner {
    margin: 0 20px;
}
.page-ttl {
    margin-bottom: 1em;
}
.sp-menu-btn {
    display: block;
}
.site-nav a {
    color: #c8c8c8;
}
.brands-nav li:nth-child(n+3)::before {
    display: none;
}
.main-nav li:nth-child(n+2)::before {
    display: none;
}
.nav-list a::after {
    display: none;
}
.brands-nav li:nth-child(1)::after {
    display: none;
}
.menu-opened .site-nav {
    display: block;
    pointer-events: auto;
}
.site-nav .nav-wrapper {
    -webkit-align-items: center;
            align-items: center;
    bottom: 0;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
            justify-content: center;
    left: 0;
    overflow-y: scroll;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 10;
}
.horizontal .site-nav .nav-wrapper {
    -webkit-align-items: normal;
            align-items: normal;
}
.nav-wrap {
    height: 262px;
}
.horizontal .nav-wrap {
    padding: 20px 0 50px;
}
.main-nav {
    position: relative;
    right: auto;
    top: 0;
}
.nav-list {
    height: auto;
    margin-left: 0;
    -webkit-perspective: 500px;
            perspective: 500px;
    text-align: center;
    -webkit-transform: translate(0,0);
            transform: translate(0,0);
    -webkit-writing-mode: inherit;
    -moz-writing-mode: inherit;
    -ms-writing-mode: inherit;
    -ms-writing-mode: inherit;
    writing-mode: inherit;
}
.nav-list li {
    display: list-item;
    margin: 3px 0;
    opacity: 0;
    -webkit-transform: translate3d(0,0,50px);
            transform: translate3d(0,0,50px);
}
.nav-list a {
    display: inline;
    font-size: 30px;
    font-size: 3.0rem;
}
.nav-list a:before {
    -webkit-transform-origin: left top;
            transform-origin: left top;
}
.nav-list .active a:before {
    -webkit-animation-name: lineInHorizontal;
            animation-name: lineInHorizontal;
}
.nav-list a.is-leave:before {
    -webkit-animation-name: lineOutHorizontal;
            animation-name: lineOutHorizontal;
}
.nav-list a:before {
    bottom: -1px;
    height: 1.5px;
    top: auto;
    -webkit-transform: scaleX(0) scaleY(1);
            transform: scaleX(0) scaleY(1);
    width: 100%;
}
.bg-site-nav {
    background-image: url(../img/top/bg-visual.jpg);
    background-position: center top;
    background-size: cover;
    bottom: 0;
    -webkit-filter: grayscale(100%); /* Safari 6.0 - 9.0 */
    filter: grayscale(100%);
    left: 0;
    opacity: 0;
    position: absolute;
    right: 0;
    top: 0;
    -webkit-transform: translate3d(0,0,-50px);
            transform: translate3d(0,0,-50px);
    transition-duration: .6s;
    transition-timing-function: cubic-bezier(.075,.82,.165,1);
}
.bg-site-nav:before {
    background-color: rgba(0,40,0,0.2);
    /*background-color: rgba(0,0,0,0.3);*/
    bottom: 0;
    content: "";
    display: block;
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
}
.menu-opened .bg-site-nav {
    opacity: 1;
    -webkit-transform: translate3d(0,0,0);
            transform: translate3d(0,0,0);
}

.menu-opened .nav-list li {
    opacity: 1;
    -webkit-transform: translate3d(0,0,0);
            transform: translate3d(0,0,0);
    transition-duration: .6s;
    transition-property: opacity,-webkit-transform;
    transition-property: transform,opacity;
    transition-property: transform,opacity,-webkit-transform;
    transition-timing-function: cubic-bezier(.19,1,.22,1);
}
.menu-opened .nav-list li:nth-child(1) {
    transition-delay: .15s;
}
.menu-opened .nav-list li:nth-child(2) {
    transition-delay: .20s;
}
.menu-opened .nav-list li:nth-child(3) {
    transition-delay: .25s;
}
.menu-opened .nav-list li:nth-child(4) {
    transition-delay: .30s;
}
.menu-opened .nav-list li:nth-child(5) {
    transition-delay: .35s;
}
.menu-opened .nav-list li:nth-child(6) {
    transition-delay: .40s;
}
.menu-opened .nav-list li:nth-child(7) {
    transition-delay: .45s;
}
.site-nav .nav-list a {
    color: #FFF;
    font-size: 20px;
    font-size: 2.0rem;
}
.site-nav .nav-list li {
    margin: 0.8em 0;
}
.c-hdr {
    font-size: 1.9rem;
}
.col-img img {
    height: auto;
    max-width: 100%;
}
/*--追加--*/
.about-slide {
    max-width: 441px;
    width: 100%;
    margin: 0 auto 5px;
}
.slick-slide img {
    width: 100%;
    height: 50vw;
    object-fit: cover;
}
/*-------*/
.schedule-list .col-img img {
    min-width: 193px;
    width: 49%;
}
.schedule-list dd {
    padding-left: 36px;
}
.schedule-list dd::before {
    left: 19px;
}
.gallery-pics {
    flex-wrap: wrap;
}
.gallery-pics li {
    flex: none;
    margin: .5%;
    width: 49%;
}
.gallery-pics li:not(:last-child) {
    margin-right: .5%;
}


.c-lead {
    font-size: 1.7rem;
}
.page-ttl {
    font-size: 2.7rem;
}
.c-hdr02 {
    font-size: 2.3rem;
}
.slick-slide img {
    height: 294px;
    width: auto;
}
.movie-wrap-inner {
    left: 0;
    right: 0;
}
#outline-movie {
    width: 100%;
}
.outline-list li a .num {
    display: block;
    left: 0;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
}
.outline-list li a .ttl {
    display: block;
}
.outline-list li a .company {
    display: block;
    font-size: 10px;
}
.outline-list li a {
    box-sizing: border-box;
    display: block;
    padding-left: 42px;
}
#outline-movie {
    display: none;
}
#video {
    background-color: #000;
    display: block;
    width: 100%;
}
.movie-wrap {
    height: auto !important;
    margin-bottom: 30px;
}
.movie-wrap::before {
    padding-top: 74.8%;
}
.archive-blog .txt-data {
    float: none;
    width: auto;
}
.archive-blog .img-data {
    float: none;
    width: auto;
}
.archive-blog .img-data a img {
    height: auto;
    width: 100%;
}
.archive-blog .label-wrap {
    margin-top: .4em;
}
.schedule-list::before {
    bottom: 0;
}
.site-ttl-en span {
    font-size: 19px;
}
.js .site-desc {
    opacity: 0;
    -webkit-transform: translateX(-50px);
            transform: translateX(-50px);
    transition: opacity 1.5s ease 1s, -webkit-transform 1.5s ease 1s;
    transition: opacity 1.5s ease 1s, transform 1.5s ease 1s;
    transition: opacity 1.5s ease 1s, transform 1.5s ease 1s, -webkit-transform 1.5s ease 1s;
    transition-delay: 3s;
}
.js .loaded .site-desc {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
}

.js .site-copy {
    opacity: 0;
    -webkit-transform: translateX(0);
            transform: translateX(0);
    transition: opacity 1.5s ease 1s;
    transition: opacity 1.5s ease 1s;
    transition: opacity 1.5s ease 1s;
}
.js .loaded .site-copy {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
}
.js .scroll {
    opacity: 0;
    transition: opacity 1.5s ease 1s;
}
.js .loaded .scroll {
    opacity: 1;
}
.site-nav .nav-list a:hover, .home .site-nav .nav-list .nav01 a, .page-about .site-nav .nav-list .nav02 a, .post-type-archive-construction .site-nav .nav-list .nav03 a, .single-construction .site-nav .nav-list .nav03 a, .page-outline .site-nav .nav-list .nav04 a, .post-type-archive-news .site-nav .nav-list .nav05 a {
    color: #000;
}
.home.horizontal .container {
    margin-top: 70px;
}
.home.horizontal .container-head .bg-body {
    background-position: center top;
}
.home.horizontal .container-head .bg-body {
    height: calc(100vh - 5px) !important;
}
.home.horizontal .site-copy {
    top: 70px;
}
.horizontal .scroll {
    top: calc(100vh - 35px);
}
.map-wrap {
    padding: 0 0;
}
#map01 {
    height: 380px;
}
.site-main-copy2 {
    bottom: 10px;
    left: 10px;
    -webkit-flex-direction: column;
            flex-direction: column;
    height: auto;
    padding: 1rem;
    position: absolute;
    width: auto;
}
.site-main-copy2 span {
    white-space: nowrap;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: horizontal-tb;
            writing-mode: horizontal-tb;
}
}




@media only screen and (max-width: 479px) {
.home #about figure  {
    width: auto;
}
.home #about figure img {
    height: auto;
    width: 100%;
}
.outline-list li a .ttl {
    font-size: 1.4rem;
}
.outline-list li a .num {
    width: 2em;
}
.outline-list li a {
    padding-left: 34px;
}
.side-widget-wrap {
    float: none;
    width: 100%;
}
.side-widget-wrap2 {
    float: none;
    margin-bottom: 20px;
    width: 100%;
}
.side-widget-wrap3 {
    float: none;
    width: 100%;
}
.side-widget-wrap + .side-widget-wrap {
    margin-left: 0;
}
.slick-slide img {
    height: 224px;
}
.c-hdr br.none {
    display: block;
}
.schedule-list .col-img img {
    min-width: 151px;
}
/*--追加--*/
.about-slide {
    max-width: 336px;
    width: 100%;
    margin: 0 auto 5px;
}
/*-------*/
.activity-list figcaption {
    font-size: 1.3rem;
}
.news-list .img-data {
    height: 90px;
    left: 0;
    top: 10px;
    width: 90px;
}
.news-list .img-data img {
    height: auto;
    width: 100%;
}
.news-list a {
    padding: 10px 30px 10px 100px;
    min-height: 90px;
}
.news-list .excerpt {
    display: none;
}
.side-widget-wrap {
    margin-bottom: 20px;
}
.side-widget-wrap + .side-widget {
    float: none;
    margin-left: 0;
    width: 100%;
}
.side-search-wrap {
    margin-bottom: 20px;
}
#fancybox-wrap {
    left: 0 !important;
}
.site-main-copy {
    bottom: 180px;
    /* bottom: 110px; */
    letter-spacing: .4em;
}
.site-main-copy span {
    font-size: 1.8rem;
}
.site-main-copy em {
    font-size: 2.2rem;
}
}



@media only screen and (max-width: 374px) {
.site-desc {
    left: 15px;
    font-size: 1.5rem;
}
.site-copy {
    font-size: 1.5rem;
    width: 40px;
}
.site-catch-wrap {
    left: 15px;
}
.home-content .u-inner {
    padding: 20px 10px 30px;
}
.nothome .u-inner {
    margin: 0 10px;
}
.schedule-list .col-img img {
    min-width: 134px;
}
.activity-list figcaption {
    font-size: 1.2rem;
}
.c-txt {
    font-size: 1.5rem;
}
.outline-list li a .num {
    display: none;
}
.outline-list li a {
    padding-left: 0;
}
.site-main-copy span {
    font-size: 1.5rem;
}
.site-main-copy em {
    font-size: 1.7rem;
}
}

/* 追加 2025/06/03 */
.opening-animation {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  background-color: #fff;
  z-index: 1000;
  -webkit-animation: byeShutter 4.5s forwards;
  animation: byeShutter 4.5s forwards;
}
.opening-txt {
  position: absolute;
  margin: 0 auto;
  width: 480px;
  height: 88px;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  -webkit-animation: logo 3s forwards;
  animation: logo 3s forwards;
  animation-delay: 0.2s;
}
.opening-txt.sp { display: none;}
.opening-txt.pc { display: block; max-width: 480px;}
.opening-txt.pc img { width: 100%;}
@media only screen and (max-width: 767px) {
.js .test .site-catch {
    transition-delay: 3s;
}
.opening-txt { margin: 55% auto; width: 350px; height: 185px; }
.opening-txt.pc { display: none;}
.opening-txt.sp { display: block;}
.opening-txt.sp img { width: 100%;}
}
@media only screen and (max-width: 497px) {
.opening-txt { margin: 70% auto 30%; width: 238px; height: 125px; }
}
@keyframes byeShutter {
70% {
  opacity: 1;
}
100% {
  opacity: 0;
  display: none;
  z-index: 99;
}
}
@keyframes logo {
0% {
  opacity: 1;
}
50% {
  transform: rotate(0deg);
}
100% {
  transform: scale(0.8);
}
}