@charset "utf-8";

/*----- header -----*/
header {
    position: relative;
    width: 100%;
    height: 100vh;
    background: url("../images/h_img.jpg") no-repeat center center;
    background-size: cover;
}
header .logo {
    position: absolute;
    z-index: 9;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 195px;
    height: 230px;
    margin: auto;
}
header .copy {
    position: absolute;
    z-index: 9;
    bottom: 10vh;
    left: 0;
    width: 100%;
    color: #FFF;
    font-size: calc( 18 / var(--root-font-size) * 1rem );
    line-height: 1.5;
    text-align: center;
    text-indent: 0.05em;
}
header .logo {
    opacity: 0;
    transition: 1.5s 0.5s ease-in-out;
}
header .logo.isInView {
    opacity: 1;
}
header .copy {
    opacity: 0;
    transition: 1.5s 1s ease-in-out;
}
header .copy.isInView {
    opacity: 1;
}

.swiper {
    overflow: hidden;
}
.swiper-slide {
    width: 100%;
    height: 100vh;
    background: url("../images/h_img.jpg") no-repeat center center;
    background-size: cover;
    animation: zoomUp 60s linear 0s 1 normal both;
}

div.newsWrap {
    position: absolute;
    z-index: 9;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    height: 50px;
    padding: 0 4%;
}
div.newsWrap p,
.modaal-content-container p {
    font-family: toppan-bunkyu-mincho-pr6n, serif;
}
div.newsWrap .ttlWrap {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    color: #FFF;
    line-height: 1.5;
    transition: 0.5s 0s ease-in-out;
}
div.newsWrap .ttlWrap:hover {
    color: #8B8B8B;
}
div.newsWrap .ttlWrap .date {
    font-size: calc( 10 / var(--root-font-size) * 1rem );
    margin: 0 15px 0 0;
}
div.newsWrap .ttlWrap .ttl {
    font-size: calc( 11 / var(--root-font-size) * 1rem );
}
div.newsWrap article .date,
.modaal-content-container .date {
    font-size: calc( 13 / var(--root-font-size) * 1rem );
    line-height: 1.75;
    margin: 0 0 50px;
}
div.newsWrap article .ttl,
.modaal-content-container .ttl {
    font-size: calc( 15 / var(--root-font-size) * 1rem );
    line-height: 1.75;
}
div.newsWrap article .content,
.modaal-content-container .content {
}
div.newsWrap article .content p,
.modaal-content-container .content p {
    line-height: 2;
    margin: 0 0 2em;
}
div.newsWrap article .content a,
.modaal-content-container .content a {
    text-decoration: underline;
}

.hideArea {
	display: none;
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(2);
  }
}

@media screen and (max-width: 960px) {
header {
    position: relative;
    width: 100%;
    height: 100vh;
    background: url("../images/h_img.jpg") no-repeat center center;
    background-size: cover;
}
header .logo {
    position: absolute;
    z-index: 9;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 156px;
    height: 184px;
    margin: auto;
}
header .copy {
    position: absolute;
    z-index: 9;
    bottom: 10vh;
    left: 0;
    width: 100%;
    color: #FFF;
    font-size: calc( 12 / var(--root-font-size) * 1rem );
    line-height: 1.5;
    text-align: center;
    text-indent: 0.05em;
}
header .logo {
    opacity: 0;
    transition: 1.5s 0.5s ease-in-out;
}
header .logo.isInView {
    opacity: 1;
}
header .copy {
    opacity: 0;
    transition: 1.5s 1s ease-in-out;
}
header .copy.isInView {
    opacity: 1;
}

.swiper {
    overflow: hidden;
}
.swiper-slide {
    width: 100%;
    height: 100vh;
    background: url("../images/h_img.jpg") no-repeat center center;
    background-size: cover;
    animation: zoomUp 60s linear 0s 1 normal both;
}

div.newsWrap {
    position: absolute;
    z-index: 9;
    bottom: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    width: 100%;
    height: 50px;
    padding: 0 4%;
}
div.newsWrap p,
.modaal-content-container p {
    font-family: toppan-bunkyu-mincho-pr6n, serif;
}
div.newsWrap .ttlWrap {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    color: #FFF;
    line-height: 1.5;
    transition: 0.5s 0s ease-in-out;
}
div.newsWrap .ttlWrap:hover {
    color: #8B8B8B;
}
div.newsWrap .ttlWrap .date {
    font-size: calc( 10 / var(--root-font-size) * 1rem );
    margin: 0 15px 0 0;
}
div.newsWrap .ttlWrap .ttl {
    font-size: calc( 11 / var(--root-font-size) * 1rem );
}
div.newsWrap article .date,
.modaal-content-container .date {
    font-size: calc( 13 / var(--root-font-size) * 1rem );
    line-height: 1.75;
    margin: 0 0 50px;
}
div.newsWrap article .ttl,
.modaal-content-container .ttl {
    font-size: calc( 15 / var(--root-font-size) * 1rem );
    line-height: 1.75;
}
div.newsWrap article .content,
.modaal-content-container .content {
}
div.newsWrap article .content p,
.modaal-content-container .content p {
    line-height: 2;
    margin: 0 0 2em;
}
div.newsWrap article .content a,
.modaal-content-container .content a {
    text-decoration: underline;
}
}

/*----- main -----*/
@media screen and (max-width: 960px) {
.mainTtl {
    border-bottom: #BFC0BF solid 1px;
    padding: 0 0 15px;
    margin: 0 0 25px;
}
section#studio .mainTtl {
    margin: 0 0 25px 7.5%;
}
}

/*----- ABOUT -----*/
section#about {
    padding: 150px 0 100px;
}
section#about p {
    color: #B31011;
    font-family: toppan-bunkyu-mincho-pr6n, serif;
    font-size: calc( 17 / var(--root-font-size) * 1rem );
    line-height: 2;
    text-align: center;
    text-indent: 0.05em;
    margin: 0 0 125px;
}
section#about div.icon {
    width: 35px;
    margin: 0 auto 150px;
}
section#about div.img {
    width: 72.5%;
    height: 60vw;
    background: url("../images/about_top_img.jpg") no-repeat center center;
    background-size: cover;
}

@media screen and (max-width: 960px) {
section#about {
    padding: 100px 0 0;
}
section#about p {
    color: #B31011;
    font-family: toppan-bunkyu-mincho-pr6n, serif;
    font-size: calc( 12 / var(--root-font-size) * 1rem );
    line-height: 2.5;
    text-align: center;
    text-indent: 0.05em;
    margin: 0 0 75px;
}
section#about div.icon {
    width: 25px;
    margin: 0 auto 75px;
}
section#about div.img {
    width: 87.5%;
    height: 128vw;
    max-height: 480px;
    background: url("../images/about_top_img.jpg") no-repeat center center;
    background-size: cover;
}
}

/*----- WORKS -----*/
section#works {
    padding: 110px 0 100px;
}
section#works div.frame.flexWrap .blockR {
    padding: 0 4vw 0 0;
}

@media screen and (max-width: 960px) {
section#works {
    padding: 50px 0 25px;
}
section#works div.frame.flexWrap .blockR {
    padding: 0 7.5vw 0 0;
}
}

/*----- STUDIO -----*/
section#studio {
    padding: 110px 0 100px 4vw;
}
section#studio div.frame {
    background: #000;
    padding: 4vw;
    margin: 50px 0 0;
}
section#studio div.flexWrap {
    flex-wrap: wrap;
    padding: 0 0 75px;
}
section#studio div.flexWrap img {
    width: 50%;
    height: auto;
}

@media screen and (max-width: 960px) {
section#studio {
    padding: 50px 0 100px;
}
section#studio div.frame {
    background: #000;
    padding: 30px 7.5%;
    margin: 50px 0 0;
}
section#studio div.flexWrap {
    flex-wrap: wrap;
    padding: 0 0 30px;
}
section#studio div.flexWrap img {
    width: 100%;
    height: auto;
}
}
