*{
    padding:0px;
    margin:0px;
}
body{
    font-family: "Noto Serif JP";
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
    font-size:15px;
    letter-spacing:0;
    color:#FFF;
    background: #3F3B3A;
}
a{
    text-emphasis:none;
    color:#FFF;
}
a:hover{opacity:0.6;transition: .4s;}
img{
    display:inline-block;
    vertical-align:bottom;
    width:100%;
}
.pc-br{display:block;}
.sp-br{display:none;}

header{background: #4F5237;}
h1{
    font-family: "Noto Sans JP";
    font-size: 18px;
    font-weight: 400;
    text-align: center;
    padding:10px 0px;
    letter-spacing:0.18px;
}
.main img{
    width:100%;
    max-width: 800px;
    margin:auto;
    display: block;
}
.contents{
    display: flex;
    padding: 40px 50px 50px 50px;
    gap: 40px;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    max-width: 800px;
    margin:auto;
}
.cast{
    width:90%;
    max-width:740px;
    margin:auto;
}
h2{
    text-align: center;
    font-size:30px;
    font-weight:600;
    line-height:46px;
    letter-spacing:6px;
}
p{
    font-size: 17px;
    font-weight:600;
    line-height: 34px;
    letter-spacing: 3.4px;
    text-align:center;
}
.cast{
    width:100%;
    max-width:800px;
    margin:auto;
}
footer{
    background: #4F5237;
    display:flex;
    padding:30px 40px;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    align-self:stretch;
}
footer h2{
    color:#FFF;
    font-size:18px;
    font-weight:500;
    line-height: normal;
    letter-spacing: 1.8px;
}
footer a{
    width:380px;
    margin:15px auto;
    display: block;
}
footer p{
    text-align:center;
    font-size:12px;
    font-weight:400;
    line-height: 18px;
    letter-spacing: 1.2px;
}
@media screen and (max-width: 768px){
    .pc-br{display:none;}
    .sp-br{display:block;}

    header{padding:10px;}
    h1{
        font-size: 14px;
        font-weight: 400;
        line-height: 20px;
        letter-spacing: 1.12px;
        padding:0;
    }
    .contents{
        padding:30px 20px 40px 20px;
        gap:30px;
    }
    h2{
        font-size:18px;
        font-weight: 600;
        line-height:30px;
        letter-spacing:2.16px;
    }
    p{
        font-size:12px;
        font-weight: 600;
        line-height:21px;
        letter-spacing:0;
    }
    footer{
        padding:20px;
    }
    footer h2{
        font-size:13px;
        font-weight:500;
        line-height:normal;
        letter-spacing:1.3px;
    }
    footer a{
        max-width:260px;
        margin:15px auto;
    }
    footer p{
        font-size:10px;
        font-weight:500;
        line-height: normal;
        letter-spacing:1px;
    }
}