.pa-15 {
    padding: 15px;
}
img {
    max-width: 100%;
    width: 100%;
}

p {
    line-height: 1.75;
}
p.small {
    font-size: 65%;
}
.container {
    width: 100%;
    max-width: 750px;
    margin: 0 auto;
}

.container.movie-wrap {
    min-height: calc(100vh - 38px);
    height: 100%;
}

.btn-wrap {
    display: flex;
    justify-content: center;
    margin: 40px auto;
    padding: 0 20px;
}
.text-center {
    text-align: center;
}
#delay-item-wrap {
    display: none;
    text-align: center;
    padding: 0 15px;
}
a.btn-01 {
    max-width: 520px;
    text-decoration: none;
    font-weight: bold;
    font-size: 32px;
    animation: ef01 2s ease-out infinite;
    overflow: hidden;
    position: relative;
}
a.btn-02 {
    max-width: 420px;
    width: 100%;
    color: #fff;
    height: 120px;
    border-radius: 60px;
    background-color: #07c655;
    text-decoration: none;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 32px;
    animation: ef01 2s ease-out infinite;
    overflow: hidden;
    position: relative;
}
h1 {
    text-align: center;
    font-weight: 28px;
    font-weight: bold;
    margin: auto;
    color: #353535;
}
h1.title-01 span:nth-child(1){
    color: #74c94a;
}
h1.title-01 span:nth-child(2){
    color: #e76c23;
}
h1.title-01 span:nth-child(3){
    color: #37ace8;
}
h1.title-01 span:nth-child(4){
    color: #673e80;
}
h1.title-01 span:nth-child(5){
    color: #f9d217;
}

h2 {
    text-align: center;
    font-size: 20px;
    font-weight: bold;
}
a.btn-01::before,a.btn-02::before {
    content: "";
    display: inline-block;
    top: -180px;
    left: 0;
    width: 30px;
    height: 100%;
    background-color: #fff;
    position: absolute;
    transition: 300ms;
    animation: shinyshiny 2.5s ease-in-out infinite;
}


@keyframes shinyshiny {
  0% { -webkit-transform: scale(0) rotate(45deg); opacity: 0; }
  80% { -webkit-transform: scale(0) rotate(45deg); opacity: 0.5; }
  81% { -webkit-transform: scale(4) rotate(45deg); opacity: 1; }
  100% { -webkit-transform: scale(50) rotate(45deg); opacity: 0; }
}

@keyframes ef01 { 0%, 40%, 60%, 80% { transform: scale(1); }
  50%, 70% { transform: scale(1.05); } }

main {
    text-align: center;
}
main img {
    max-height: 80vh;
    width: auto;
    margin: 0 auto;
    height: 100%;

}
.mv .btn-wrap {
    height: 20vh;
    width: auto;
    margin: 0 auto;
}
.movie-wrap {
margin-top: 25px;
  position: relative;
  width: 100%;
  padding-bottom: 56.25%; /* 高さ = 幅 × 9 ÷ 16 → 16:9比率 */
  height: 0;
  overflow: hidden;
}

.movie-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.movie-wrap 
.dummy {
    max-width: 800px;
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 9;
    background-color: #ccc;
}
.title-02 {
    background-color: rgb(41, 194, 174);
    color: #fff;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
    display: inline-block;
    padding: 10px;
}
.fs-01 {
    font-size: 3.5vw;
}
footer {
    width: 100%;
    background-color: #000;

}
footer.movie-page {
    position: fixed;
    bottom: 0;
    width: 100%;
    background-color: #000;

}
footer ul {
    display: flex;
    justify-content: center;
    padding: 10px 20px;
    list-style: none;
    margin-block-start: 0;
    margin-block-end: 0;
}


footer li {
    padding: 0 20px;
    font-size: 14px;
}
footer li + li {
    border-left: 1px solid #fff;
}

footer a {
    color: #fff;
    text-decoration: none;
}
