@charset "UTF-8";
@import url(top.css);
@import url(event_detail.css);
@import url(default.css);
@import url(header.css);
@import url(footer.css);
* {
    margin: 0;
    padding: 0;
    text-decoration: none;
}
html {
    overflow-x: hidden;
}
:root {
    --vivid-blue: #1d50a2;
    --vivid-deep-blue: #1349a1;
    --vivid-yellow: #feef00;
    --blue: #1d50a2;
    --lightblue: #d2e7ec;
    --yellow: #feef00;
}
.Nothing {
    font-family: "nothing", sans-serif;
    font-weight: 400;
    font-style: normal;
}
.f1-bold {
    font-family: noto-sans-cjk-jp, sans-serif;
    font-weight: 700;
    font-style: normal;
}
.Ingra-bold {
    font-family: "ingra", sans-serif;
    font-weight: 700;
    font-style: normal;
}
.notosans {
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-weight: 500;
    font-style: normal;
}
.scroll_up {
    transition: 0.8s ease-in-out;
    transform: translateY(30px);
    opacity: 0;
}
.scroll_up.on {
    transform: translateY(0);
    opacity: 1;
}
.br-sp {
    display: none;
}
.img-sp {
    display: none;
}
@media screen and (min-width:780px) and (max-width:1000px) {
    .br-sp {
        display: inline;
    }
    .br-pc {
        display: none;
    }
}
@media screen and (max-width:780px) {
    .br-sp {
        display: inline;
    }
    .br-pc {
        display: none;
    }
    .img-sp {
        display: inline;
    }
    .img-pc {
        display: none;
    }
}
.main-top {
    position: relative;
    width: 100%;
}
.top-text {
    position: absolute;
    top: 0;
    left: 0;
    width: 51%;
    clip-path: polygon(0% 100%, 0% 0%, 100% 0%, 85% 100%);
    padding: 14rem 0;
    background-color: #0D387C;
    z-index: 1;
}
.top-text>h1 {
    margin-left: 42%;
    font-size: 4rem;
    color: #fff;
}
.top-text>p {
    margin: 2rem 0 0 42%;
    color: #fff;
}
.main-top-img {
    margin: 0 0 0 auto;
    width: 57%;
    padding: 18rem 0;
    background-repeat: no-repeat;
}
@media screen and (min-width:1280px) and (max-width:1500px) {
    .top-text>h1 {
        margin-left: 38%;
    }
    .top-text>p {
        margin-left: 38%;
    }
}
@media screen and (min-width:1000px) and (max-width:1280px) {
    .top-text>h1 {
        margin-left: 20%;
    }
    .top-text>p {
        margin-left: 20%;
    }
}
@media screen and (min-width:780px) and (max-width:1000px) {
    .top-text>h1 {
        margin-left: 15%;
        font-size: 3.6rem;
    }
    .top-text>p {
        margin-left: 15%;
    }
    .main-top-img {
        background-position: center;
    }
}
@media screen and (max-width:780px) {
    .top-text {
        top: auto;
        bottom: -2rem;
        width: 100%;
        max-width: 50rem;
        padding: 2rem 0;
    }
    .top-text>h1 {
        margin-left: 4%;
        font-size: 3rem;
    }
    .top-text>p {
        margin: 0 0 0 4%;
    }
    .main-top-img {
        width: 100%;
        background-position: center;
    }
}
footer {
    width: 100%;
    background-color: #fff;
}
.foot-link {
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    width: 57%;
    min-width: 93rem;
    padding: 2rem 0;
}
.foot-logo {
    width: 18%;
    padding-bottom: 1rem;
}
.foot-logo>p {
    margin-top: .6rem;
    width: fit-content;
    padding: .2rem .5rem;
    font-size: 1.4rem;
    color: var(--blue);
    border: .1rem solid var(--blue);
}
.foot-logo a {
    color: #000;
}
.foot-logo p {
    color: #000;
}
.foot-link>ul {
    display: flex;
    flex-wrap: wrap;
    width: 50%;
    gap: .5%;
}
.foot-link>ul>li {
    margin-bottom: .6rem;
    width: 33%;
    font-size: 1.3rem;
}
.foot-link>ul>li>a::before {
    content: "\f104";
    margin-right: .6rem;
    color: var(--blue);
    font-weight: 900;
    font-family: "Font Awesome\ 5 Free";
}
.foot-link>ul>li>a {
    color: #000;
}
.foot-link>ul>li>p::before {
    content: "\f104";
    margin-right: .6rem;
    color: var(--blue);
    font-weight: 900;
    font-family: "Font Awesome\ 5 Free";
}
.foot-link>ul>li>p {
    color: #000;
    cursor: pointer;
}
.copylight {
    padding: 1rem 0;
    text-align: center;
    font-size: 1.2rem;
    color: #fff;
    background-color: var(--blue);
}
.fot_policy {
    margin: 0 auto 15px;
    width: 48%;
    min-width: 80rem;
    padding: 2rem 0;
}
.fot_policy ul {
    display: flex;
    color: #000;
    justify-content: end;
}
.fot_policy li {
    padding-left: 25px;
}
.fot_policy a {
    font-size: 14px;
    color: #000;
}
.external_link li {
    width: 180px;
}
.sp_qr{/*20260210*/
    /* display: none; */
    display: flex;
    flex-direction: column;
    margin-bottom: .8rem;
}
.sp_qr img{
    margin: 0 auto;
    max-width: 8rem;
}
.sp_qr_text{
    font-size: 13px;
    text-align: center;
}
/*.external_link li:first-of-type{width:155px}*/
.external_link li:first-of-type a {
    width: 100%;
}
.external_link li:nth-of-type(2) {
    width: 195px;
}
.external_link a {
    display: block;
    color: #000;
}
.external_link img {
    width: 100%;
    object-fit: cover;
}
@media screen and (max-width:940px) {
    .external_link li {
        margin: 0 calc(8 / 940 * 100vw);
        width: calc(180 / 940 * 100vw);
    }
    /*.external_link li:first-of-type a{margin-left:calc(-35 / 940 * 100vw)}*/
    .external_link li:nth-of-type(2) {
        width: calc(195 / 940 * 100vw);
    }
}
@media screen and (min-width:780px) and (max-width:940px) {
    .foot-link {
        width: 90%;
        min-width: initial;
    }
    .foot-logo {
        width: 16.5rem;
    }
    .foot-link>ul {
        width: 46.5rem;
    }
    .fot_policy {
        width: 78%;
        min-width: initial;
    }
}
@media screen and (max-width:780px) {
    .copylight {
        padding: 1.4rem 0;
    }
    .foot-link {
        flex-direction: column;
        width: 100%;
        min-width: initial;
        padding: 1.4rem 0;
    }
    .foot-link>ul {
        display: none;
    }
    .foot-logo {
        width: 50%;
        max-width: 30rem;
        margin: 0 auto;
    }
    .foot-logo>p {
        margin: .6rem auto;
    }
    .fot_policy {
        display: none;
    }
    .external_link ul {
        margin: 2rem auto 0;
        display: flex;
        flex-wrap: wrap;/*20260210*/
        width: 90%;
        align-items: center;
    }
    .external_link li {
        margin: 0 .5rem;
        /* width: 30rem; */
        width: 100% !important;/*20260210*/
    }
    .external_link_banner_wrap a{
        margin: 0 auto;
        max-width: 30rem;
        width: 85%;
    }
    .external_link_banner_wrap li:first-of-type{
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 1rem;
    }
    .external_link_banner_wrap li:first-of-type a{
        margin: 0 0;
        max-width: 22rem;
        width: 60%;
    }
    .sp_qr{
        max-width: 10rem;
        width: 30%;
    }
    .sp_qr_text{
        display: none;
    }
    /* .external_link li:first-of-type a {
        margin-left: 0;
    }
    .external_link li:first-of-type, .external_link li:nth-of-type(2) {
        width: 30rem;
    } */
    .external_link li:last-of-type {
        display: flex;
        justify-content: center;
    }
    .external_link a {
        font-size: 1.4rem;
    }
}
@media screen and (max-width:500px) {
    .external_link ul {
        margin: 2rem auto 0;
        display: flex;
        width: 100%;
    }
    .external_link li {
        margin: 0 0;
        width: 30rem;
    }
    .external_link li:nth-of-type(2) {
        width: 30rem;
    }
    .external_link a {
        font-size: 1.2rem;
    }
}
.drone_menu {
    cursor: pointer;
}
.drone_video {
    margin: 0 auto;
    display: block;
    width: 1600px;
    height: 800px;
}
.drone_video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media screen and (max-width:1700px) {
    .drone_video {
        width: calc(1600 / 1700 * 100vw);
        height: calc(800 / 1700 * 100vw);
    }
}
@media screen and (max-width:780px) {
    .drone_video {
        width: calc(720 / 780 * 100vw);
        height: calc(500 / 780 * 100vw);
    }
}
.drone_menu {
    margin: -18px 0 0;
}
.foot-link>ul>li:nth-of-type(13)>a::before, .foot-link>ul>li:nth-of-type(14)>a::before {
    color: transparent;
}
#pagetop {
    position: fixed;
    bottom: 25px;
    right: 25px;
    width: 50px;
    height: 50px;
    z-index: 8;
}
#pagetop img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
body.active #pagetop {
    display: none;
}
@media screen and (max-width:780px) {
    #pagetop {
        right: calc(10 / 780 * 100vw);
    }
}
@media screen and (max-width:500px) {
    #pagetop {
        bottom: calc(10 / 500 * 100vw);
        width: 50px;
        height: 50px;
    }
}