@charset "UTF-8";
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    list-style: none;
    text-decoration: none;
}
img {
    width: 100%;
    vertical-align: bottom;
}
/* common */
body {
    background-color: rgb(23, 15, 15);
    color: white;
    /* font-family: "Yuji Syuku", serif; */
    font-family: serif;
    font-weight: 400;
    font-style: normal;
    overflow-x: hidden;
}
.wrap {
    width: 900px;
    margin: 0 auto;
}
html {
    scroll-behavior: smooth;
}
@media (max-width: 769px) {
    .wrap {
        width: 90%;
        margin: 0 auto;
    }
}
/* header */
.grid-container {
    display: grid;
    grid-template-columns: 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px 80px;
    grid-template-rows: 50px 50px 50px 50px;
    gap: 1px;
    opacity: 0.6;
}
.grid-container div {
    display: flex;
    background-size: cover;
    background-position: center;
}
.grid-item01 {
    grid-column: 1/2;
    grid-row: 1/2;
    background-image: url(../img/20220402_112414.jpg);
}
.grid-item02 {
    grid-column: 2/3;
    grid-row: 1/3;
    background-image: url(../img/img_0400.jpeg);
}
.grid-item03 {
    grid-column: 3/4;
    grid-row: 1/2;
    background-image: url(../img/20230813_112742.jpg);
}
.grid-item04 {
    grid-column: 4/6;
    grid-row: 1/2;
    background-image: url(../img/20220827_113529.jpg);
}
.grid-item05 {
    grid-column: 6/7;
    grid-row: 1/2;
    background-image: url(../img/20220429_133619.jpg);
}
.grid-item06 {
    grid-column: 7/8;
    grid-row: 1/2;
    background-image: url(../img/20211128_113711.jpg);
}
.grid-item07 {
    grid-column: 8/9;
    grid-row: 1/2;
    background-image: url(../img/img_0197.jpg);
}
.grid-item08 {
    grid-column: 9/10;
    grid-row: 1/2;
    background-image: url(../img/20220917_114237.jpg);
}
.grid-item09 {
    grid-column: 10/11;
    grid-row: 1/2;
    background-image: url(../img/20220910_131205.jpg);
}
.grid-item10 {
    grid-column: 11/12;
    grid-row: 1/2;
    background-image: url(../img/20220429_133612.jpg);
}
.grid-item11 {
    grid-column: 12/13;
    grid-row: 1/2;
    background-image: url(../img/20220821_110550.jpg);
}
.grid-item12 {
    grid-column: 13/14;
    grid-row: 1/2;
    background-image: url(../img/img_0338.jpeg);
}
.grid-item13 {
    grid-column: 14/15;
    grid-row: 1/2;
    background-image: url(../img/img_0397.jpeg);
}
.grid-item14 {
    grid-column: 15/16;
    grid-row: 1/2;
    background-image: url(../img/img_0396.jpeg);
}
.grid-item15 {
    grid-column: 16/17;
    grid-row: 1/2;
    background-image: url(../img/img_3492.jpg);
}
.grid-item16 {
    grid-column: 17/18;
    grid-row: 1/2;
    background-image: url(../img/img_0742.jpeg);
}
.grid-item17 {
    grid-column: 18/19;
    grid-row: 1/2;
    background-image: url(../img/img_3544.jpg);
}
.grid-item18 {
    grid-column: 19/20;
    grid-row: 1/2;
    background-image: url(../img/img_3574.jpg);
}
.grid-item19 {
    grid-column: 20/21;
    grid-row: 1/2;
    background-image: url(../img/img_3566.jpg);
}
.grid-item20 {
    grid-column: 1/2;
    grid-row: 2/3;
    background-image: url(../img/img_3505.jpg);
}
.grid-item21 {
    grid-column: 3/4;
    grid-row: 2/3;
    background-image: url(../img/img_3543.jpg);
}
.grid-item22 {
    grid-column: 4/5;
    grid-row: 2/3;
    background-image: url(../img/img_0381.jpeg);
}
.grid-item23 {
    grid-column: 4/5;
    grid-row: 2/3;
    background-image: url(../img/img_0381.jpeg);
}
.grid-item24 {
    grid-column: 5/6;
    grid-row: 2/3;
    background-image: url(../img/img_0248.jpg);
}
.grid-item25 {
    grid-column: 6/7;
    grid-row: 2/4;
    background-image: url(../img/20230813_112737.jpg);
}
.grid-item26 {
    grid-column: 7/8;
    grid-row: 2/3;
    background-image: url(../img/20221015_124431.jpg);
}
.grid-item27 {
    grid-column: 8/9;
    grid-row: 2/3;
    background-image: url(../img/20221002_115400.jpg);
}
.grid-item28 {
    grid-column: 9/11;
    grid-row: 2/3;
    background-image: url(../img/20230821_110731.jpg);
}
.grid-item29 {
    grid-column: 11/12;
    grid-row: 2/3;
    background-image: url(../img/20220925_132319.jpg);
}
.grid-item30 {
    grid-column: 12/13;
    grid-row: 2/3;
    background-image: url(../img/20220921_111005.jpg);
}
.grid-item31 {
    grid-column: 13/14;
    grid-row: 2/3;
    background-image: url(../img/20220910_131218.jpg);
}
.grid-item32 {
    grid-column: 14/15;
    grid-row: 2/4;
    background-image: url(../img/20220921_111002.jpg);
}
.grid-item33 {
    grid-column: 15/16;
    grid-row: 2/3;
    background-image: url(../img/20210911_115725.jpg);
}
.grid-item34 {
    grid-column: 16/17;
    grid-row: 2/3;
    background-image: url(../img/20231014_111051.jpg);
}
.grid-item35 {
    grid-column: 16/17;
    grid-row: 2/3;
    background-image: url(../img/20230826_135841.jpg);
}
.grid-item36 {
    grid-column: 17/18;
    grid-row: 2/3;
    background-image: url(../img/20231014_111036.jpg);
}
.grid-item37 {
    grid-column: 18/20;
    grid-row: 2/3;
    background-image: url(../img/img_3501.jpg);
}
.grid-item38 {
    grid-column: 20/21;
    grid-row: 2/3;
    background-image: url(../img/img_3493.jpg);
}
.grid-item39 {
    grid-column: 1/2;
    grid-row: 3/4;
    background-image: url(../img/img_0423.jpeg);
}
.grid-item40 {
    grid-column: 2/4;
    grid-row: 3/4;
    background-image: url(../img/img_0304.jpeg);
}
.grid-item41 {
    grid-column: 4/5;
    grid-row: 3/4;
    background-image: url(../img/20230822_061407.jpg);
}
.grid-item42 {
    grid-column: 5/6;
    grid-row: 3/4;
    background-image: url(../img/20230823_113514.jpg);
}
.grid-item43 {
    grid-column: 7/8;
    grid-row: 3/4;
    background-image: url(../img/20230813_130252.jpg);
}
.grid-item44 {
    grid-column: 8/9;
    grid-row: 3/5;
    background-image: url(../img/20220808_114507.jpg);
}
.grid-item45 {
    grid-column: 9/10;
    grid-row: 3/4;
    background-image: url(../img/20211009_112000.jpg);
}
.grid-item46 {
    grid-column: 10/12;
    grid-row: 3/4;
    background-image: url(../img/img_0410.jpeg);
}
.grid-item47 {
    grid-column: 12/13;
    grid-row: 3/5;
    background-image: url(../img/20220429_132705.jpg);
}
.grid-item48 {
    grid-column: 13/14;
    grid-row: 3/4;
    background-image: url(../img/20220808_113958.jpg);
}
.grid-item49 {
    grid-column: 15/16;
    grid-row: 3/4;
    background-image: url(../img/20220429_133614.jpg);
}
.grid-item50 {
    grid-column: 16/17;
    grid-row: 3/4;
    background-image: url(../img/img_0789.jpeg);
}
.grid-item51 {
    grid-column: 17/19;
    grid-row: 3/4;
    background-image: url(../img/img_0738.jpeg);
}
.grid-item52 {
    grid-column: 19/20;
    grid-row: 3/4;
    background-image: url(../img/img_0557.jpeg);
}
.grid-item53 {
    grid-column: 20/21;
    grid-row: 3/4;
    background-image: url(../img/img_0307.jpeg);
}
.grid-item54 {
    grid-column: 1/2;
    grid-row: 4/5;
    background-image: url(../img/img_0284.jpeg);
}
.grid-item55 {
    grid-column: 2/3;
    grid-row: 4/5;
    background-image: url(../img/img_0273.jpeg);
}
.grid-item56 {
    grid-column: 3/5;
    grid-row: 4/5;
    background-image: url(../img/img_0257.jpeg);
}
.grid-item57 {
    grid-column: 5/6;
    grid-row: 4/5;
    background-image: url(../img/img_0219.jpeg);
}
.grid-item58 {
    grid-column: 6/7;
    grid-row: 4/5;
    background-image: url(../img/img_0017.jpeg);
}
.grid-item59 {
    grid-column: 7/8;
    grid-row: 4/5;
    background-image: url(../img/20240907_185138.jpeg);
}
.grid-item60 {
    grid-column: 9/11;
    grid-row: 4/5;
    background-image: url(../img/20240822_121918.jpeg);
}
.grid-item61 {
    grid-column: 11/12;
    grid-row: 4/5;
    background-image: url(../img/20240712_110009.jpeg);
}
.grid-item62 {
    grid-column: 13/14;
    grid-row: 4/5;
    background-image: url(../img/20240705_123413.jpeg);
}
.grid-item63 {
    grid-column: 14/15;
    grid-row: 4/5;
    background-image: url(../img/20240614_114525.jpeg);
}
.grid-item64 {
    grid-column: 15/16;
    grid-row: 4/5;
    background-image: url(../img/20240613_111644.jpeg);
}
.grid-item65 {
    grid-column: 16/17;
    grid-row: 4/5;
    background-image: url(../img/20240327_181101.jpeg);
}
.grid-item66 {
    grid-column: 17/18;
    grid-row: 4/5;
    background-image: url(../img/20240203_122240.jpeg);
}
.grid-item67 {
    grid-column: 18/20;
    grid-row: 4/5;
    background-image: url(../img/20231126_111054.jpeg);
}
.grid-item68 {
    grid-column: 20/21;
    grid-row: 4/5;
    background-image: url(../img/20231022_122108.jpeg);
}
header img {
    width: 180px;
    height: 180px;
    transition: 1s;
}
header img:hover {
    transform: rotateY(360deg);
}
header {
    /* position: relative; */
    /* margin: 0 auto; */
}
.flex_box_header {
    display: flex;
    position: relative;
    top: -210px;
    width: 900px;
    margin: 0 auto;
}
/* .flex_box_header {
    animation: purupuru 5s ease-in 1 forwards;
}
@keyframes purupuru {
    0% {
        top: -220px;
        left: 0px;
    }
    25% {
        top: -220px;
        left: 1px;
    }
    50% {
        top: -219px;
        left: 1x;
    }
    75% {
        top: -219px;
        left: 0px;
    }
    100% {
        top: -220px;
        left: 0px;
    }
} */

.flex_box_header p {
    font-size: 4.5em;
    font-family: "Yuji Syuku", serif;
    color: white;
    text-shadow: darkgrey 2px 2px;
    padding: 25px 0 0 0;
    z-index: 2;
}

.flex_box_nav {
    display: flex;
    justify-content: space-between;
    position: absolute;
    width: 470px;
    top: 175px;
    margin: 0 50%;
    /* left: 55%; */
    /* right: 20%; */
    transform: translate(-50%, 0);
}
.flex_box_nav li a {
    color: white;
    font-size: 1em;
    padding: 0 10px;
    border: 1px solid white;
    margin: 0 5px;
    box-shadow: darkgrey 1px 1px;
    text-shadow: darkgrey 1px 1px;
}
.flex_box_nav li a:hover {
    color: darkgrey;
    border: 1px solid darkgrey;
    background-color: rgba(0, 0, 0, 0.329);
    opacity: 0.7;
    box-shadow: darkolivegreen 1px 1px;
    text-shadow: darkolivegreen 1px 1px;
}
/* hamburger */
.hamburger-morph {
    position: fixed;
    top: 20px;
    right: 20px;
    z-index: 1000;
    width: 48px;
    height: 48px;
    padding: 0;
    border: none;
    background: transparent;
    cursor: pointer;
}

.hamburger-morph__icon {
    width: 100%;
    height: 100%;
}

.hamburger-morph__line {
    fill: none;
    stroke: white;
    stroke-width: 6;
    transition: stroke-dasharray 600ms cubic-bezier(0.4, 0, 0.2, 1),
        stroke-dashoffset 600ms cubic-bezier(0.4, 0, 0.2, 1);
}

.hamburger-morph__line:nth-child(1) {
    stroke-dasharray: 60 207;
}

.hamburger-morph__line:nth-child(2) {
    stroke-dasharray: 60 60;
}

.hamburger-morph__line:nth-child(3) {
    stroke-dasharray: 60 207;
}

.hamburger-morph.active .hamburger-morph__line:nth-child(1) {
    stroke-dasharray: 90 207;
    stroke-dashoffset: -134;
}

.hamburger-morph.active .hamburger-morph__line:nth-child(2) {
    stroke-dasharray: 1 60;
    stroke-dashoffset: -30;
}

.hamburger-morph.active .hamburger-morph__line:nth-child(3) {
    stroke-dasharray: 90 207;
    stroke-dashoffset: -134;
}

.nav-morph {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(29, 29, 31, 0.9);
    clip-path: circle(0% at calc(100% - 44px) 44px);
    transition: clip-path 0.7s cubic-bezier(0.4, 0, 0.2, 1);
    z-index: 900;
}

.nav-morph.active {
    clip-path: circle(150% at calc(100% - 44px) 44px);
}

.nav-morph__wrapper {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.nav-morph__list {
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: center;
}

.nav-morph__item {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

.nav-morph.active .nav-morph__item {
    opacity: 1;
    transform: translateY(0);
}

.nav-morph.active .nav-morph__item:nth-child(1) {
    transition-delay: 0.3s;
}
.nav-morph.active .nav-morph__item:nth-child(2) {
    transition-delay: 0.4s;
}
.nav-morph.active .nav-morph__item:nth-child(3) {
    transition-delay: 0.5s;
}
.nav-morph.active .nav-morph__item:nth-child(4) {
    transition-delay: 0.6s;
}

.nav-morph__link {
    position: relative;
    display: inline-block;
    padding: 20px;
    font-size: 20px;
    color: #fff;
    text-decoration: none;
    overflow: hidden;
}

.nav-morph__text,
.nav-morph__hover {
    display: block;
    transition: transform 0.3s ease;
}

.nav-morph__hover {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    transform: translateY(0%);
}

.nav-morph__link:hover .nav-morph__text {
    transform: translateY(-100%);
}

.nav-morph__link:hover .nav-morph__hover {
    transform: translateY(-100%);
}

.sp-navi {
    display: none;
}
@media (max-width: 769px) {
    .flex_box_header {
        top: -180px;
    }
    header img:hover {
        transform: none;
    }
    .pc-navi {
        display: none;
    }
    .sp-navi {
        display: block;
    }
}
/* main */
/* hero */
.hero {
    max-width: 900px;
    margin: 0 auto;
    position: relative;
    /* max-width: 100%; */
}
.hero img {
    position: relative;
    aspect-ratio: 9/5;
    top: -100px;
    object-fit: cover;
}

.animation_box {
    position: absolute;
    margin: 0 auto;
    width: 100%;
    top: 40%;
    left: 5%;
    font-size: 3em;
    text-shadow: darkolivegreen 2px 1px;
    animation: display 5s ease-in forwards;
}
@keyframes display {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
@media (max-width: 769px) {
    .animation_box {
        font-size: 5vw;
        top: 35%;
        left: 5%;
    }
}
/* introduction Section */
.introduction {
    position: relative;
    padding-top: 50px;
    padding-left: 30px;
    font-size: 40px;
    margin: 0px 0 50px 0;
}
.introduction span {
    position: relative;
    z-index: 2;
}
.introduction::before {
    content: attr(data-en);
    position: absolute;
    transform: rotate(-5deg);
    top: -20px;
    left: 0;
    color: rgba(169, 169, 169, 0.5);
    font-size: 80px;
    font-weight: 400;
    font-family: luxus-brut, cursive;
    font-style: italic;
}
.intoduction_sct p {
    letter-spacing: 0.1em;
    line-height: 1.7;
    text-align: justify;
    /* text-indent: 1em; */
}
/* menu Section */
.menu {
    position: relative;
    padding-top: 50px;
    padding-left: 30px;
    font-size: 40px;
    margin: 150px 0 50px 0;
}
.menu span {
    position: relative;
    z-index: 2;
}
.menu::before {
    content: attr(data-en);
    position: absolute;
    transform: rotate(-5deg);
    top: -20px;
    left: 0;
    color: rgba(169, 169, 169, 0.5);
    font-size: 80px;
    font-weight: 400;
    font-family: luxus-brut, cursive;
    font-style: italic;
}

h3 {
    position: relative;
    padding: 0.25em 1em;
    border-top: solid 2px white;
    border-bottom: solid 2px white;
    width: fit-content;
    margin: 50px;
}
h3:before,
h3:after {
    content: "";
    position: absolute;
    top: -7px;
    width: 2px;
    height: -webkit-calc(100% + 14px);
    height: calc(100% + 14px);
    background-color: white;
}
h3:before {
    left: 7px;
}
h3:after {
    right: 7px;
}

h4 {
    position: relative;
    padding: 1rem 0.5rem;
    margin-bottom: 20px;
    font-size: 1.2em;
}

h4:after {
    position: absolute;
    bottom: 0;
    left: 0;
    margin-left: 5px;
    width: 290px;
    height: 5px;
    content: "";
    background-image: -webkit-gradient(
        linear,
        left top,
        right top,
        from(#fa709a),
        to(#fee140)
    );
    background-image: -webkit-linear-gradient(left, #fa709a 0%, #fee140 100%);
    background-image: linear-gradient(to right, #fa709a 0%, #fee140 100%);
}
.flex_box {
    display: flex;
    justify-content: space-between;
}

.flex_item_img {
    width: 280px;
    aspect-ratio: 16/9;
    /* height: 150px; */
    margin: 10px;
    object-fit: cover;
    overflow: hidden;
}
.flex_item img:hover {
    transform: scale(1.2);
    transition: 1s;
}
.flex_item p {
    width: 290px;
    padding-left: 10px;
    line-height: 1.7;
}

.right {
    text-align: right;
}

@media (max-width: 769px) {
    .flex_box {
        display: block;
        /* justify-content: space-between; */
    }
    .flex_item_img {
        width: 90%;
        margin: 10px auto;
    }
    .flex_item img:hover {
        transform: scale(1);
    }
    .flex_item p {
        width: 90%;
        margin: 0 auto;
        margin-bottom: 20px;
    }
    /* .right {
        text-align: right;
    } */
}

/* access Section */
.access {
    position: relative;
    padding-top: 50px;
    padding-left: 30px;
    font-size: 40px;
    margin: 150px 0 50px 0;
}
.access span {
    position: relative;
    z-index: 2;
}
.access::before {
    content: attr(data-en);
    position: absolute;
    transform: rotate(-5deg);
    top: -20px;
    left: 0;
    color: rgba(169, 169, 169, 0.5);
    font-size: 80px;
    font-weight: 400;
    font-family: luxus-brut, cursive;
    font-style: italic;
}
.access_sct {
    /* width: 900px;
    margin: 0 auto; */
}
.introduce_sct {
    display: flex;
    justify-content: space-between;
    gap: 6%;
    margin: 10% 0;
}
.flex_box_introduce {
    width: 50%;
}
.flex_box_introduce img {
    width: 100%;
    display: block;
    object-fit: cover;
}
.flex_box_introduce h3 {
    display: block;
}
.flex_box_introduce .image1 {
    aspect-ratio: 9/16;
    margin: 50px 0 10px;
}
.flex_box_introduce .image2 {
    aspect-ratio: 5/4;
}
.flex_box_introduce div {
    display: block;
    margin: 10px 0;
}
@media (max-width: 769px) {
    .access_sct {
        width: 90%;
        margin: 0 auto;
    }
    .introduce_sct {
        display: block;
    }
    .flex_box_introduce {
        width: 80%;
        margin: 0 auto;
    }
}

/* new Section */
.new {
    position: relative;
    padding-top: 50px;
    padding-left: 30px;
    font-size: 40px;
    margin: 150px 0 50px 0;
}
.new span {
    position: relative;
    z-index: 2;
}
.new::before {
    content: attr(data-en);
    position: absolute;
    transform: rotate(-5deg);
    top: -20px;
    left: 0;
    color: rgba(169, 169, 169, 0.5);
    font-size: 80px;
    font-weight: 400;
    font-family: luxus-brut, cursive;
    font-style: italic;
}
.new_sct dt {
    float: left;
    padding: 20px 50px 0 0;
}
.new_sct dd {
    padding: 20px 0 0 0;
}
@media (max-width: 769px) {
    .new_sct dt {
        float: none;
        /* padding: 20px 50px 0 0; */
    }
    .new_sct dd {
        margin-left: 5%;
        /* padding: 20px 0 0 0; */
    }
}
/* footer */
footer {
    width: 100%;
    color: silver;
}
footer span {
    font-family: "Yuji Syuku", serif;
    font-size: 1.5em;
    color: silver;
    text-shadow: darkolivegreen 1px 1px;
}
.flex_box_footer {
    display: flex;
    border-top: 2px solid gray;
    position: relative;
    justify-content: right;
    align-items: center;
    margin: 100px 10px 0;
}
.flex_box_footer a {
    width: 100px;
    height: 100px;
    position: relative;
}

/* OPEN記念イベントチケット */
.ticket {
    width: 250px;
    border: 3px solid gold;
    position: fixed;
    top: 20px;
    /* bottom: 220px; */
    right: 20px;
    transition: 1s;
    z-index: 3;
}
.ticket:hover {
    transform: rotateY(360deg);
}
.new_sct dd span {
    color: #fa709a;
}
@media (max-width: 769px) {
    .ticket {
        width: 120px;
        border: 1px solid gold;
        position: fixed;
        top: unset;
        bottom: 20px;
        left: 20px;
        /* transition: 1s; */
    }
    .ticket:hover {
        transform: none;
    }
}
