:root{
    --font-en:bryant, sans-serif;
    --font-ja:fot-tsukuardgothic-std, sans-serif;
    --font-logotype:space-mono, sans-serif;
    --colorwh:#fff;
    --colorblack:#333;
    --colorglay:#666;
}
/*ローディング画面*/

.shutter{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #999;
    z-index: 9999;
    animation: byeShutter 4s forwards;
}
.shutter::before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto;
    background-color: #fff;
    width: 0;
    height: 1px;
    z-index: 9999;
    animation: shutterOpen 4s forwards;
}
.container {
    animation: contentScale 4s forwards;
} 
@keyframes byeShutter {
    70%{
        opacity: 1;
    }100%{
        opacity: 0;
        display: none;
        z-index: -1;
    }
}
@keyframes shutterOpen {
    0% {
    width: 0;
    height: 1px;
    }
    50% {
    width: 100%;
    height: 1px;
    }
    90% {
    width: 100%;
    height: 100%;
    }
    100% {
    width: 100%;
    height: 100%;
    display: none;
    z-index: -1;
    }
}
@keyframes contentScale {
    70%{
        transform: perspective(800px) scale(1) rotateX(0);
        /* perspective: (800px);
        scale: (1);
        rotate: (0deg); */
    }100%{
        transform: perspective(800px) scale(1) rotateX(0);
        /* perspective: (800px);
        scale: (1);
        rotate: (0deg); */
    }
}   
/*ロゴ画面*/
#delay{
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    z-index: 9000;
}
#delay img{
    width: 60%;
    padding-top: 50%;
    z-index: 9000;
}
#typing {
    margin: 1.4% auto 0;
    font-size: 20px;
    font-family: var(--font-logotype);
    color: #333;
    z-index: 9500;
}
@media(min-width:600px){
    #typing {
        font-size: 30px;
    }
}
@media(min-width:960px){
    #typing {
        font-size: 40px;
    }
    #delay img{
        width: 40%;
        padding-top: 150px;
        z-index: 9000;
    }
}
.wrapper{
    width: 100vw;
    margin: 0 auto;
    position: relative;
}
.top-title{
    width: 100%;
    margin: 0 auto;
    z-index: 1000;
    position: absolute;
    left: 50%;
    top:40%;
    transform: translate(-50%,-40%);
    text-shadow: 3px 3px 10px rgba(0, 0, 0, 0.2);
}
.top-title h1{
    font-family: fot-tsukuardgothic-std, sans-serif;
    font-weight: 400;
    font-size: min(6.4vw,50px);
    color:#fff;
}

.lead{
    margin: 0 auto;
    padding:20vh 0;
    width: 80vw;
}
.lead p{
    /* font-family: "A1 Gothic R",sans-serif; */
    font-size: 1.8rem;
    text-align: left;
    line-height: 3.5rem;
    font-weight: 100;
}
@media (max-width:960px){
    .lead br {
        display: none;
    }
}
@media (min-width:960px){
    .lead {
        display: flex;
        justify-content: center;
    }
    .lead p {
        margin-top: 70px;
        line-height: 8.0rem;
        font-size: 2.0rem;
    }
}
.about-index{
    position: relative;
    width: 84vw;
    max-width: 645px;
    margin: 0 auto;
}
.about-title{
    margin: 0 auto;
    padding-top: 5vh;
    max-width: 325px;
}
.about-square{
    color: #666;
    width: 80%;
    height: 34vh;
    max-height: 300px;
    max-width: 400px;
    background-color:rgba(255, 255,255, 0.8);
    position: relative;
    position: absolute;
    left: 50%;
    top: 10%;
    transform: translate(-50%,0);
    padding: 10px;
    box-shadow: 10px 10px 25px rgba(0, 0, 0, 0.2);
}

.triangle1{
    position: absolute;
    left: 37%;
    display: inline-block;
    border-top: 3px solid #666;
    border-right: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-left: 3px solid #888;
}
.triangle2{
    position: absolute;
    right: 36%;
    display: inline-block;
    border-top: 3px solid transparent;
    border-right: 3px solid #888;
    border-bottom: 3px solid #888;
    border-left: 3px solid transparent;
}
.about-square h2{
    font-family: bryant,sans-serif;
    font-weight: 200;
    font-size: 2.4rem;
    padding-top:10px ;
}
.about-square p{
    padding-top: 3vh;
}
.about-index img{
    width: 100%;
}
.btn{
    margin:10px;
    margin-top: 3vh;
    display: inline-block;
    background-color: #fff;
    border-radius: 10px;
    border:0.05px solid #999;
    padding: 10px ;
    box-shadow: 3px 3px 10px rgba(0, 0, 0, 0.1);
    text-decoration: none;
    color: #333;
    position: relative;
	overflow: hidden;
    transition: ease .2s;
}
.btn span{
    position: relative;
    z-index: 3;
    color: #666;
}
.btn:hover span{
    color: #fff;
}
.bgcenterx:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	background: #999;
    border-radius: 10px;
	width: 100%;
	height: 100%;
	transition: transform .3s cubic-bezier(0.8, 0, 0.2, 1) 0s;
	transform: scale(0, 1);
	transform-origin: right top;
}
.bgcenterx:hover:before{
	transform-origin: left top;
    transform: scale(1,1);
}

@media (min-width:961px){
    .about-index{
        width: 76.3vw;
        max-width: 1100px;
    }
    .about-square{
        width: 60%;
        max-width: 475px;
        height: 140px;
        position: relative;
        position: absolute;
        right: 20%;
        top: 45%;
        transform: translate(-20%,-47%);
        padding: 10px 20px;
    }
    .about-title h2{
        position: absolute;
        left: 20%;
        top: 20%;
    }
    .about-square .btn{
        position: absolute;
        right: 3%;
        top:15%;
        padding: 10px 40px;
        margin-right: 10px;
    }
    .about-square h2{
        font-size: 4.0rem;
        font-weight: 200;
        padding-top: 10px;
        position: absolute;
        left: 15%;
    }
    .triangle1{
        position: absolute;
        left: 10%;
        top:15%;
        border-top: 6px solid #888;
        border-right: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 6px solid #888;
    }
    .triangle2{
        position: absolute;
        right: initial;
        left: 43%;
        top:50%;
        border-top: 6px solid transparent;
        border-right: 6px solid #888;
        border-bottom: 6px solid #888;
        border-left: 6px solid transparent;
    }
    .about-title p{
        position: absolute;
        left:10%;
        top: 53%;
    }
}
.plan-index{
    margin: 0 auto;
    margin-top: 70px;
    width: 84vw;
    max-width: 645px;
    background-color: #fff;
    border:0.05px solid #999;
    box-shadow: 10px 10px 25px rgba(0, 0, 0, 0.2);
}
.plan-title{
    margin: 0 auto;
    position: relative;
    padding-bottom: 10px;
    width: 327px;
}
.triangle3{
    position: absolute;
    left: 37%;
    top: -3%;
    display: inline-block;
    border-top: 3px solid #666;
    border-right: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-left: 3px solid #888;
}
.triangle4{
    position: absolute;
    right: 38%;
    display: inline-block;
    border-top: 3px solid transparent;
    border-right: 3px solid #888;
    border-bottom: 3px solid #888;
    border-left: 3px solid transparent;
}
.plan-index img{
    margin-top: 20px;
    width: 85%;
}
.plan-title h2{
    margin-top: 10px;
    font-family: bryant,sans-serif;
    font-weight: 200;
}
.plan-title p {
    margin-top: 30px;
    line-height: 4.0rem;
}
@media (min-width:961px){
    .plan-index{
        margin-top: 150px;
        width: 76.3vw;
        max-width: 1100px;
        height: 57vh;
        max-height: 580px;
        background-image: url(../images/top/pc/t06.jpg);
        background-size: cover;
        border: 10px solid #fff;
        position: relative;
    }   
    .plan-index img{
        display: none;
    }
    .plan-title {
        width: 22.7vw;
        max-width: 325px;
        padding: 20px 20px;
        background-color:rgba(255, 255,255, 0.8);
        position: relative;
        left: -30%;
        top: 50%;
        transform: translate(0%,-50%);
    }
    .plan-title h2{
        font-size: 4.0rem;
        font-weight: 200;
        position: absolute;
        left: 35%;
        top: 10%;
    }
    .triangle3{
        position: absolute;
        left: 25%;
        top: 7%;
        display: inline-block;
        border-top: 6px solid #888;
        border-right: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 6px solid #888;
    }
    .triangle4{
        position: absolute;
        right: initial;
        left: 65%;
        top:25%;
        border-top: 6px solid transparent;
        border-right: 6px solid #888;
        border-bottom: 6px solid #888;
        border-left: 6px solid transparent;
    }
    .plan-title p {
        margin-top: 80px;
        padding-top: 20px;
        line-height: 4.0rem;
    }
    .plan-square .btn{
        padding: 10px 50px;
    }
}
.gallery-index{
    margin: 0 auto;
    margin-top: 70px;
    width: 84vw;
    max-width: 645px;
}
.gallery-title{
    margin: 0 auto;
    margin-top: 30px;
    margin-bottom: 20px;
    width: 327px;
    position: relative;
}
.triangle5{
    position: absolute;
    left: 32%;
    top: -5%;
    display: inline-block;
    border-top: 3px solid #666;
    border-right: 3px solid transparent;
    border-bottom: 3px solid transparent;
    border-left: 3px solid #888;
}
.triangle6{
    position: absolute;
    right: 31%;
    display: inline-block;
    border-top: 3px solid transparent;
    border-right: 3px solid #888;
    border-bottom: 3px solid #888;
    border-left: 3px solid transparent;
}
.gallery-title h2{
    margin-top: 10px;
    font-family: bryant,sans-serif;
    font-weight: 200;
}
.gallery-title p {
    margin-top: 20px;
}
.gallery-index img{
    width: 100%;
}@media (min-width:961px){
    .gallery-index{
        margin-top: 150px;
        margin-bottom: 150px;
        width: 76.3vw;
        max-width: 1100px;
        display: flex;
        justify-content: space-between;
    }   
    .gallery-title{
        margin: 1.5vw auto 0;
    }
    .gallery-title h2{
        margin-top: 10px;
        font-size: 4.0rem;
        font-weight: 200;
    }
    .gallery-title p {
        margin-top: 1vw;
        padding-top: 10px;
        line-height: 4.0rem;
    }
    .gallery-title .btn {
        margin-top: 1.3vw;
    }
    .triangle5{
        position: absolute;
        left: 19%;
        top: -5%;
        display: inline-block;
        border-top: 6px solid #888;
        border-right: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 6px solid #888;
    }
    .triangle6{
        position: absolute;
        right: initial;
        left: 75%;
        top:23%;
        border-top: 6px solid transparent;
        border-right: 6px solid #888;
        border-bottom: 6px solid #888;
        border-left: 6px solid transparent;
    }
    .gallery-index img{
        width: 100%;
    }
    
}