.op {
    transition: 0.35s
}

.op:hover {
    opacity: 0.7 !important
}

.btn {
    transition: 0.35s;
}

.btn:focus,
.btn:hover {
    transform: translate(0px, -5px);
    filter: drop-shadow(0px 4px 10px rgba(0, 0, 0, 0.18));
}

@media screen and (max-width:400px) {
    .btn-arrow {
        position: relative;
        min-width: 32.6rem;
    }
}


.ban-campaign {
    transition: 0.35s;
}

.ban-campaign:focus,
.ban-campaign:hover {
    transform: translate(0px, -5px);
}

.sns-share a {
    transition: 0.35s;
}

.sns-share a:focus,
.sns-share a:hover {
    transform: translate(0px, -5px);
}

/* hero */
.movie {
    _filter: brightness(0.9);
}

#hero .hero-inner {
    display: flex;
    align-items: center;
}

#hero .hero-inner .container {
    _height: 85vh;
}

@media screen and (max-width:959px) {
    #hero .hero-inner .container {
        max-height: initial;
    }
}


@media (min-width: 1200px) {
    #hero {
        min-height: 62.5vw;
    }
}

@media (min-width: 2000px) {
    #hero {
        min-height: initial;
        height: calc(100vh - (8.4rem + 6.5rem));
    }
}

#hero .hero-inner .anniv-logo {
    max-width: 480px;
}

@media screen and (max-width:1800px) {
    #hero .hero-inner .anniv-logo {
        max-width: 438px;
    }
}

@media screen and (max-width:1300px) {
    #hero .hero-inner .anniv-logo {
        max-width: 400px;
    }
}

@media screen and (max-width:767px) {
    #hero .hero-inner .anniv-logo {
        max-width: 325px;
    }
}



#hero .hero-inner h1,
#hero .hero-inner .lead {
    filter: drop-shadow(1px 1px 20px #230848);
}

#hero .hero-inner h1 {
    font-size: 6.5rem;
    font-feature-settings: "palt";
    letter-spacing: 3px;
}

#hero .hero-inner .lead {
    margin-bottom: 0;
}

@media screen and (min-width:1880px) {
    #hero .hero-inner .lead {
        font-size: 2.2rem;
    }
}

@media screen and (max-width:1880px) {
    #hero .hero-inner h1 {
        font-size: 6rem;
    }
}

@media screen and (max-width:1480px) {
    #hero .hero-inner h1 {
        font-size: 5.5rem;
        margin-bottom: 25px
    }

    #hero .hero-inner .lead {
        font-size: 1.8rem;
    }
}

@media screen and (max-width:1280px) {
    #hero .hero-inner h1 {
        font-size: 4.5rem;
    }
}

@media screen and (max-width:767px) {
    #hero .hero-inner .anniv-logo {
        margin-bottom: 3rem;
        width: 26vh;
    }

    #hero .hero-inner h1 {
        margin-bottom: 20px;
        font-size: 3.65rem;
    }

    #hero .hero-inner .lead {
        font-size: 1.5rem;
    }
}

@media screen and (max-width:480px) {
    #hero .hero-inner h1 {
        letter-spacing: 1px;
    }

    #hero .hero-inner .anniv-logo {
        margin-bottom: 4rem;
        width: 26vh;
    }

    #hero .hero-inner h1 {
        margin-bottom: 20px;
        font-size: 3.5rem;
    }

    #hero .hero-inner .lead {
        font-size: 1.5rem;
    }
}

@media (max-width: 399px) {
    #hero .hero-inner .lead {
        font-size: 1.4rem;
    }
}

/* CEO */
#ceos-note {
    padding-top: 4rem;
}

#ceos-note .img-circle {
    margin-bottom: 6rem;
}

#ceos-note .ceo-image img {
    max-width: 250px;
}

#ceos-note .fuwa-elem2 {
    top: 15%;
}

@media screen and (max-width:767px) {
    #ceos-note .ceo-image img {
        width: 47.5%;
    }
}

@media screen and (max-width:480px) {
    #ceos-note {
        padding-top: 0rem;
    }

    #ceos-note .fuwa-elem2 {
        top: 23%;
    }
}


@media screen and (min-width:960px) {
    .card.bordered .h2.year {
        font-size: 5rem;
    }
}

@media screen and (min-width:1200px) {
    .card.bordered .h2.year {
        font-size: 5rem;
    }
}

.card_Beginning img,
.card_2022 img {
    border-radius: 7px;
}

section#figures {
    z-index: -1;
}

@media (min-width: 960px) {

    #event::after,
    #ceos-note::after,
    #figures::after {
        bottom: -2.3rem;
    }
}

@media screen and (max-width:1200px) {

    #event::after,
    #ceos-note::after,
    #figures::after {
        height: 5.75rem;
        bottom: -1.75rem;
    }
}

@media screen and (max-width:767px) {

    #ceos-note::after,
    #event::after,
    #figures::after {
        bottom: -2.2vw;
        height: 5rem;
    }
}

@media screen and (max-width:700px) {

    #event::after,
    #ceos-note::after,
    #figures::after {
        height: 4.5rem;
        bottom: -2.6vw;
    }
}

@media screen and (max-width:480px) {

    #event::after,
    #ceos-note::after,
    #figures::after {
        height: 3.4rem;
        bottom: -2.6vw;
    }
}

@media (min-width: 960px) {
    #campaign .bg-colored .h3 {
        margin-bottom: 3.5rem;
        font-size: 3.5rem;
    }
}

@media screen and (max-width:959px) {
    #campaign .bg-colored .h3 {
        margin-bottom: 25px;
    }
}

@media screen and (max-width:480px) {
    section#history {
        padding-bottom: 4rem;
    }
}

/* history */
@media screen and (max-width:480px) {
    #history .fuwa-elem5 {
        top: -33%;
        right: -11%;
    }
}



/* voices */
@media screen and (max-width:480px) {
    #voices .fuwa-elem1 {
        transform: translateX(-85px);
    }

    #voices .fuwa-elem2 {
        top: 64%;
        transform: translateX(90px);
    }

    #voices .fuwa-elem4 {
        top: 56.5%;
        left: -5%;
    }

    #voices .fuwa-elem8 {
        right: -4%;
        width: 120px;
    }

    #voices .fuwa-elem7 {
        width: 52px;
        transform: translateX(62px);
    }

    #voices .fuwa-elem6 {
        width: 140px;
        left: -5%;
    }
}

/* キャンペーン */
@media screen and (max-width:480px) {
    #campaign .fuwa-elem7 {
        right: -16px;
    }

    #campaign .fuwa-elem6 {
        width: 110px;
        top: -26%;
        left: -24px;
    }


}

/* event */
@media screen and (max-width:480px) {

    #event h3,
    #event .h3 {
        font-size: 1.8rem;
        line-height: 1.35;
    }
}

/* footer */
@media screen and (max-width:480px) {
    footer {
        margin-top: 4.5rem;
    }

    footer .copyright {
        margin: 11rem 0 0;
    }
}
