 
/* 
Theme Name: MOIF2024
Version: 1.0
*/
@charset "UTF-8";
@font-face {
    font-family: 'Bahnschrift';
    src:
        url("../font/bahnschrift.ttf") format("truetype");
}
/* CSS Document */
html {
    font-size: 62.5%;
    -webkit-font-smoothing: antialiased;
    text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
    font-family: "Noto Sans JP", sans-serif;
    color: black;
}
body {
    width: 100%;
    height: 100%;
    font-size: 1.6em;
    line-height: 1.8;
    /* letter-spacing: 0.1rem; */
    /* font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic","Noto Sans JP", sans-serif; */
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    overflow-x: hidden;
}
a {
    text-decoration: none;
    transition:all 0.3s ease;
    color: inherit;
}
a:hover{
    transition:all 0.3s ease;
    outline:none;
    opacity: 0.8;
}
*,
*:before,
*:after {
    box-sizing:border-box;
}
@media (max-width: 500px){
    body {
        font-size: 1.4em;
        line-height: 1.5;
    }
}
/* ------------------------------------- /
/   共通
/* ------------------------------------- */
.taC {
    text-align: center;
}
.taR {
    text-align: right;
}
.fw600 {
    font-weight: 600;
}
.fw700 {
    font-weight: 700;
}
.fwB {
    font-weight: bold;
}
.iB {
    display: inline-block;
}
.space {
    margin-top: 128px;
}
.inner {
    width: 87.85%;
    max-width: 1200px;
    margin: 0 auto;
}
/* ------------------------------------- /
/  TOPへ戻るボタン
/* ------------------------------------- */
#top .page-top {
    position: fixed;
    bottom: 28px;
    right: 28px;
    height: 60px;
    width: 60px;
    background: linear-gradient(0deg, #0a0a23 0%, #6f6f77 100%);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    color: white;
    z-index: 4;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 5px;
    font-weight: 700;
    font-family: 'Bahnschrift';
    font-size: 1.3rem;
}
#top .page-top span {
    display: block;
}
#top .page-top span img {
    transform: rotate(270deg);
}
@media (max-width: 768px){
    #top .page-top {
        bottom: 20px;
        right: 20px;
        height: 50px;
        width: 50px;
    }
}
/* ------------------------------------- /
/  事前来場者登録ボタン
/* ------------------------------------- */
#top .register {
    position: fixed;
    bottom: 160px;
    right: 28px;
    width: 160px;
    height: 160px;
    color: white;
    z-index: 5;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 2.5rem;
    line-height: 1.44;
    font-weight: 700;
    background: linear-gradient(0deg, rgb(13, 29, 134) 0%, rgb(131, 79, 229) 100%);    border-radius: 50%;
    text-align: center;
}
#top .register span {
    position: relative;
}
#top .register span::after {
    content: '';
    position: absolute;
    width: 18px;
    height: 18px;
    bottom: -20px;
    left: 50%;
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
    background-size: cover;
    transform: translateX(-50%);
}
@media (max-width: 768px){
    #top .register {
        bottom: 100px;
        right: 10px;
        width: 130px;
        height: 130px;
        font-size: 1.6rem;
    }
}

/* ------------------------------------- /
/  スクロール後のヘッダーメニュー
/* ------------------------------------- */
#g_nav {
    top: 0;
    display: flex;
    width: 100%;
    position: fixed;
    z-index: 11;
    height: 83px;
    background-color: rgba(255,255,255,0.95);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    box-shadow: 0 0 25px rgb(0 0 0 / 17%);
}
#g_logo {
    max-width: 200px;
}
#g_nav > div {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 100px;
    padding: 0 20px;
}
#g_nav nav {
    display: flex;
    margin: 0 0 0 auto;
    align-items: center;
    list-style: none;
    line-height: 1;
}
#g_nav li:not(:last-child) {
    margin-right: 15px;
}
#g_nav .header__menu--item a span {
    font-size: 2.2rem;
    color: #834FE5;
    margin-bottom: 5px;
    font-weight: 700;
}
#g_nav .header__menu--item a p {
    font-size: 1.3rem;
    font-family: "Noto Sans JP", sans-serif;
    color: black;
    font-weight: 500;
}
#demo1 .section_demo_list {
    padding-top: 25px;
}
#demo2 .section_demo_list {
    padding-top: 25px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
@media (max-width: 1080px){
    #g_nav nav {
        display: none;
    }
    #g_nav .section_demo {
        display: none;
        height: calc(100vh - 83px);
        width: 100vw;
        background-color: rgba(255, 255, 255, 0.95);
        color: white;
        position: relative;
        z-index: 13;
    }
}
@media (min-width: 991px){
    #demo1 {
        display: none;
    }
    #demo2 {
        display: none;
    }
}

@media screen and (max-width: 1080px) {
/* BUTTON（SP）
================================================== */
/* #g_nav .btn_hamburger {position: absolute;width: 30px;top: 40px;right: 25px;margin: 0 0 0 auto !important;padding: 0;transform: translateY(-50%);}
#g_nav .btn_hamburger a {position: relative;display: block;height: 16px;-webkit-transition: all .4s;transition: all .4s;box-sizing: border-box;}
#g_nav .btn_hamburger span {position: absolute;display: inline-block;left: 0;width: 100%;height: 1px;background-color: #161b1d;border-radius: 2px;-webkit-transition: all .4s;transition: all .4s;box-sizing: border-box;}
#g_nav .btn_hamburger span:nth-of-type(1) {top: 0;}
#g_nav .btn_hamburger span:nth-of-type(2) {top: 7px;}
#g_nav .btn_hamburger span:nth-of-type(3) {bottom: 0;}
#g_nav .btn_hamburger span:nth-of-type(2)::after {position: absolute;top: 0;left: 0;content: '';width: 100%;height: 1px;background-color: #161b1d;border-radius: 2px;-webkit-transition: all .4s;transition: all .4s;}
#g_nav .btn_hamburger .active span:nth-of-type(2) {-webkit-transform: rotate(-45deg);-ms-transform: rotate(-45deg);transform: rotate(-45deg);}
#g_nav .btn_hamburger .active span:nth-of-type(2)::after {-webkit-transform: rotate(90deg);-ms-transform: rotate(90deg);transform: rotate(90deg);}
#g_nav .btn_hamburger .active span:nth-of-type(1) {-webkit-transform: translateY(20px) scale(0);-ms-transform: translateY(20px) scale(0);transform: translateY(20px) scale(0);}
#g_nav .btn_hamburger .active span:nth-of-type(3) {-webkit-transform: translateY(-20px) scale(0);-ms-transform: translateY(-20px) scale(0);transform: translateY(-20px) scale(0);} */
/* ▲ BUTTON（SP） ▲ ===================================== */
}
/* ------------------------------------- /
/  first view
/* ------------------------------------- */
#fv {
    position: relative;
    height: auto;
    /* height: calc(100vh - 100px); */
    /* min-height: 620px; */
    z-index: 3;
    /* background: url(../img/fv_bg.webp), #fff; */
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    margin-top: -100px;
    overflow: hidden;
    background-color: #fff;
}
#fv .fv_bg {
    object-fit: cover;
}
#fv picture {
    width: 100%;
    height: 100%;
    display: block;        /* 余白防止 */
    position: relative;    /* 特に不要だが念のため */
}

#fv picture img {
    width: 100%;
    height: 100%;
    object-fit: cover;     /* #fvの高さにフィット */
    display: block;        /* 画像下の余白防止 */
}
/* スクロールしていないときのヘッダーメニュー */
header {
    width: 100%;
    margin: 0 auto;
    height: 100px;
    color: #834FE5;
    background-color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    padding-right: 58px;
    padding-left: 30px;
    top: 0;
    z-index: 9999;
}
.header__menu {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
.btn_hamburger {
    display: none;
}
.header__menu--item {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 0 20px;
}
.header__menu--item a {
    display: flex;
    flex-direction: column;
    align-items: center;
}
nav {
    line-height: 1;
    font-family: 'Bahnschrift';
}
nav .header__menu--item a span {
    font-size: 2.2rem;
    margin-bottom: 5px;
    font-weight: 700;
}

#demo2 .section_demo_list .header__menu--item {
    margin-bottom: 25px;
}
#demo2 .section_demo_list .header__menu--item a {
    line-height: 1;
}
#demo2 .section_demo_list .header__menu--item a span {
    font-size: 2.2rem;
}
#demo2 .section_demo_list .header__menu--item a p {
    font-size: 1.6rem;
}
nav .header__menu--item a p {
    font-size: 1.3rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    color: #1A1311;
}
#fv_theme {
    height: 100%;
    width: 100%;
}
#fv_theme img {
    width: max(min(40%, 496px), 240px);
    height: 94%;
    object-fit: contain;
    object-position: top left;
}
#fv_logo {
    max-width: 312px;
}
.fv_content ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 42px;
    font-size: clamp(1.6rem, 2vw, 2.0rem);
    font-weight: 700;
    font-family: "Noto Sans JP", sans-serif;
    margin-bottom: 48px;
}
.fv_content ul li {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em;
}
.fv_content ul li::before {
    content: '';
    display: block;
    width: 1em;
    height: 1em;
    background: #000;
    border-radius: 50%;
}
.fv_content ul li:nth-child(1)::before{
    background: #FF007A;
}
.fv_content ul li:nth-child(2)::before{
    background: #00FF00;
}
.fv_content ul li:nth-child(3)::before{
    background: #FF9500;
}
.fv_content ul li:nth-child(4)::before{
    background: #7600FF;
}
.fv_content ul li:nth-child(5)::before{
    background: #00B8FF;
}
#fv_banner {
    width: 100%;
    margin: 0 auto;
}
#fv_banner img {
    margin: 0 auto;
}
#fv_banner img:nth-child(1){
    margin-bottom: 48px;
}
#fv_banner img:nth-child(2){
    width: 535px;
}
#topics {
    width: 100%;
    color: white;
    background-color: #0A176A;
}
#topics_inner {
    display: flex;
    height: 100%;
    align-items: center;
}
#topics_ttl {
    display: flex;
    align-items: center;
    padding: 10px 20px;
    height: 100%;
    min-width: 110px;
    border-right: 1px white solid;
}
#topics_box {
    display: flex;
    align-items: center;
    padding: 10px 20px;
    min-height: 70px;
    gap: 20px;
}
.bggrid {
    margin-top: 60px;
}
.bggrid .exhibitor__grid {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
}
.exhibitor__grid--item {
    cursor: pointer;
    width: calc((100% - 30px * 4) / 5);
    display: block;
}
.exhibitor__grid--item__img {
    height: 120px;
    padding:  8px 14px 0 14px;
    position: relative;
    border-radius: 3px;
    display: flex;
    justify-content: center;
    position: relative;
}
.exhibitor__grid--item__img .plus__button {
    position: absolute;
    background-color: #0A176A;
    width: 35px;
    height: 35px;
    bottom: 0;
    right: 0;
    border-radius: 3px;
}
.exhibitor__grid--item__img .plus__button::after {
    content: '';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
}
.exhibitor__grid--item__img > img {
    height: 100%;
    object-fit: contain;
}
.exhibitor__grid--item__subtitle {
    font-size: 1.2rem;
    font-weight: 500;
}
.exhibitor__grid--item__title {
    font-size: 1.6rem;
    font-weight: 700;
}
@media (max-width: 1800px){
    #fv_logo {
        top: 100px;
        left: unset;
        right: 8%;
    }
}
@media (max-width: 1570px){
    #fv {
        margin-top: -75px;
        /* height: calc(100vh - 145px); */
    }
    header {
        height: 75px;
        padding-right: 30px;
    }
    .header__menu {
        /* display: none; */
    }
    .header__menu--item {
        margin: 0 10px;
    }
    nav .header__menu--item a span {
        font-size: 2.0rem;
    }
    nav .header__menu--item a p {
        font-size: 1.2rem;
    }
    #fv_logo {
        top: 15px;
        max-width: 240px;
    }
}
@media (max-width: 1200px) {
    .header__menu {
        display: none;
    }
    /* BUTTON（SP）
    ================================================== */
    .btn_hamburger {display: block; position: fixed;width: 30px;top: 40px;right: 25px;margin: 0 0 0 auto !important;padding: 0;transform: translateY(-50%);z-index: 10000;}
    .btn_hamburger a {position: relative;display: block;height: 16px;-webkit-transition: all .4s;transition: all .4s;box-sizing: border-box;}
    .btn_hamburger span {position: absolute;display: inline-block;left: 0;width: 100%;height: 1px;background-color: #000;border-radius: 2px;-webkit-transition: all .4s;transition: all .4s;box-sizing: border-box;}
    .btn_hamburger span:nth-of-type(1) {top: 0;}
    .btn_hamburger span:nth-of-type(2) {top: 7px;}
    .btn_hamburger span:nth-of-type(3) {bottom: 0;}
    .btn_hamburger span:nth-of-type(2)::after {position: absolute;top: 0;left: 0;content: '';width: 100%;height: 1px;background-color: #000;border-radius: 2px;-webkit-transition: all .4s;transition: all .4s;}
    .btn_hamburger .active span:nth-of-type(2) {background-color: #000;}
    .btn_hamburger .active span:nth-of-type(2) {-webkit-transform: rotate(-45deg);-ms-transform: rotate(-45deg);transform: rotate(-45deg);}
    .btn_hamburger .active span:nth-of-type(2)::after {-webkit-transform: rotate(90deg);-ms-transform: rotate(90deg);transform: rotate(90deg);background-color: #000;}
    .btn_hamburger .active span:nth-of-type(1) {-webkit-transform: translateY(20px) scale(0);-ms-transform: translateY(20px) scale(0);transform: translateY(20px) scale(0);}
    .btn_hamburger .active span:nth-of-type(3) {-webkit-transform: translateY(-20px) scale(0);-ms-transform: translateY(-20px) scale(0);transform: translateY(-20px) scale(0);}
}
@media (max-width: 1080px){
    .section_demo {
        display: none;
        height: 100vh;
        width: 100vw;
        background-color: rgb(0, 0, 0);
        color: white;
        position: fixed;
        z-index: 13;
        top: 0;
    }
    #g_nav nav {
        display: none;
    }
    #g_nav .section_demo {
        display: none;
        height: calc(100vh - 83px);
        width: 100vw;
        background-color: rgba(255, 255, 255, 0.95);
        color: white;
        position: relative;
        z-index: 13;
    }
    .bggrid .exhibitor__grid {
        gap: 25px;
    }
    .exhibitor__grid--item {
        cursor: pointer;
        width: calc((100% - 25px * 3) / 4);
        display: block;
    }
}
@media (max-width: 768px){
    /* #fv {
        min-height: 730px;
    } */
    #topics_ttl {
        display: none;
    }
    .bggrid {
        margin-top: 30px;
    }
    .bggrid .exhibitor__grid {
        gap: 25px;
    }
    .exhibitor__grid--item {
        cursor: pointer;
        width: calc((100% - 25px * 2) / 3);
        display: block;
    }
    /* @media (max-height:800px){ */
        #fv_banner {
            width: calc(100% - 70px);
            right: 60px;
            bottom: 10px;
        }
    /* } */
    .fv_content ul {
        column-gap: 30px;
        margin-bottom: 18px;
    }
    .fv_content ul li {
        column-gap: 0.5em;
    }
    #fv_logo {
        top: 22px;
        right: 80px;
        max-width: 240px;
    }
}
@media (max-width: 600px){
    #fv {
        /* height: calc(100vh - 145px); */
        /* margin-top: -30px; */
    }
    #fv_banner {
        top: 300px;
    }
    #fv_logo {
        max-width: 200px;
    }
}
@media (max-width: 500px){
    .bggrid .exhibitor__grid {
        gap: 15px;
    }
    .exhibitor__grid--item {
        cursor: pointer;
        width: calc((100% - 15px * 1) / 2);
        display: block;
    }
    #fv_logo {
        top: unset;
        bottom: 13%;
        right: unset;
        left: 10px;
        max-width: unset;
        width: calc(100% - 70px);
    }
}
/* ------------------------------------- /
/  main
/* ------------------------------------- */
main {
    position: relative;
    background-color: #fff;
}
/* ------------------------------------- /
/  caution
/* ------------------------------------- */
.caution {
    padding: 20px 0;
    font-size: 2.0rem;
    color: white;
    text-align: center;
    font-weight: 700;
}
@media (max-width: 768px){
    .caution {
        padding: 20px 0;
        font-size: 1.5rem;
    }
}
/* ------------------------------------- /
/  about
/* ------------------------------------- */
.about {
    padding: 120px 0 100px;
    color: #1A1311;
    position: relative;
}
.about .about_bg_1 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave.png) repeat-x, #F2F2F2;
    background-size: 4305px 556px;
    background-position: 0 -20%;
    animation: bgloop_about_1 50s linear infinite;
    /* mix-blend-mode: screen; */
}
@keyframes bgloop_about_1 {
    from {background-position: 0  -20%;}
    to {background-position: -4305px -20%;}
}
.about .about_bg_2 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave_2.png) repeat-x;
    background-size: 4728px 1026px;
    background-position: 0 100%;
    animation: bgloop_about_2 50s linear infinite;
    opacity: 0.15;
    /* mix-blend-mode: screen; */
}
@keyframes bgloop_about_2 {
    from {background-position: 0  100%;}
    to {background-position: -4728px 100%;}
}
.about .inner {
    position: relative;
}
.about .inner .container {
    display: flex;
    justify-content: space-between;
    padding-bottom: 145px;
}
.about .inner .container .inner__left {
    width: 45%;
    position: relative;
}
.about .inner .container .inner__left .circle {
    position: absolute;
    width: 56%;
    aspect-ratio: 1;
    border-radius: 50%;
    background-color: rgba(26, 19, 17, 0.4);
}
.about .inner .container .inner__left .circle .circle__inner {
    width: 100%;
    height: 100%;
    position: absolute;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-size: 1.6rem;
    font-weight: 700;
}
.about .inner .container .inner__left .circle .tag {
    margin-top: 12px;
    padding: 5px 20px;
    border-radius: 20px 0 20px 0;
    background: linear-gradient(270deg, #0D1D86 0%, #D5016F 100%);
    font-size: 1.4rem;
}
.about .inner .container .inner__left .circle.c1 {
    top: 0;
    left: 22%;
}
.about .inner .container .inner__left .circle.c1 .circle__inner {
    top: -30px;
}
.about .inner .container .inner__left .circle.c2 {
    bottom: 0;
    left: 0;
}
.about .inner .container .inner__left .circle.c2 .circle__inner {
    top: 30px;
}
.about .inner .container .inner__left .circle.c3 {
    bottom: 0;
    right: 0;
}
.about .inner .container .inner__left .circle.c3 .circle__inner {
    top: 30px;
}
.about .inner .container .inner__left .overlay {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 3.8rem;
    line-height: 1.13;
    text-align: center;
    font-family: 'Bahnschrift', sans-serif;
    font-weight: 700;
}
.about .inner .container .inner__right {
    width: 47.5%;
    position: relative;
    z-index: 2;
}
.about .inner .container .inner__right .ttl__bg {
    /* position: absolute; */
    /* top: 0; */
    /* right: 0; */
    display: block;
    color: rgb(131 79 229 / 30%);
    font-size: 17.3rem;
    line-height: 1;
    z-index: -1;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    text-align: right;
    width: 100%;
}
.about .inner .container .inner__right .ttl {
    position: relative;
}
.about .inner .container .inner__right h2 {
    /* padding-top: 100px; */
    font-size: 3.5rem;
    /* margin-bottom: 30px; */
    font-weight: 700;
    position: absolute;
    bottom: 0;
    width: 100%;
}
.about .inner .container .inner__right h2 .sm {
    font-size: 2.6rem;
}
.about .inner .container .inner__right p {
    /* padding-bottom: 15px; */
}
.about .inner .box {
    width: 100%;
    /* border: 1px solid white; */
    background-color: #ffffff;
    border-radius: 200px 0 200px 0;
    padding: 77px 20px 79px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.about .inner .box h3 {
    font-size: 3.2rem;
    font-weight: 700;
}
.about .inner .box ul {
    margin: 50px auto;
}
.about .inner .box ul li {
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 2.0rem;
    margin-bottom: 10px;
}
.about .inner .box ul li img {
    width: 33px;
}
.about .inner .box a {
    font-size: 2.0rem;
    border-radius: 5px;
    color: #fff;
    background: linear-gradient(0deg, rgb(13, 29, 134) 0%, rgb(131, 79, 229) 100%);
    line-height: 1;
    padding: 20px 60px;
    position: relative;
    font-weight: 700;
}
.about .inner .box a::after {
    content: '';
    position: absolute;
    background-image: url(../img/arrow.svg);
    background-repeat: no-repeat;
    width: 21px;
    height: 17px;
    right: 20px;
}
@media (max-width: 1400px){
    .about {
        padding: 80px 0 60px;
    }
    .about .inner .box {
        border-radius: 100px 0 100px 0;
        padding: 40px 20px 40px;
    }
    .about .inner .container .inner__right {
        width: 50%;
    }
    .about .inner .container .inner__right .ttl__bg {
        font-size: 12.0rem;
    }
    .about .inner .container .inner__right h2 {
        font-size: 2.8rem;
    }
    .about .inner .container .inner__right h2 .sm {
        font-size: 2.0rem;
    }
}
@media (max-width: 1200px){
    .about .inner .container .inner__right h2 {
        font-size: 2.0rem;
    }
    .about .inner .container .inner__right h2 .sm {
        font-size: 1.6rem;
    }
}
@media (max-width: 768px){
    .about {
        padding: 40px 0 30px;
    }
    .about .inner .container {
        flex-direction: column;
        align-items: center;
        padding-bottom: 100px;
    }
    .about .inner .container .inner__left,
    .about .inner .container .inner__right {
        width: 100%;
    }
    .about .inner .container .inner__right h2 {
        /* padding-top: 80px; */
        font-size: 2.0rem;
        /* margin-bottom: 20px; */
    }
    .about .inner .container .inner__right h2 .sm {
        font-size: 1.4rem;
    }
    .about .inner .container {
        padding-bottom: 50px;
    }
    .about .inner .container .inner__right .ttl__bg {
        font-size: 10.0rem;
    }
    .about .inner .box {
        border-radius: 80px 0 80px 0;
        padding: 30px 20px 30px;
    }
    .about .inner .box h3 {
        font-size: 2.4rem;
    }
    .about .inner .box ul {
        margin: 20px auto;
    }
    .about .inner .box ul li {
        gap: 10px;
        font-size: 1.6rem;
    }
}
@media (max-width: 500px){
    .about .inner .container {
        padding-bottom: 30px;
    }
    .about .inner .container .inner__left .circle {
        position: relative;
        width: 100%;
        aspect-ratio: unset;
        border-radius: unset;
        margin-bottom: 30px;
        border-radius: 10px;
        padding: 20px;
    }
    .about .inner .container .inner__left .circle .circle__inner {
        width: 100%;
        height: 100%;
        position: relative;
        font-size: 1.6rem;
    }
    .about .inner .container .inner__left .circle.c1 {
        top: 0;
        left: unset;
    }
    .about .inner .container .inner__left .circle.c1 .circle__inner {
        top: unset;
    }
    .about .inner .container .inner__left .circle.c2 {
        bottom: 0;
        left: 0;
    }
    .about .inner .container .inner__left .circle.c2 .circle__inner {
        top: unset;
    }
    .about .inner .container .inner__left .circle.c3 {
        bottom: 0;
        right: 0;
    }
    .about .inner .container .inner__left .circle.c3 .circle__inner {
        top: unset;
    }
    .about .inner .container .inner__left .overlay {
        position: relative;
        top: unset;
        left: unset;
        transform: unset;
        font-size: 3.8rem;
    }
    .about .inner .box ul li {
        font-size: 1.4rem;
    }
    .about .inner .box ul li img {
        width: 26px;
    }
    .about .inner .box a {
        font-size: 1.5rem;
        padding: 15px 40px;
    }
    .about .inner .box a::after {
        right: 15px;
    }
}
/* ------------------------------------- /
/  slider
/* ------------------------------------- */
.slider-8 .slick-slide {
    aspect-ratio: 4 / 3;
    height: 400px;
    position: relative;
    overflow: hidden;
}
.slider-8 .slick-slide img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media (max-width: 768px){
    .slider-8 .slick-slide {
        height: 300px;
    }
}
/* ------------------------------------- /
/  outline
/* ------------------------------------- */
.outline {
    padding: 100px 0;
    position: relative;
    /* background-color: #F2F2F2; */
}
.outline .outline_bg_1 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave_2.png) repeat-x;
    background-size: 4728px 1026px;
    background-position: left top -20%;
    animation: bgloop_outline_1 50s linear infinite;
    opacity: 0.15;
    /* mix-blend-mode: screen; */
    z-index: 0;
}
@keyframes bgloop_outline_1 {
    from {background-position: 0 -20%;}
    to {background-position: -4728px -20%;}
}
.outline .outline_bg_2 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background:  url(../img/bg_wave.png) repeat-x;
    background-size: 4305px 556px;
    background-position: left bottom 0;
    animation: bgloop_outline_2 50s linear infinite;
    /* mix-blend-mode: screen; */
    z-index: 0;
}
@keyframes bgloop_outline_2 {
    from {background-position: 0 100%;}
    to {background-position: -4305px 130%;}
}
.outline .outline_bg_3 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #F2F2F2;
    z-index: 0;
}
.outline .inner {
    position: relative;
}
.outline h2 {
    color: #834FE5;
    font-size: 6.2rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.outline .sub__ttl {
    color: #834FE5;
    font-weight: 700;
}
.outline table {
    margin-top: 60px;
    color: #1A1311;
    width: 100%;
}
.outline table tr {
    border-top: 1px solid #E3E3E3;
    border-bottom: 1px solid #E3E3E3;
}
.outline table tr th,
.outline table tr td {
    padding: 20px 10px;
    font-weight: 700;
}
.outline table tr th {
    min-width: 95px;
}
.outline .inner .box {
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 80px auto 100px;
}
.outline .inner .box a {
    font-size: 1.8rem;
    border-radius: 5px;
    background: linear-gradient(0deg, rgb(13, 29, 134) 0%, rgb(131, 79, 229) 100%);
    color: white;
    line-height: 1;
    padding: 20px 60px;
    font-weight: 700;
    position: relative;
}
.outline .inner .box a::after {
    content: '';
    position: absolute;
    background-image: url(../img/arrow.svg);
    background-repeat: no-repeat;
    width: 21px;
    height: 17px;
    right: 20px;
}
.outline h3 {
    color: #834FE5;
    font-size: 6.2rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.outline .slider {
    position: relative;
    margin: 40px auto 110px;
    max-width: 900px;
}
.slider-9 {
    position: relative;
}
.slider-9 .slick-slide {
    margin: 0;
    position: relative;
    overflow: hidden;
    width: 100%;
}
.slider-9 .slick-slide > div {
    display: flex;
    align-items: center;
}
.slider-9 .slick-slide img {
    display: block;
    max-height: 560px;
    object-fit: contain;
    border-radius: 10px;
}
.slider-9 .slick-arrow {
    width: 60px;
    height: 60px;
    border-radius: 5px;
    background-color: #834FE5;
    cursor: pointer;
    border: none;
    outline: none;
    font-size: 0;
    position: absolute;
    top: 50%;
    z-index: 1;
    filter: drop-shadow(0px 3px 6px rgba(0, 0, 0, 0.16));
}
.slider-9 .slick-arrow::before {
    content: '';
    display: block;
    background-image: url(../img/arrow.svg);
    background-repeat: no-repeat;
    width: 21px;
    height: 17px;
    position: absolute;
    top: 24px;
}
.slider-9 .slick-next {
right: -30px;
}
.slider-9 .slick-prev {
left: -30px;
}
.slider-9 .slick-next::before {
left: 20px;
}
.slider-9 .slick-prev::before {
right: 22px;
transform: rotate(180deg);
}
.dots-9 .slick-dots {
text-align: center;
}
.dots-9 .slick-dots li {
display: inline-block;
}
.dots-9 .slick-dots button {
display: block;
width: 8px;
height: 8px;
margin: 6px;
font-size: 0;
padding: 0;
border: 0;
outline: none;
cursor: pointer;
background: white;
border-radius: 50%;
text-indent: -9999px;
}
.dots-9 .slick-dots .slick-active button {
width: 12px;
height: 12px;
}
.lb-nav {
    display: none!important;
}
.outline .timetable {
    margin-top: 40px;
}
.outline .timetable h3 {
    margin-top: 60px;
    color: white;
    background: #834FE5;
    border-radius: 3px;
    padding: 18px 30px;
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 25px;
}
.outline .timetable img {
    border-radius: 10px;
}
@media (max-width: 1200px){
    .outline {
        padding: 80px 0;
    }
    .outline h2 {
        font-size: 4.0rem;
    }
    .outline table {
        margin-top: 40px;
    }
    .outline .inner .box {
        margin: 60px auto 80px;
    }
    .outline .inner .box a {
        font-size: 1.6rem;
        padding: 20px 60px;
    }
    .outline .inner .box a::after {
        width: 21px;
        height: 17px;
        right: 20px;
    }
    .outline h3 {
        font-size: 4.0rem;
    }
    .outline .slider {
        margin-top: 20px;
        margin-bottom: 60px;
    }
    .outline .timetable h3 {
        margin-top: 40px;
        margin-bottom: 20px;
    }

}
@media (max-width: 768px){
    .outline {
        padding: 50px 0;
    }
    .outline h2 {
        font-size: 3.6rem;
    }
    .outline table {
        margin-top: 30px;
    }
    .outline .inner .box {
        margin: 40px auto 50px;
    }
    .outline .inner .box a::after {
        width: 21px;
        height: 17px;
        right: 20px;
    }
    .outline h3 {
        font-size: 3.6rem;
    }
    .outline table tr th,
    .outline table tr td {
        padding: 10px 5px;
    }
    /* .outline .slider { */
        /* margin-bottom: 40px; */
    /* } */
    .slider-9 .slick-arrow {
        display: none!important;
    }
    .outline .timetable h3 {
        margin-top: 40px;
        margin-bottom: 40px;
        padding: 10px 15px;
        font-size: 1.8rem;
    }
}
@media (max-width: 500px){
    .outline {
        padding: 30px 0;
    }
    .outline h2 {
        font-size: 2.8rem;
    }
    .outline table {
        margin-top: 20px;
    }
    .outline .inner .box {
        margin: 20px auto 30px;
    }
    .outline .inner .box a::after {
        width: 21px;
        height: 17px;
        right: 20px;
    }
    .outline h3 {
        font-size: 2.8rem;
    }
    /* .outline .slider { */
        /* margin-bottom: 20px; */
    /* } */
    /* .slider-9 .slick-next, */
    /* .slider-9 .slick-prev { */
    /* display: none!important; */
    /* } */
    .outline .timetable h3 {
        margin-top: 20px;
        margin-bottom: 20px;
    }
}

/* ------------------------------------- /
/  floormap
/* ------------------------------------- */
.floormap {
    padding-top: 100px;
}
@media (max-width: 1200px){
    .floormap {
        padding-top: 80px;
    }
}
@media (max-width: 768px){
    .floormap {
        padding-top: 50px;
    }
}
@media (max-width: 500px){
    .floormap {
        padding-top: 30px;
    }
}


/* ------------------------------------- /
/  lecture
/* ------------------------------------- */
.lecture {
    padding: 20px 0 600px;
    margin-bottom: -500px;
    position: relative;
    background-color: #F2F2F2;
}
.lecture .lecture_bg {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    /* background-image: url(../img/lecture_bg.webp); */
    /* background-size: cover; */
    background-color: white;
    border-radius: 800px 0 0 0;
}
.lecture .inner {
    position: relative;
}
.lecture h2 {
    font-size: 12.0rem;
    color: #834FE5;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1;
}
.lecture .sub__ttl {
    margin-top: 20px;
    margin-bottom: 70px;
    color: #834FE5;
    display: block;
    font-weight: 700;
}
.lecture .lect {
    margin-top: 50px;
    width: 100%;
    min-height: 600px;
    border-radius: 10px;
    background-color: #F8F8F8;
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
    padding: 60px;
    /* display: flex; */
    justify-content: space-between;
    /* font-weight: 700; */
    gap: 30px;
}
.lecture .lect__upper {
    /* max-width: 820px; */
    margin-bottom: 30px;
}
.lecture .lect__upper .lect__detail {
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
    row-gap: 20px;
    margin-bottom: 29px;
    font-size: 2.1rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
}
.lecture .lect__upper .lect__detail .head {
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 8px 25px;
    line-height: 1;
    margin-right: 15px;
    font-size: 1.5rem;
    display: inline-block;
}
.lecture .lect__upper .lect__ttl {
    font-size: 2.2rem;
    display: block;
    margin-bottom: 30px;
    font-weight: 700;
}
.lecture .lect__profile__container {
    display: flex;
    gap: 30px;
    /* margin-bottom: 30px; */
    align-items: flex-start;
}
.lecture .lect .lect__profile__container:nth-child(3) {
    margin-top: 30px;
}
.lecture .lect__profile {
    /* margin-top: 30px; */
    border-radius: 10px;
    background-color: white;
    padding: 29px 35px;
    min-height: 280px;
    width: 100%;
}
.lecture .lect__profile span {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
}
.lecture .lect__profile .name {
    font-size: 2.2rem;
    font-weight: 700;
}
.lecture .lect__profile p {
    margin-top: 20px;
    font-size: 1.6rem;
    line-height: 1.92;
}
.lecture .lect__right {
    min-width: 280px;
}
.lecture img {
    max-width: 280px;
    border-radius: 10px;
    object-fit: contain;
}
@media (max-width: 1200px){
    .lecture h2 {
        font-size: 8.0rem;
    }
    .lecture .sub__ttl {
        margin-bottom: 50px;
    }
}
@media (max-width: 1000px){
    .lecture .lect {
        margin-top: 30px;
        border-radius: 10px;
        padding: 40px;
        gap: 20px;
    }
}
@media (max-width: 768px){
    .lecture h2 {
        font-size: 4.0rem;
    }
    .lecture .sub__ttl {
        margin-top: 10px;
        margin-bottom: 30px;
        font-size: 1.4rem;
    }
    .lecture .lect {
        flex-direction: column;
        margin-top: 20px;
        border-radius: 5px;
        padding: 20px;
    }
    .lecture .lect__upper,
    .lecture .lect__right {
        max-width: unset;
        width: 100%;
    }
    .lecture .lect__upper .lect__detail {
        margin-bottom: 15px;
        font-size: 1.5rem;
    }
    .lecture .lect__upper .lect__ttl {
        font-size: 1.8rem;
        margin-bottom: 15px;
    }
    .lecture .lect__profile__container {
        flex-wrap: wrap;
        gap: 20px;
    }
    .lecture .lect .lect__profile__container:nth-child(3) {
        margin-top: 20px;
    }
    .lecture .lect__profile {
        border-radius: 5px;
        padding: 20px;
        min-height: unset;
    }
    .lecture .lect__profile span {
        font-size: 1.4rem;
    }
    .lecture .lect__profile .name {
        font-size: 1.7rem;
    }
    .lecture .lect__right {
        display: flex;
        justify-content: space-between;
        gap: 30px;
        row-gap: 30px;
        flex-wrap: wrap;
    }
    .lecture img {
        max-width: 324px;
        margin-bottom: unset;
        border-radius: 5px;
    }
}
@media (max-width: 500px){
    .lecture {
        padding: 20px 0 400px;
        margin-bottom: -350px;
    }
    .lecture h2 {
        font-size: 2.8rem;
    }
    .lecture .sub__ttl {
        margin-bottom: 20px;
    }
}
/* ------------------------------------- /
/  event
/* ------------------------------------- */
.event {
    padding: 100px 0;
    background-color: #F2F2F2;
    border-radius: 800px 0 0 0;
    position: relative;
}
.event h2 {
    font-size: 12.0rem;
    font-family: "Oswald", sans-serif;
    color: #834FE5;
    font-weight: 500;
}
.event .sub__ttl {
    margin-top: 20px;
    color: #834FE5;
    font-size: 1.6rem;
    font-weight: 700;
    margin-bottom: 70px;
    display: block;
}
.event h3 {
    margin-top: 70px;
    color: white;
    background: #834FE5;
    border-radius: 3px;
    padding: 18px 30px;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 50px;
}
/* .event h3:nth-of-type(2) {
    background: linear-gradient(270deg, #08BDFF 0%, #2E3C96 100%);
} */
.event h3:nth-of-type(3) {
    background: linear-gradient(270deg, #00C99B 0%, #00899B 100%);
}
.event h3:nth-of-type(4) {
    background: linear-gradient(270deg, #D5016F 0%, #FF835D 100%);
    display: flex;
    justify-content: space-between;
    gap: 30px;
    row-gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}
.event h3:nth-of-type(4) .lect__detail {
    display: flex;
    gap: 30px;
    row-gap: 10px;
    font-size: 2.1rem;
    flex-wrap: wrap;
    font-weight: 500;
}
.event h3:nth-of-type(4) .lect__detail .head {
    color: #0A176A;
    background-color: white;
    border-radius: 3px;
    padding: 8px 25px;
    line-height: 1;
    margin-right: 15px;
    font-size: 1.5rem;
    display: inline-block;
}
.event .container {
    padding: 56px 0 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 30px;
    row-gap: 60px;
}
.event .container > * {
    width: calc((100% - 30px * 3) / 4);
}
.event .container .profile .profile_img {
    position: relative;
}
.event .container .profile .profile_img img {
    border-radius: 3px;
}
.event .container .profile .profile_img a {
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 10px 33px 10px 13px;
    font-size: 1.5rem;
    white-space: nowrap;
    line-height: 1;
    cursor: pointer;
}
.event .container .profile .profile_img a::after {
    content:'';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 11px;
    right: 15px;
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
}
.event .container .profile .profile_img button {
    font-size: 1.5rem;
    position: absolute;
    bottom: 10px;
    left: 50%;
    transform: translateX(-50%);
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 10px 33px 10px 13px;
    white-space: nowrap;
    line-height: 1;
    cursor: pointer;
}
.event .container .profile .profile_img button::after {
    content:'';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 50%;
    right: 15px;
    transform: translateY(-50%);
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
}
.event .workshop__detail {
    font-size: 2.1rem;
    font-weight: 700;
}
.modal {
    display: none;
    position: fixed;
    z-index: 20;
    left: 0;
    top: 0;
    height: 100%;
    width: 100%;
    overflow: auto;
    background-color: rgba(0,0,0,0.5);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}
.modal .modal-box {
    color: white;
    background-color: #0000007d;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    max-width: 800px;
    width: 90%;
    border-radius: 10px;
    position: relative;
    padding: 40px 50px;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-height: 75vh;
}
.modal .modal-box .modal-inner {
    display: flex;
    gap: 40px;
}
.modal .modal-box .modal-inner .modal-img {
    width: 150px;
}
.modal .modal-box .modal-inner .modal-img img { 
    border-radius: 5px;
}
.modal .modal-box .modal-inner .modal-profile {
    width: calc(100% - 190px);
}
.modal .modal-box .modal-inner .name {
    font-size: 2.2rem;
    font-weight: 700;
}
.modal .modal-box .modal-inner .post {
    font-size: 1.5rem;
    margin-bottom: 40px;
}
.modal .modal-box .modalClose {
    position: absolute;
    top: 20px;
    right: 20px;
}
.modal .modal-box .modalClose img {
    height: 40px;
    width: 40px;
}
.event .container .profile span {
    display: block;
    font-size: 1.5rem;
}
.event .container .profile > .name {
    margin-top: 30px;
    font-weight: 700;
    font-size: 2.1rem;
}
.event .container .profile .company {
    margin-top: 10px;
}
.event .session {
    margin-top: 30px;
    background-color: #FAFAFA;
    border-radius: 10px;
    padding: 50px 60px;
}
.event .session .detail {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-wrap: wrap;
}
.event .session .detail .time {
    font-size: 4.0rem;
    color: #0A176A;
    font-family: "Oswald", sans-serif;
    line-height: 1;
}
.event .session .detail .location {
    font-size: 1.8rem;
    color: white;
    background-color: #0A176A;
    padding: 11px 14px;
    line-height: 1;
    border-radius: 3px;
} 
.event .session h4 {
    font-weight: 700;
    font-size: 2.5rem;
    margin: 20px 0;
}
.event .session .manager__list {
    margin-top: 35px;
    display: flex;
    gap: 35px;
    flex-wrap: wrap;
}
.event .session .manager__list .manager {
    display: flex;
    align-items: center;
    gap: 20px;
}
.event .session .manager__list .manager img {
    width: 88px;
    object-fit: contain;
    border-radius: 50%;
    aspect-ratio: 1;
}
.event .workshop {
    padding: 60px 0;
    margin: 0 50px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #E3E3E3;
    gap: 30px;
}
.event .workshop.meeting {
    padding: 0 0 60px;
}
.event .workshop .workshop__left {
    max-width: 720px;
}
.event .workshop .workshop__left .workshop__sp1050 {
    display: none;
}
.event .workshop .workshop__left .workshop__detail {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    row-gap: 10px;
    margin-bottom: 29px;
    font-size: 2.1rem;
}
.event .workshop .workshop__left .workshop__detail .head {
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 8px 25px;
    line-height: 1;
    margin-right: 15px;
    font-size: 1.5rem;
    display: inline-block;
}
.event .workshop .workshop__left .workshop__ttl {
    display: block;
    font-size: 2.2rem;
    margin-bottom: 10px;
    font-weight: 700;
}
.event .workshop .workshop__left p {
    margin-top: 25px;
}
.event .workshop .workshop__left a {
    margin-top: 40px;
    color: white;
    background: linear-gradient(0deg, rgb(13, 29, 134) 0%, rgb(131, 79, 229) 100%);
    border-radius: 3px;
    padding: 15px;
    max-width: 340px;
    display: block;
    text-align: center;
    font-size: 2.0rem;
    line-height: 1.7;
    position: relative;
    font-weight: 700;
}
.event .workshop .workshop__left a::after {
    content:'';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 50%;
    right: 20px;
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
    transform: translateY(-50%);
}
.event .workshop .workshop__right {
    max-width: 340px;
    width: 100%;
}
.event .workshop .workshop__right img {
    border-radius: 5px;
}
.event .workshop .workshop__right p {
    margin-top: 10px;
}
.event .workshop .workshop__right a {
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 15px;
    width: 100%;
    display: block;
    text-align: center;
    font-size: 2.0rem;
    line-height: 1.7;
    position: relative;
    font-weight: 700;
}
.event .workshop .workshop__right a::after {
    content:'';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 50%;
    right: 20px;
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
    transform: translateY(-50%);
}
.event .box .event__button {
    margin: 40px auto 0;
    color: white;
    background: linear-gradient(0deg, rgb(13, 29, 134) 0%, rgb(131, 79, 229) 100%);
    border-radius: 3px;
    padding: 15px;
    max-width: 340px;
    display: block;
    text-align: center;
    font-size: 2.0rem;
    line-height: 1.7;
    position: relative;
    font-weight: 700;
}
.event .box .event__button::after {
    content:'';
    position: absolute;
    width: 11px;
    height: 11px;
    top: 50%;
    right: 20px;
    background-image: url(../img/plus.svg);
    background-repeat: no-repeat;
    transform: translateY(-50%);
}
@media (max-width: 1200px){
    .event {
        padding: 80px 0;
        border-radius: 400px 0 0 0;
    }
    .event h2 {
        font-size: 8.0rem;
    }
    .event .sub__ttl {
        margin-bottom: 50px;
    }
    .event h3 {
        margin-top: 50px;
        margin-bottom: 50px;
    }
    .event .container {
        padding: 30px 0 80px;
        row-gap: 40px;
        gap: 20px;
    }
    .event .container > * {
        width: calc((100% - 20px * 2) / 3);
    }
    .event .container .profile .profile_img button {
        font-size: 1.4rem;
        padding: 10px 28px 10px 8px;
    }
    .event .session {
        margin-top: 30px;
        padding: 30px 50px;
    }
}
@media (max-width: 1050px){
    .event .workshop {
        padding: 40px 0;
        margin: 0;
        flex-direction: column;
    }
    .event .workshop .workshop__left .workshop__sp1050 {
        display: block;
        max-width: 340px;
    }
    .event .workshop .workshop__left a {
        margin: 20px auto;
        border-radius: 3px;
        padding: 10px;
        max-width: 340px;
        font-size: 1.8rem;
    }
    .event .workshop .workshop__right {
        display: none;
    }
}
@media (max-width: 768px){
    .event {
        padding: 50px 0;
        border-radius: 300px 0 0 0;
    }
    .event .sub__ttl {
        margin-top: 10px;
        margin-bottom: 30px;
        font-size: 1.4rem;
    }
    .event h2 {
        font-size: 4.0rem;
    }
    .event h3 {
        margin-top: 40px;
        margin-bottom: 40px;
        padding: 10px 15px;
        font-size: 2.0rem;
    }
    .event h3:nth-of-type(4) .lect__detail {
        font-size: 1.5rem;
    }
    .event .session h4 {
        font-size: 1.8rem;
    }
    .event .container {
        padding: 0 0 20px;
        row-gap: 20px;
        gap: 10px;
    }
    .event .container > * {
        width: calc((100% - 10px * 2) / 3);
    }
    .event .container .profile .profile_img button {
        font-size: 1.3rem;
        padding: 7px 16px 7px 9px;
    }
    .event .container .profile .profile_img button::after {
        right: 5px;
    }
    .event .session {
        margin-top: 20px;
        border-radius: 5px;
        padding: 20px;
    }
    .event .session .detail .time {
        font-size: 3.0rem;
    }
    .event .session .detail .location {
        font-size: 1.5rem;
        padding: 8px 10px;
    } 
    .event .session .manager__list {
        gap: 20px;
    }
    .modal .modal-box .modal-inner {
        flex-direction: column;
        gap: 20px;
        height: 100%;
    }
    .modal .modal-box .modal-inner .modal-profile {
        width: 100%;
        /* height: calc(100% - 285px); */
        overflow-y: auto;
    }
    .event .workshop .workshop__left .workshop__detail {
        margin-bottom: 15px;
        font-size: 1.6rem;
    }
    .event .workshop .workshop__left .workshop__ttl {
        font-size: 1.8rem;
    }
    .event .workshop .workshop__left p {
        margin-top: 10px;
    }
    .modal .modal-box .modalClose img {
        height: 20px;
        width: 20px;
    }
}
@media (max-width: 600px){
    .event .container > * {
        width: calc((100% - 10px * 1) / 2);
    }
    .event .container .profile span {
        font-size: 1.3rem;
    }
    .event .container .profile > .name {
        margin-top: 10px;
        font-size: 1.8rem;
    }
    .event .container .profile > .company {
        margin-top: 5px;
    }
}
@media (max-width: 500px){
    .event {
        padding: 0 0 10px;
        border-radius: 200px 0 0 0;
    }
    .event h2 {
        font-size: 2.8rem;
    }
    .event .sub__ttl {
        margin-bottom: 20px;
    }
    .event h3 {
        margin-top: 20px;
        margin-bottom: 20px;
    }
    .event .workshop {
        padding: 10px 0 20px;
        margin: 0;
    }
    .modal .modal-box {
        border-radius: 5px;
        padding: 20px 25px;
    }
    .modal .modal-box .modal-inner .post {
        margin-bottom: 10px;
    }
}
/* ------------------------------------- /
/  pitch
/* ------------------------------------- */
.pitch {
    padding: 100px 0 50px;
    position: relative;
    background-color: #F2F2F2;
    margin: -1px 0 -1px;
}
.pitch .pitch_bg {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-color: white;
    border-radius: 800px 0 0 0;
}
.pitch .pitch_bg_1 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave.png) repeat-x;
    background-size: 4305px 556px;
    background-position: 0 -5%;
    animation: bgloop_pitch_1 50s linear infinite;
    mix-blend-mode: screen;
}
@keyframes bgloop_pitch_1 {
    from {background-position: 0  -5%;}
    to {background-position: -4305px -5%;}
}
.pitch .pitch_bg_2 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave_2.png) repeat-x;
    background-size: 4728px 1026px;
    background-position: left top 35%;
    animation: bgloop_pitch_2 50s linear infinite;
    mix-blend-mode: screen;
}
@keyframes bgloop_pitch_2 {
    from {background-position: 0  35%;}
    to {background-position: -4728px 35%;}
}
.pitch .pitch_bg_3 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave_2.png) repeat-x;
    background-size: 4728px 1026px;
    background-position: left -15% top 65%;
    animation: bgloop_pitch_3 50s linear infinite;
    mix-blend-mode: screen;
}
@keyframes bgloop_pitch_3 {
    from {background-position: 15%  65%;}
    to {background-position: -85% 65%;}
}
.pitch .pitch_bg_4 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave.png) repeat-x;
    background-size: 4305px 556px;
    background-position: left top 90%;
    animation: bgloop_pitch_4 50s linear infinite;
    mix-blend-mode: screen;
}
@keyframes bgloop_pitch_4 {
    from {background-position: 0  90%;}
    to {background-position: -4305px 90%;}
}
.pitch .inner {
    position: relative;
}
.pitch h2 {
    color: #834FE5;
    font-size: 12.0rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.pitch .sub_ttl {
    color: #834FE5;
    font-weight: 700;
}
.pitch h3 {
    color: white;
    background: #834FE5;
    border-radius: 3px;
    padding: 18px 30px;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.2;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    row-gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}
.pitch .pitch__detail {
    display: flex;
    gap: 30px;
    row-gap: 10px;
    font-size: 2.1rem;
    flex-wrap: wrap;
}
.pitch .pitch__detail .head {
    color: #0A176A;
    background-color: white;
    border-radius: 3px;
    padding: 8px 25px;
    line-height: 1;
    margin-right: 15px;
    font-size: 1.5rem;
    display: inline-block;
}
.pitch h3:nth-of-type(1) {
    margin-top: 70px;
}
.pitch h3:nth-of-type(2) {
    background: #834FE5;
    margin-bottom: 50px;
}
.pitch h3:nth-of-type(3) {
    background: linear-gradient(270deg, #00C99B 0%, #00899B 100%);
    margin-bottom: 50px;
}
.pitch .profile__container {
    background-color: white;
    margin: 40px 0px 100px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 20px 70px;
    border-radius: 10px;
    box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.16);
}
.pitch .profile__container .profile {
    padding: 25px 20px;
    background-color: white;
    width: 100%;
    border-bottom: 1px solid #E3E3E3;
}
.pitch .profile__container .profile:last-child {
    border: none;
}
.pitch .profile__container .profile .wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
}
.pitch .profile__container .profile .profile__left {
    display: flex;
    align-items: center;
}
.pitch .profile__container .profile .profile__right {
    display: flex;
    align-items: center;
    text-align: right;
    flex-wrap: wrap;
}
.pitch .profile__container .profile .ttl {
    font-size: 2.0rem;
    font-weight: 700;
}
.pitch .profile__container .profile .name {
    font-size: 1.6rem;
    font-weight: 700;
    width: 100%;
}
.pitch .profile__container .profile .company {
    font-size: 1.6rem;
    font-weight: 700;
    width: 100%;
}
.pitch .profile__container .profile > button {
    margin-top: 35px;
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 10px;
    max-width: 190px;
    display: block;
    text-align: center;
    font-size: 2.0rem;
    line-height: 1.7;
    font-size: 1.5rem;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 11px;
}
.pitch .profile__container .profile > button img {
    width: 11px;
    height: 11px;
}
.pitch .innovator__pitch__contents {
    padding: 60px;
    background-color: white;
    border-radius: 10px;
    margin-bottom: 70px;
}
.pitch .innovator__pitch__contents .innovator {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
    row-gap: 20px;
}
.pitch .innovator__pitch__contents .innovator .innovator__img img {
    border-radius: 10px;
}
.pitch .innovator__pitch__contents .innovator__txt h4 {
    margin-bottom: 10px;
    font-size: 2.8rem;
    line-height: 1.7;
    font-weight: 700;
}
.pitch .innovator__pitch__contents .innovator__txt p {
    margin-bottom: 20px;
}
.pitch label {
    color: white;
    border-radius: 3px;
    padding: 18px 70px 18px 30px;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.2;
    display: flex;
    justify-content: space-between;
    background: linear-gradient(270deg, #00C99B 0%, #00899B 100%);
    margin-top: 50px;
    position: relative;
}
.pitch label::before {
    content: '';
    position: absolute;
    width: 30px;
    height: 2px;
    top: 50%;
    right: 30px;
    background: white;
    transform: translateY(-50%);
}
.pitch label::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 30px;
    width: 30px;
    height: 2px;
    background: white;
    transition: .4s;
    transform: translateY(-50%) rotate(90deg);
}
.toggle:checked + label::after {
    transform: translateY(-50%) rotate(180deg);
}
.toggle {
	display: none;
}
.pitch label, 
.pitch .pitch__theme__contents {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.pitch .pitch__theme__contents {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0 20px;
	overflow: hidden;
}
.toggle:checked + label + .pitch__theme__contents {	/*開閉時*/
	height: auto;
	transition: all .3s;
    /* padding: 70px; */
    padding: 0;
    background-color: white;
    border-radius: 10px;
    /* font-weight: 700; */
    /* margin-bottom: 70px; */
    margin-top: 20px;
}
.pitch__theme__contents .innovator {
    display: flex;
    justify-content: space-between;
    padding: 15px 30px;
    gap: 30px;
}
.pitch .innovator:not(:first-child) {
    border-top: 1px solid #E3E3E3;
}
.pitch__theme__contents .innovator .ttl {
    font-size: 1.8rem;
    width: 60%;
    font-weight: 700;
}
.pitch__theme__contents .innovator .detail {
    width: calc(100% - 60% - 30px);
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 10px;
    word-break: keep-all;
    text-align: right;
    font-size: 1.5rem;
}
.pitch__theme__contents .innovator .detail span:nth-of-type(3) {
    font-weight: 700;
}
@media (max-width: 1200px){
    .pitch {
        padding: 80px 0;
    }
    .pitch h2 {
        font-size: 8.0rem;
    }
    .pitch h3 {
        font-size: 2.0rem;
    }
    .pitch .innovator__pitch__contents .innovator {
        flex-direction: column;
        align-items: flex-start;
        padding: 10px 0;
        gap: 5px;
    }
    .pitch .innovator .ttl {
        font-size: 1.6rem;
        width: 100%;
    }
    .pitch .innovator__pitch__contents {
        padding: 50px;
        margin-bottom: 50px;
    }
    .pitch .innovator__pitch__contents .innovator > * {
        width: 100%;
    }
    .pitch .innovator__pitch__contents .innovator__txt h4 {
        font-size: 2.6rem;
    }
    .toggle:checked + label + .pitch__theme__contents {	/*開閉時*/
        border-radius: 10px;
    }
    .pitch__theme__contents .innovator .detail {
        width: 100%;
        text-align: left;
        font-size: 1.4rem;
    }
}
@media (max-width: 768px){
    .pitch {
        padding: 50px 0;
    }
    .pitch h2 {
        font-size: 4.0rem;
    }
    .pitch .sub_ttl {
        font-size: 1.4rem;
    }
    .pitch h3 {
        font-size: 1.8rem;
        padding: 10px 15px;
    }
    .pitch h3:nth-of-type(1) {
        margin-top: 50px;
    }
    .pitch h3:nth-of-type(2) {
        margin-bottom: 40px;
    }
    .pitch h3:nth-of-type(3) {
        margin-bottom: 40px;
    }
    .pitch label {
        padding: 10px 15px;
        font-size: 1.8rem;
        margin-bottom: 25px;
    }
    .pitch label::before {
        width: 20px;
        height: 1px;
        right: 20px;
    }
    .pitch label::after {
        right: 20px;
        width: 20px;
        height: 1px;
    }
    .pitch .profile__container {
        padding: 20px;
        margin: 20px 0px;
        gap: 20px;
        row-gap: 20px;
    }
    .pitch .pitch__detail {
        font-size: 1.6rem;
    }
    .pitch .pitch__detail .head {
        padding: 8px 20px;
        margin-right: 10px;
        font-size: 1.4rem;
    }
    .pitch .profile__container .profile {
        padding: 10px;
        width: 100%;
        border-radius: 5px;
    }
    .pitch .profile__container .profile .wrapper {
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .pitch .profile__container .profile .profile__left {
        width: 100%;
    }
    .pitch .profile__container .profile .profile__right {
        width: 100%;
    }
    .pitch .profile__container .profile .ttl {
        font-size: 1.6rem;
    }
    .pitch .profile__container .profile .name {
        margin-top: 10px;
        font-size: 1.5rem;
    }
    .pitch .profile__container .profile .company {
        margin-top: 5px;
        font-size: 1.3rem;
    }
    .pitch .profile__container .profile > button {
        margin-top: 20px;
    }
    .pitch .innovator__pitch__contents {
        padding: 30px;
        margin-bottom: 30px;
    }
    .toggle:checked + label + .pitch__theme__contents {	/*開閉時*/
        border-radius: 5px;
    }
    .pitch .innovator__pitch__contents .innovator__txt h4 {
        font-size: 2.0rem;
    }
    .pitch .innovator .ttl {
        font-size: 1.5rem;
    }
    .pitch .innovator .detail {
        font-size: 1.4rem;
        row-gap: 5px;
    }
}
@media (max-width: 500px){
    .pitch {
        padding: 20px 0;
    }
    .pitch h2 {
        font-size: 2.8rem;
    }
    .pitch h3:nth-of-type(1) {
        margin-top: 30px;
    }
    .pitch h3:nth-of-type(2) {
        margin-bottom: 25px;
    }
    .pitch h3:nth-of-type(3) {
        margin-bottom: 25px;
    }
    .pitch .innovator__pitch__contents {
        padding: 20px;
        margin-bottom: 20px;
    }
    .toggle:checked + label + .pitch__theme__contents {	/*開閉時*/
        margin-bottom: 20px;
    }
    .pitch .profile__container .profile .ttl {
        font-size: 1.5rem;
    }
    .pitch .profile__container .profile > button {
        max-width: unset;
        width: 100%;
    }
    .pitch .innovator__pitch__contents .innovator__txt h4 {
        font-size: 1.6rem;
    }
}

/* ------------------------------------- /
/  exhibitor
/* ------------------------------------- */
.exhibitor {
    padding-top: 100px;
    background-color: white;
    /* font-weight: 700; */
    position: relative;
}
.exhibitor .inner {
    position: relative;
}
.exhibitor .exhibitor_bg_1 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave.png) repeat-x;
    background-size: 4305px 556px;
    background-position: 0 -5%;
    animation: bgloop_exhibitor_1 50s linear infinite;
}
@keyframes bgloop_exhibitor_1 {
    from {background-position: 0  -5%;}
    to {background-position: -4305px -5%;}
}
.exhibitor h2 {
    color: #834FE5;
    font-size: 6.2rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.exhibitor .sub_ttl {
    color: #834FE5;
    font-weight: 700;
}
.bggrid #modal {
    background: #ffffffd9;
    display: none;
    padding: 50px 5px 5px 5px;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    height: 75vh;
    width: 65%;
    z-index: 99;
    border-radius: 10px;
    border: 1px solid #707070;
    /* overflow-y: auto; */
}
.bggrid #modal .modal__img {
    width: 100%;
    height: 25%;
    display: flex;
    justify-content: center;
}
.bggrid #modal .modal__img > img {
    width: 100%;
    height: 100%;
    max-width: 260px;
    object-fit: contain;
}
.bggrid #modal .modal__inner {
    height: 70%;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 45px 40px;
    margin-bottom: 30px;
}
.bggrid #modal .modal__inner .modal__title {
    width: 100%;
    text-align: left;
    font-size: 20px;
    font-weight: 700;
    color: #1D1D1D;
}
.bggrid #modal .modal__inner .modal__category {
    width: 100%;
    text-align: left;
    font-size: 1.5rem;
    font-weight: 500;
    color: #1A1311;
    margin-top: 10px;
    display: flex;
    gap: 9px;
}
.bggrid #modal .modal__inner .modal__category span {
    height: 20px;
    color: #fff;
    border-radius: 2px;
    font-size: 1.6rem;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 2px 3px;
}
.bggrid #modal .modal__inner .modal__category .sustainable {
    background: #FF9500;
}
.bggrid #modal .modal__inner .modal__category .create {
    background: #00B8FF;
}
.bggrid #modal .modal__inner .modal__category .wellness {
    background: #FF007A;
}
/* .bggrid #modal .modal__inner .modal__category .団体・機関 {
    background: #00d800;
}
.bggrid #modal .modal__inner .modal__category .大学・研究機関 {
    background: #7600FF;
}
.bggrid #modal .modal__inner .modal__category .最適化栄養食の認証事業 {
    background: #008b9a;
}
.bggrid #modal .modal__inner .modal__category .自治体・公的機関 {
    background: #f15325;
} */

.bggrid #modal .modal__inner .modal__subtitle {
    width: 100%;
    text-align: left;
    font-size: 1.8rem;
    color: #1A1311;
    margin-top: 25px;
}
.bggrid #modal .modal__inner .modal__tags {
    width: 100%;
    display: flex;
    margin-top: 8px;
    flex-wrap: wrap;
}
.bggrid #modal .modal__inner .modal__tags--item {
    margin-right: 5px;
    font-size: 1.6rem;
    color: #7A7A7A;
}
.bggrid #modal .modal__inner .modal__content {
    width: 100%;
}
.bggrid #modal .modal__inner .modal__content > p {
    width: 100%;
    text-align: left;
    font-size: 16px;
    color: #1A1311;
    line-height: 24px;
    margin-top: 16px;
}
.bggrid #modal .modal__inner div:has(.modal__website) {
    width: 100%;
    text-align: left;
    margin-top: 20px;
    font-size: 1.6rem;
    color: #7A7A7A;
}
.bggrid #modal .modal__inner .modal__needwant {
    width: 100%;
    display: flex;
    flex-direction: column;
    padding: 25px 30px;
    background: #0A176A;
    margin-top: 25px;
    border-radius: 3px;
    color: white;
    position: relative;
}
.bggrid #modal .modal__inner .modal__needwant::after {
    position: absolute;
    content: '';
    bottom: 0;
    left: 0;
    height: 30px;
    width: 1px;
    background-color: transparent;
}
.bggrid #modal .modal__inner .modal__needwant--title {
    width: 100%;
    text-align: left;
    font-size: 2.0rem;
    font-weight: 700;
    font-family: "Lato", sans-serif;
}
.bggrid #modal .modal__inner .modal__needwant--content {
    width: 100%;
    text-align: left;
    font-size: 1.6rem;
    line-height: 1.75;
    margin-top: 16px;
}
.bggrid #modal #close__btn {
    cursor: pointer;
    position: absolute;
    top: 20px;
    right: 20px;
    text-align: center;
    line-height: 40px;
    height: 40px;
    width: 40px;
    color: #1D1D1D;
}
.bggrid #modal #close__btn img {
    width: 40px;
    height: 100%;
}
.bggrid #overlay {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: none;
    cursor: pointer;
    position: fixed;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    z-index: 13;
}
@media (max-width: 1200px){
    .exhibitor {
        padding-top: 80px;
    }
    .exhibitor h2 {
        font-size: 4.0rem;
    }
}
@media (max-width: 768px){
    .exhibitor {
        padding-top: 60px;
    }
    .exhibitor h2 {
        font-size: 3.6rem;
    }
    .bggrid #modal {
        padding: 30px 5px 5px 5px;
        height: 75vh;
        width: 90%;
        border-radius: 5px;
    }
    .bggrid #modal #close__btn {
        top: 10px;
        right: 10px;
        height: 20px;
        width: 20px;
    }
    .bggrid #modal #close__btn img {
        width: 20px;
        height: 100%;
    }
    .bggrid #modal .modal__inner {
        padding: 25px 20px;
        margin-bottom: 20px;
    }
    .bggrid #modal .modal__inner .modal__needwant::after {
        height: 10px;
    }
    .bggrid #modal .modal__inner .modal__title {
        font-size: 1.7rem;
    }
    .bggrid #modal .modal__inner .modal__category {
        font-size: 1.4rem;
    }
    .bggrid #modal .modal__inner .modal__subtitle {
        font-size: 1.6rem;
        margin-top: 15px;
    }
    .bggrid #modal .modal__inner .modal__tags--item {
        margin-right: 5px;
        font-size: 1.4rem;
    }
    .bggrid #modal .modal__inner .modal__content > p {
        font-size: 1.4rem;
        line-height: unset;
        margin-top: 10px;
    }
    .bggrid #modal .modal__inner div:has(.modal__website) {
        margin-top: 5px;
        font-size: 1.4rem;
    }
    .bggrid #modal .modal__inner .modal__needwant {
        padding: 15px 20px;
        margin-top: 15px;
    }
    .bggrid #modal .modal__inner .modal__needwant--title {
        font-size: 1.7rem;
    }
    .bggrid #modal .modal__inner .modal__needwant--content {
        font-size: 1.4rem;
        margin-top: 10px;
    }
}
@media (max-width: 500px){
    .exhibitor {
        padding-top: 30px;
    }
    .exhibitor h2 {
        font-size: 2.8rem;
    }
}

/* ------------------------------------- /
/  partner
/* ------------------------------------- */
.partner {
    padding: 100px 0;
    background-color: white;
    margin: -1px 0;
}
.partner h2 {
    color: #834FE5;
    font-size: 6.2rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.partner .sub_ttl {
    color: #834FE5;
    font-weight: 700;
}
.partner .partner__container {
    padding: 80px;
    margin-top: 70px;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 27px;
    row-gap: 30px;
    box-shadow: #0000003b 0px 0px 12px 2px;
    border-radius: 10px;
}
.partner .partner__container .company {
    display: flex;
    align-items: center;
    width: calc((100% - 27px * 3) / 4);
}
.partner .partner__container .company img {
    object-fit: contain;
    /* aspect-ratio: 1 / 1; */
    margin: 0 auto;
    max-height: 140px;
}
@media (max-width: 1200px){
    .partner {
        padding: 80px 0;
    }
    .partner h2 {
        font-size: 4.0rem;
    }
    .partner .partner__container {
        padding: 60px;
        margin-top: 50px;
        gap: 20px;
        row-gap: 20px;
        border-radius: 10px;
    }
    .partner .partner__container .company {
        width: calc((100% - 20px * 2) / 3);
    }
}
@media (max-width: 768px){
    .partner {
        padding: 30px 0;
    }
    .partner h2 {
        font-size: 3.6rem;
    }
    .partner .partner__container {
        padding: 20px;
        margin-top: 30px;
        gap: 20px;
        row-gap: 20px;
        border-radius: 10px;
    }
    .partner .partner__container .company {
        width: calc((100% - 20px * 1) / 2);
    }
}
@media (max-width: 500px){
    .partner h2 {
        font-size: 2.8rem;
    }
}

/* ------------------------------------- /
/  access
/* ------------------------------------- */
.access {
    padding: 100px 0 170px;
    background-color: white;
    position: relative;
}
.access .access_bg_1 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave.png) repeat-x;
    background-size: 4305px 556px;
    background-position: 0 0;
    animation: bgloop_access_1 50s linear infinite;
}
@keyframes bgloop_access_1 {
    from {background-position: 0  0;}
    to {background-position: -4305px 0;}
}
.access .access_bg_2 {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: url(../img/bg_wave_2.png) repeat-x;
    background-size: 4728px 1026px;
    background-position: 0 100%;
    animation: bgloop_access_2 50s linear infinite;
    opacity: 0.15;
}
@keyframes bgloop_access_2 {
    from {background-position: 0  100%;}
    to {background-position: -4728px 100%;}
}
.access .inner {
    position: relative;
}
.access h2 {
    color: #834FE5;
    font-size: 6.2rem;
    font-family: "Oswald", sans-serif;
    font-weight: 500;
    line-height: 1.5;
}
.access .sub_ttl {
    color: #834FE5;
    font-weight: 700;
}
.access .access__container {
    margin-top: 60px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 30px;
}
.access .access__container iframe {
    width: 100%;
    max-width: 600px;
    height: 450px;
    border-radius: 10px;
}
.access .access__container h4 {
    font-size: 2.2rem;
    font-weight: 700;
}
.access .access__container .access__right .detail {
    margin-top: 30px;
    background-color: white;
    padding: 30px;
    border-radius: 10px;
}
.access .sansin {
    margin-top: 90px;
    padding: 70px 75px 80px;
    box-shadow: #0000003b 0px 0px 12px 2px;
    border-radius: 10px;
    background-color: white;
}
.access h3 {
    font-size: 2.2rem;
    font-weight: 700;
    margin-bottom: 24px;
}
.access .sansin__container {
    display: flex;
    align-items: flex-start;
    gap: 40px;
}
.access .sansin__container iframe {
    margin: 0 auto;
    min-width: 449px;
    aspect-ratio: 449 / 256;
}
.access .sansin__container .facilities {
    margin-top: 30px;
    display: flex;
    flex-wrap: wrap;
    border-top: #E3E3E3 1px solid;
    border-bottom: #E3E3E3 1px solid;
    padding: 20px 10px;
}
.access .sansin__container .facilities div {
    display: flex;
    align-items: center;
    margin-right: 20px;
}
.access .sansin__container .facilities div img {
    width: 11px;
    height: 11px;
}
.access .sansin > a {
    margin: 35px auto 60px;
    color: white;
    background-color: #0A176A;
    border-radius: 3px;
    padding: 10px;
    max-width: 320px;
    display: block;
    text-align: center;
    line-height: 1.7;
    font-size: 1.5rem;
    position: relative;
    font-weight: 700;
}
.access .sansin > a::after {
    content: '';
    position: absolute;
    background-image: url(../img/arrow.svg);
    background-repeat: no-repeat;
    width: 21px;
    height: 17px;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.sansin__img__container {
    display: flex;
    gap: 28px;
    flex-wrap: wrap;
}
.sansin__img__container img {
    width: calc(( 100% - 28px * 2) / 3);
}
@media (max-width: 1200px){
    .access {
        padding: 80px 0 120px;
    }
    .access h2 {
        font-size: 4.0rem;
    }
    .access h3 {
        font-size: 2.0rem;
        margin-bottom: 18px;
    }
}
@media (max-width: 1000px){
    .access .access__container {
        margin-top: 40px;
        flex-direction: column;
    }
    .access .sansin__container {
        flex-direction: column;
    }
    .access .sansin__container iframe {
        min-width: unset;
        width: 100%;
    }
}
@media (max-width: 768px){
    .access {
        padding: 40px 0 80px;
    }
    .access h2 {
        font-size: 6.0rem;
    }
    .access h3 {
        margin-bottom: 15px;
    }
    .access .access__container .access__right .detail {
        margin-top: 20px;
        padding: 10px;
        border-radius: 5px;
    }
    .access .access__container {
        margin-top: 30px;
    }
    .access .access__container h4 {
        font-size: 1.8rem;
    }
    .access .sansin {
        margin-top: 50px;
        padding: 30px 20px 20px;
    }
    .access .sansin > a {
        margin: 25px auto 40px;
    }
}
@media (max-width: 500px){
    .access {
        padding: 20px 0 20px;
    }
    .access h2 {
        font-size: 2.8rem;
    }
    .sansin__img__container img {
        width: 100%;
    }
}

/* ------------------------------------- /
/  footer
/* ------------------------------------- */
footer {
    padding: 100px 0;
    color: white;
    background: #0A176A;
    background-size: cover;
    background-repeat: no-repeat;
}
footer .inner {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    gap: 30px;
}
footer .logo {
    width: 228px;
}
footer .wrapper {
    display: flex;
    justify-content: space-between;
    gap: 60px;
}
footer .copyright {
    text-align: right;
    font-size: 1.2rem;
}
@media (max-width: 1200px){
    footer {
        padding: 80px 0;
    }
    footer .logo {
        width: 250px;
    }
    footer .wrapper {
        gap: 30px;
        flex-direction: column;
        margin-bottom: 30px;
    }
}
@media (max-width: 768px){
    footer {
        padding: 60px 0;
    }
    footer .inner {
        flex-direction: column;
    }
    footer .logo {
        width: 200px;
    }
    footer .wrapper {
        gap: 20px;
    }
}
@media (max-width: 500px){
}
