/*****************************************************************
全てに適用
*****************************************************************/
* {
    box-sizing: border-box;
}
body {
    overflow-x: hidden;
    min-height: 100vh;
    overflow-wrap: anywhere;
    word-break: normal;
    overflow-wrap: break-word;
    line-height: 1.75em;
}
ul.type1,
ol.type1 {
    padding: 0;
    margin: .8em 0;
}
ul.type1 li,
ol.type1 li {
    margin: .6em 0 0 2em;
}
.list-indent {
    padding-left: 1.5em;
}
p {
    font-size: inherit;
    line-height: 1.75em;
}
.btn {
    font-size: 1rem;
    padding: 1rem 2rem;
    display: block;
}
.pointer-none {
    pointer-events: none;
    opacity: 0.3;
}
.btn-wrap {
    margin-top: 2rem;
    margin-bottom: 2rem;
    justify-content: center;
    gap: 3rem;
}
#nav_icon {
    width: 3em;
    height: 2.75em;
    background-color: #009fe8;
    top: 0.5rem;
}
#nav_icon .menu-ic,
#nav_icon .menu-ic:before,
#nav_icon .menu-ic:after {
    width: 2em;
    background-color: #fff;
}
#nav_icon .menu-ic {
    top: 1.2em;
}
#nav_icon .menu-ic:before {
    top: -0.6em;
}
#nav_icon .menu-ic:after {
    bottom: -0.6em;
}
body.drawer-opened header {
    height: 60px;
}
body.drawer-opened nav.type1 .nav-contents {
    top: 60px !important;
    height: calc(100vh - 60px);
    max-height: calc(100vh - 60px);
    background-color: #b2e2f8;
    overflow-y: scroll;
    padding-bottom: 50px;
}
body.drawer-opened nav.type1 .nav-contents > ul {
    padding: 20px 10px;
    font-size: 80%;
    overflow-y: scroll;
}
body.drawer-opened nav.type1 .nav-contents > ul li {
    width: 100%;
}
@media (width <= 991px ) {
    h3 {
        font-size: 1.1rem;    
    }
    /* .btn-wrap {
        gap: 2rem;
    } */
}


/*****************************************************************
header
*****************************************************************/
header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 110px;
}
@media (width <= 991px ) {
    header {
        height: 60px;
    }
}
@media (width <= 767px ) {
    header .w960 h1 {
        width: 80%;
        margin-left: 0;
    }
}

/*****************************************************************
main
*****************************************************************/
main {
    content: "";
    background-image: url(../img/bg.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
main .container {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 30px 0;
    margin-inline: auto;
    width: 100%;
    max-width: 960px;
}
main .contents {
    width: 710px;
}
main .sidebar {
    width: 230px;
    padding: 0 10px;
}
main .sidebar .banner-list,
main .sidebar .banner-list a img,
main .sidebar .video-banner img,
main .sidebar .flyer img{
    margin-top: 10px;
}
main .news {
    margin-top: 30px;
    background-color: #fff;
}
main .news h2 {
    font-size: 1.25rem;
    font-weight: 500;
    background-color: #009fe8;
    color: #fff;
    padding: 5px 15px;
}
main .news dl {
    padding: 30px;
}
main .news dl dt {
    width: 120px;
}
main .news dl dd {
    width: calc(100% - 120px);
    margin: 0 0 1em 0;
}
@media (width <= 991px ) {
    main .container {
        flex-direction: column-reverse;
        align-items: center;
    }
    main .sidebar {
        width: 710px;
    }
    main .sidebar .banner-list {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 10px;
        margin-bottom: 30px;
    }
    main .news {
        margin: 30px 0;
    }
    main .news .log {
        height: 180px;
        overflow-y: scroll;
    }
}
@media (width <= 767px ) {
    main .container {
        padding: 10px 10px 30px 10px;
    }
    main .contents {
        width: 100%;
    }
    main .sidebar {
        width: 100%;
    }
    main .news dl {
        padding: 10px 20px;
    }
    main .news dl dt {
        width: 100%;
    }
    main .news dl dd {
        width: 100%;
    }
}

/*****************************************************************
nav
*****************************************************************/
nav ul {
    margin: 0;
    /* padding: 0 10px 32px 10px; */
    width: 100%;
    display: block;
}
nav ul li {
    margin-bottom: 5px;
}
nav.type1 ul li > a{
    font-size: 0.9rem;
    font-weight: 500;
    line-height: 1.3rem;
    color: #182987;
    background-color: #fff;
    padding: 0 5px;
    height: 50px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    font-feature-settings: "palt";
}
nav ul li a.current {
    background-color: #fdd108;
    color: #182987;
}

/*****************************************************************
address
*****************************************************************/
address {
    padding: 20px;
}
address:first-of-type {
    width: 55%;
}
address:last-of-type {
    width: 45%;
}
address p {
    line-height: 1.75em;
}
address .role {
    font-weight: 500;
    color: #009fe8;
    padding-bottom: 10px;
    border-bottom: 1px solid #009fe8;
}
address .name {
    font-weight: bold;
}
address .info {
    font-size: 80%;
}
@media (width <= 991px ) {
    address {
        padding: 10px;
    }
    address:first-of-type {
        width: 100%;
    }
    address:last-of-type {
        width: 100%;
    }
}

/*****************************************************************
footer
*****************************************************************/
footer a {
    color: #0000FF;
}

/*****************************************************************
copybg
*****************************************************************/
.copybg {
    font-size: 75%;
    background-color: #009fe8;
    padding: 10px;
}

/*****************************************************************
サブページ　.subpage
*****************************************************************/
.subpage .contents {
    background-color: #fff;
    padding: 30px;
}
.subpage .contents h2 {
    font-size: 1.5rem;
    font-weight: bold;
    color: #009fe8;
    padding-bottom: 10px;
    margin-bottom: 2rem;
    border-bottom: 1px solid #009fe8;
}
.subpage .contents h3 {
    font-size: 1.25rem;
    font-weight: 500;
    color: #009fe8;
    margin-top: 2rem;
}
.subpage .contents h4 {
    font-size: 1rem;
    font-weight: 600;
    padding-bottom: 0.5em;
    margin-top: 1.5em;
    border-bottom: 1px solid #999;
}
.subpage .contents table {
    width: 100%;
    margin: 1rem auto;
}
.subpage .contents table th,
.subpage .contents table td {
    padding: 0.5rem 1rem;
    border: 1px solid #ccc;
}
.subpage .contents table th {
    background-color: #eee;
}
@media (width <= 991px ) {
    .subpage .contents {
        padding: 2rem 1rem;
        margin-bottom: 1rem;
    }
}
@media (width <= 767px ) {
    .subpage .contents h2 {
        font-size: 1.2rem;
    }
}

/*****************************************************************
大会会長挨拶　.subpage#greeting
*****************************************************************/
.subpage#greeting .contents .flex-wrap {
    justify-content: end;
    gap: 20px;
    align-items: end;
}
.subpage#greeting .contents .name p {
    /* font-size: 80%; */
    text-align: right;
    line-height: 2em;
}
.subpage#greeting .contents .name p span {
    font-size: 1.25rem;
    font-weight: bold;
}
@media (width <= 767px ) {
    .subpage#greeting .contents .flex-wrap {
        flex-direction: column-reverse;
        margin-inline: auto;
    }
    .subpage#greeting .contents .name {
        margin-inline: auto;
    }
    .subpage#greeting .contents .name p {
        font-size: 70%;
        text-align: center;
    }
    .subpage#greeting .contents .ph {
        margin-inline: auto;
    }
}

/*****************************************************************
開催概要　.subpage#outline
*****************************************************************/
.subpage#outline .contents dl {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
}
.subpage#outline .contents dl dt,
.subpage#outline .contents dl dd {
    padding: 1rem;
    border-bottom: 1px solid #ccc;
}
.subpage#outline .contents dl dt {
    width: 8em;
    font-weight: bold;
}
.subpage#outline .contents dl dd {
    width: calc(100% - 8em);
}
@media (width <= 767px ) {
    .subpage#outline .contents dl dt,
    .subpage#outline .contents dl dd {
        padding: 1rem 0.5rem;
        width: 100%;
    }
    .subpage#outline .contents dl dt {
        padding-bottom: 0;
        border-bottom: none;
    }
    .subpage#outline .contents dl dd {
        padding-top: 0;
        border-bottom: 1px solid #ccc;
    }
}

/*****************************************************************
会場アクセス　.subpage#access
*****************************************************************/
.subpage#access .contents dl {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 1rem;
}
.subpage#access .contents dl dt {
    width: 8em;
    font-weight: bold;
}
.subpage#access .contents dl dd {
    width: calc(100% - 8em);
}
@media (width <= 767px ) {
    .subpage#access .contents dl dt,
    .subpage#access .contents dl dd {
        width: 100%;
    }
}
