@charset "UTF-8";

/* Basic Reset */
*,
*:before,
*:after {
  box-sizing: border-box;
  color: inherit; 
  margin: 0;
  padding: 0;
}

/* Layout */
html, body {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 95%;
  width: 100%;
  height: auto;
  margin: initial;
  padding: initial;
  background-color:#ffffff;
  /*background-image: linear-gradient(180deg, #eef7f2, #f0e9a8);*/
}

/* ###################################################################### */
/* COMMON ----------- */
/* BUTTONS ----------- */
.quick-notification {width: 100%; background-color: #ffff004a; font-size: 1rem !important; padding: 1% 5%;}
.detail {margin-bottom: 1.5rem;}
.align-center {margin: 1% auto !important; padding: 2% 0 !important; text-align: center !important;}
hr {margin: 0 0 2% 0;}

.coming_soon {
  width: 100%; margin: auto; padding: 10%; border: 1px solid black;
  font-size: 1.7rem; font-weight: 600; text-align: center; align-content: center;
}
.special_notes {
  width: 100%; padding: 2% 10%; margin: 1% 0% 5% 0%; background-color: #329a9898; font-size: 1.2rem; text-align: center; font-weight: 600;}


  table {border-collapse: collapse; width: 80%; overflow-x: auto; margin: 2% auto; font-size: 1.2rem;}
      th, td {text-align: left; padding: 1%; border: 1px solid #000; text-align: center;}
      th, td .col-name {font-weight: 600;}
      /*tr:nth-child(even) {background-color: transparent;}  */  
      th a {
        font-weight: 600; color: #329a98 !important; text-decoration: underline; text-underline-offset: 5px; }  
      th a:hover {color: #ff9800 !important;text-decoration: underline; transition: 300ms;}
      .disable-tr {background-color: #8080804d;}  

.closing-note {
  width: 100%;
    box-shadow: 0px 10px 14px -7px #9e9d9d;
    background: linear-gradient(to bottom, #fff5e4 5%, #f9e1bb, #fbb54c 100%);
    background-color: transparent;
    border-radius: 4px;
    border: 1px solid #800;
    display: inline-block;
    cursor:default;    
    padding: 3%;
    margin: 0;
    text-decoration: none;
}
.closing-note p {text-align: center !important; font-size: 1.3rem !important; color: #800; font-weight: 600; margin: 0;}

.closing-note-last {
  width: 60%;
    box-shadow: 0px 10px 14px -7px #9e9d9d;
    background-color: #934493;
    border-radius: 4px;
    border: 1px solid rgb(255, 255, 255);
    display: inline-block;
    cursor:default;    
    padding: 3%;
    margin: 0;
    margin-top: 3%;
    text-decoration: none;
}
.closing-note-last p {text-align: center !important; font-size: 1.4rem !important; color: rgb(255, 255, 255); font-weight: 600; margin: 0;}

.download-link {
  width: min(75%);
  box-shadow: 0px 10px 14px -7px #9e9d9d;
	background:linear-gradient(to bottom, #fff5e4 5%, #f9e1bb, #fbb54c 100%);
	background-color:#ff980026;
	border-radius:4px;
	border:1px solid #fbb54c;
	display:inline-block;
	cursor:pointer;
	color:#000000; font-weight: 600;
	padding: 1%;
  margin: 1rem;
	text-decoration:none;
  text-align: center !important;
}
.download-link a {color: #000 !important; text-decoration: none !important;}
.download-link:hover {
  background:linear-gradient(to right, #FF9800 , #ff980026);
}*
.download-link-second {
  width: min(75%);
  box-shadow: 0px 10px 14px -7px #9e9d9d;
	background:linear-gradient(to bottom, #fff7f7 5%, #848483 100%);
	background-color:#ff980026;
	border-radius:4px;
	border:1px solid #000000;
	display:inline-block;
	color:#000000; font-weight: 600;
	padding: 1%;
  margin: 1rem;
	text-decoration:none;
  text-align: center !important;
}
.download-link-second a {color: #000 !important; text-decoration: none !important;}
/*.download-link-second:hover {
  background:linear-gradient(to right, #FF9800 , #ff980026);
}*/

.program-btn {
  width: 100%;
  margin: 3% auto;
  padding: 1%;  
  border: 2px solid #00000000;
  background-image:linear-gradient(to bottom, #ffffffb3 35%, #ffffff 100%);
  border-radius: 4px;
  box-shadow: 0px 8px 15px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease 0s;
  cursor: pointer;
  outline: none;
  
 }
 .program-btn a {
  font-size: 1.2rem;
  font-weight: 600;
  color: #000000 !important;
  text-decoration: none !important;
 }
 .program-btn:hover {
  background:linear-gradient(to right, #1f7c85, #8bc34a54);
    box-shadow: 0px 15px 20px rgba(74, 83, 79, 0.4);
    color: #fff;
    transform: translateY(-7px);
 }
 .program-btn:active {
  transform: translateY(-1px);
}
.contact-info {padding: 0% 15%;}
.contact-info .card {
  box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.2);
    max-width: 85%;
    margin: auto;
    padding: 5% 3%;;
    text-align: center; font-weight: 600;
    background-color: #9e9e9e4f;
    line-height: 1.75;
}

.contact-info .card p {font-size: 1.2rem; text-align: center;}

iframe {width: -webkit-fill-available; margin-bottom: 3%;}
del {
  background-image: linear-gradient(#b81c22, #b81c22);
    background-position: 0 50%;
    background-size: 100% 10%;
    background-repeat: repeat-x;
    text-decoration: none;
    padding: 0 2px;
}


@media (min-width: 320px) and  (max-width: 599px) {
  table {font-size: 1.1rem; width: 100%;}
  .col-name {writing-mode: vertical-rl; height: 12%;}

  .contact-info {padding: 0;}
    .contact-info .card {padding: 5% 0; max-width: 100%;}
    .contact-info .card p {font-size: 1.1rem;}

  .special_notes {font-size: 1rem; padding: 2% 4%;}
  .closing-note {padding: 3% 0;}
    .closing-note p {font-size: 1rem !important;}
  .program-btn a  {font-size: 1rem;}

  
  
}

/* ###################################################################### */
/*--------------------- Side Bar ----------*/
.margin-bottom-add {margin-bottom: 5%;}
.sidebar {
  width: 17%;
  height: 100vh;
  background-color: #329a98;
  color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  padding-top: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow-y: auto;
  transform: translateX(0);
  transition: transform 0.3s ease; z-index: 9999;
}

.sidebar a {
  color: #000000;
  padding: 10px 5px;
  text-decoration: none;
  display: block;
  text-align: center;
  font-size: 1.2rem;
  border-bottom: none;
  border-bottom: 1px dotted #7600003d;

  margin: 0 5px;
  position: relative;
  perspective: 800px;
  overflow: hidden;
}

.sidebar a::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(193, 256, 234, 0.23);
  top: 0;
  left: 0;
  transform: rotateX(90deg) scaleY(0);
  transform-origin: center right;
  transition: transform 0.4s, opacity 1.1s;
}

.sidebar a:hover::before {
  transform: rotateX(0deg) scaleY(1);
  opacity: 0;
}

.sidebar img {width: 50%;}
nav {margin-top: 15%;}



/* ###################################################################### */
/*--------------------- Responsive Buttons ----------*/
.menu-btn, .close-btn {
  display: none;
  font-size: 2rem;
  background-color: transparent;
  border: none;
  color: #091542;
  cursor: pointer;
  position: fixed;
  top: 10px;
  z-index: 1;
}
.menu-btn {left: 3%;}

.close-btn { left: 80%; color: #000;}

@media   (min-width: 1500px) {
  .sidebar a {font-size: 1.5rem;}
}
@media (min-width: 320px) and  (max-width: 599px) {
  .sidebar {width: 50%; transform: translateX(-100%); }
  .sidebar a {font-size: 1.2rem;}
  .menu-btn {display: block; width: 100%;
        background-color: #329a98; border: none;
        left: 0;
        top: 0;         text-align: justify;
        padding: 0 1%;}
  .sidebar img {width: 50%;}
  .sidebar.active {transform: translateX(0);}
  .close-btn {display: block; border:none;}
}

@media (min-width: 600px) and  (max-width: 1023px) {
  .sidebar {width: 35%; transform: translateX(-100%); }
  .sidebar a {font-size: 1.2rem;}
  .menu-btn {display: block;}
  .sidebar img {width: 50%;}
  .sidebar.active {width: 28%; transform: translateX(0);}
  .close-btn {display: block; border:none;}
}


/* ################################################ Right-side ###################### */
.main-container {
  margin-left: 17%; 

}
.background-shape {
  background: orange;
  width: 100%;
  height: 200px;
  -ms-transform: skewY(-20deg);
  -webkit-transform: skewY(-20deg);
  transform: skewY(-20deg);
  border-radius: 30px;
  position: absolute;
  top: 0px;
  left: 50px;
}

  /*-------------------------------*/
  /*-------------------------------*/
  .main-container.top {
    width: 100%;
    max-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    z-index: -10;
  }

  .main-container .top {
  background-image: url("../img/30th_bg.png"); 
  /* background-image: linear-gradient(to right, #598ce9, #93cce0, #afe3f5, #d5dfd7); */
  height: 100vh;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  }
  .main-container .top .hero-text {
  text-align: center;
  position: absolute;
  top: 35%;
  left: 50%;
  margin: 5% 0;
  transform: translate(-50%, -50%);
  color: #800;
  width: 100%;
  }
  .main-container .top .hero-text h1 {
    font-size: 3rem; font-weight: 600; margin: 0 auto 2%; color: #ffffff;
  }

  .main-container .top .hero-text h2 {
    font-size: 5.3rem;
    font-weight: 600;
    line-height: 1;
    font-family: YuMincho, "游明朝体", Yu Mincho, "游明朝", serif;
    text-align: center;
    /* color: #FF9800; */
    /* text-shadow:-1px -1px 1px #b3a30f, 1px 1px 2px #574e4e; */
    color: #813090;
    padding: 10px 0;
    text-shadow: 2px 2px 5px #f9f9f9;
    background-image: linear-gradient(to right, #c8cab500, #fbfbfb6b, #f0ba9400);
  }
  /*.main-container .top .hero-text h2 {font-size: 3.8rem; font-weight: 600; color: #03487f; line-height: 1.3;
    font-family: YuMincho, "游明朝体", Yu Mincho, "游明朝", serif; background-image: linear-gradient(to right, #c8cab500, #d7debc6b, #f0ba9400); 
  }*/

    
  .main-container .top .hero-text h2 span {font-size: 2.3rem;}
  .main-container .top .hero-text h4 {font-size: 1.2rem; color: #000; background: #cbdfe9a3;}
  .main-container .top .hero-text .info-wrap { max-width: 1000px; 
    display: flex; flex-direction: row; width: 85%; margin: 5% auto 0; }
  .main-container .top .hero-text .info-wrap .info-wrap-col {width: calc(50%); margin: 2% auto; padding: 0%; }
  .main-container .top .hero-text .info-wrap .info-wrap-col ul li {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    margin-bottom: 0rem; }

    .main-container .top .hero-text .info-wrap .info-wrap-col ul li .top-circle {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      width: 5rem;
      height: 5rem;
      aspect-ratio: 1 / 1;
      clip-path: polygon(25% 6%, 75% 6%, 100% 50%, 75% 91%, 25% 90%, 0% 50%);
      background: #329a98a3;
      opacity: 85%; }
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li .top-circle p {font-size: 1rem; color: #000000;}
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li .circle-text p {
      font-size: 1.2rem; font-weight: 600; margin-left: 1.5rem; text-align: justify;}
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li .circle-text p span {
      font-size: 1.5rem; font-weight: 600; color:#000 ;}
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li p {
      font-size: 1.5rem; font-weight: 600; color: #000;}
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li dd span { 
      font-size: 1.5rem; font-weight: 600; color: #000;}
      .main-container .top .hero-text .info-wrap .info-wrap-col ul li dd {
        font-size: 1.0rem; font-weight: 590; margin-top: 3%;  text-align: justify; color: #000;}


   @media (min-width: 1024px) and  (max-width: 1150px) {.main-container .top .hero-text .info-wrap {width: 96%;}}
   @media (min-width: 600px) and  (max-width: 1023px){
    
    .main-container .top .hero-text .info-wrap {width: 96%;}
    .main-container {margin-left: 0;padding-top: 0%;  width: 100%;}
    .main-container .top .hero-text h1 {font-size: 1.5rem;}


    .main-container .top .hero-text .info-wrap {display: flex; flex-direction: row; } 
    .main-container .top .hero-text .info-wrap .info-wrap-co l{width: calc(100%); margin: 2% 5%; }

    .main-container .top .hero-text .info-wrap .info-wrap-col ul li .circle-text p span {font-size: 1.3rem;}
    .main-container .top .hero-text .info-wrap .info-wrap-col ul li .circle-text p {font-size: 1.1rem;}

  }

  @media (min-width: 320px) and  (max-width: 599px){
    .main-container {margin-left: 0;}
    .main-container .top {height: 115vh;}
    .main-container .top .hero-text {
      text-align: center;
      position: absolute;
      bottom: 0;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 100%;
      }
    .main-container .top .hero-text .info-wrap {width: 100%; display: flex; flex-direction: column; padding: 0 5%; margin: 1% auto 0;}
    .main-container .top .hero-text .info-wrap .info-wrap-col{width: calc(100%); margin: 2% 0; }  
    .main-container .top .hero-text h1 {font-size: 1.3rem; margin: 2% 0;}
    .main-container .top .hero-text h2 {font-size: 2.1rem; background-color: transparent; line-height: 1.3;}
    .main-container .top .hero-text h2 span {font-size: 2rem;}
    .main-container .top .hero-text .info-wrap .info-wrap-col ul li .top-circle {height: 5rem; width: 5rem;}
    .main-container .top .hero-text .info-wrap .info-wrap-col ul li dd span {font-size: 1.3rem;}
        
    .main-container .top .hero-text .info-wrap .info-wrap-col ul li .circle-text p span {font-size: 1.3rem;}
  }


/* ###################################################################### */
  /* SUB-CONTAINER ----------- */
  .sub-container {
    width: 100%;
    height: auto;
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    z-index: -10;    
  } 

  .sub-container .text-area {width: 75%; margin: auto; padding: 0;}
 
/* ----------- */
.text-cont { width: 100%; min-height: 100vh; padding: 1% 1% 5% 1%; margin: auto;}

.text-cont h1 {font-size: 3rem; text-align: center; margin: 3% auto; color: #216564; font-weight: 600;
background-image: linear-gradient(to bottom, #329a98, #b9e6f900, #c8cab500, #b2ebf200, #329a98); width: 75%; }
.text-cont h2 {font-size: 1.8rem; text-align: justify; margin: 3% auto; color: #000000; border-bottom: 1px solid #000000; font-weight: 600;}
.text-cont h3 {font-size: 1.8rem; text-align: center; margin: 2% auto; color: #000000;}
.text-cont h4 {font-size: 1.4rem; text-align: justify; margin: 1% auto; color: #000000;}
.text-cont h5 {font-size: 0.9rem; text-align: justify; margin: 1% 0; font-weight: 500;}
.text-cont p {font-size: 1.2rem; text-align: justify; margin-left: 1%;}
.text-cont a {color: #216564; text-decoration: underline; text-underline-offset: 5px;}
.text-cont a:hover {color: #ff9800;}
.highlights {
  width: min(75%);
  font-size: 1.8rem;
    background-image: linear-gradient(360deg, #76736d, transparent);
    border-radius: 25px;
    padding: 1.0rem;
    margin: 1rem;
    text-align: center !important;
    transition: all ease-in-out 0.5s;
    color: #2b160f;
    font-weight: 600;
}

@media (min-width: 1200px) and  (max-width: 3500px) {
  .sub-container .text-area {width: 60%;}
}

@media (min-width: 600px) and  (max-width: 1023px) {
  .sub-container .text-area {width: 85%;}
  .coming_soon {padding: 8%;}

  .highlights {width: min(75%);}
 .download-link  {width: min(75%);}
}

@media (min-width: 320px) and  (max-width: 599px) {
 .sub-container .text-area {width: 92%; padding: 0;}

 .text-cont { width: 100%;}  
 .text-cont p {font-size: 1rem; margin-left: 0;}  
  .text-cont h1 {font-size: 2rem; width: 100%; margin-top: 15%;}
 .text-cont h2 {font-size: 1.5rem;}
 .text-cont h3 {font-size: 1.4rem;}
  .text-cont h5 {font-size: 0.8rem;}

 .coming_soon {font-size: 1.5rem; padding: 8% 10%; margin: auto;}
 .highlights {width: min(100%);}
 .download-link  {width: min(100%);}
}
  
   /* ----------------------------------------------------------------------------- */
   .sub-container .text-area .news {}
   .sub-container .text-area .news .ad-banner {width: 100%; margin: 10% 0; display: flex; flex-direction: row;}
   .sub-container .text-area .news .ad-banner .ad-banner-slot {width: 20%; margin: auto;}
   .sub-container .text-area .news .ad-banner .ad-banner-slot img {width: 100%;}

   .sub-container .text-area .news .news-wrap {margin: 8% auto 20%; width: 70%;}
   .sub-container .text-area .news .news-wrap ul li {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: nowrap;
    border-bottom: #6158584f solid 1px;
    margin-bottom: clamp(0.5rem, 0.391rem + 0.55vw, 0.8rem); }

    .sub-container .text-area .news .news-wrap ul li .date {
      width: 10rem;
      font-size: clamp(1.1rem, 0.991rem + 0.55vw, 1.4rem);
      font-weight: 700;
      color:#000000; }
    .sub-container .text-area .news .news-wrap ul li .cont {
      width: 100%;
      max-width: 100%;
      font-size: 1.2rem;
      font-weight: 500;
      margin-left: clamp(0.6rem, 0.455rem + 0.73vw, 1rem);
      color: #000000;  }
    .sub-container .text-area .news .news-wrap ul li .cont a {
      color: #2199f4; text-decoration: none; font-size: 1.2rem;}
    .sub-container .text-area .news .news-wrap ul li .cont a:hover {color: #ff9800; }


       @media (min-width: 1900px) and  (max-width: 3500px) {
        .sub-container .text-area .news .news-wrap {width: 45%;}
      }

       @media (min-width: 1400px) and  (max-width: 1900px) {
        .sub-container .text-area .news .news-wrap {width: 60%;}
      }
      
      @media (min-width: 600px) and  (max-width: 1023px) {
        .sub-container .text-area .news .news-wrap {width: 65%;}
      }
  
      @media (min-width: 320px) and  (max-width: 599px) {
        .sub-container .text-area .news .news-wrap {width: 95%;}
        .sub-container .text-area .news .news-wrap ul li {flex-direction: column;}

        .sub-container .text-area .news .ad-banner{flex-direction: column !important;}
        .sub-container .text-area .news .ad-banner .ad-banner-slot {width: 65%; margin: auto;}
   
      }
   
   /* ----------- */
   .sub-container .text-area .greeting .greeting-wrap {width: 85%; margin: auto;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text {width: 100%; margin-bottom: 5%;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text h4 {border-bottom: #000000 solid 1px; margin-bottom: 5%; padding: 1%;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-img {float: right; margin-left: 5%; margin-bottom: 2%;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-img img {width: 100%; max-width: clamp(10rem, 12rem + 10vw, 15rem);}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text p {font-size: 1.2rem;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-from {display: flex; flex-direction: column; justify-content: center; align-items: flex-end;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-from ul {margin-top: 10%;}
   .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-from ul li {font-size: 1.2rem; font-weight: 500; list-style-type: none;}
   .sub-container .text-area .greeting video {width: 100%;}

   @media (min-width: 600px) and  (max-width: 1023px) {
    .sub-container .text-area .greeting .greeting-wrap {width: 85%;}
   }
  
   @media (min-width: 320px) and  (max-width: 599px) {
    .sub-container .text-area .greeting .greeting-wrap {width: 95%;}
    .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-img {float: none; text-align: center; margin: 7% auto; padding: 0%;}
    .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text p {font-size: 1rem;}
    .sub-container .text-area .greeting .greeting-wrap .greeting-wrap-text .greeting-from ul li {font-size: 1rem;}
  
   }

   /* ----------- */
   .sub-container .text-area .outline {}
   .sub-container .text-area .outline .outline-wrap {width: 85%; margin: auto;}
   .sub-container .text-area .outline .outline-wrap .sponsor-title {font-size: 1.5rem !important;}



   @media (min-width: 600px) and  (max-width: 1023px) {
    .sub-container .text-area .outline .outline-wrap {width: 85%; }
   }
  
   @media (min-width: 320px) and  (max-width: 599px) {
    .sub-container .text-area .outline .outline-wrap {width: 95%; }
    .sub-container .text-area .outline .outline-wrap .sponsor-title {font-size: 1.3rem !important;}
   }

   /* ----------- */
   .sub-container .text-area .abstract {}
   .sub-container .text-area .abstract .title {
    text-align: center !important; color: #000000;
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 1;
    margin-bottom: 1rem;
  }
  .sub-container .text-area .abstract .abstract-wrap {width: 100%;}
  .sub-container .text-area .abstract ul {
    margin-left: 0.3em; }
    @media screen and (max-width: 780px) {
      .sub-container .text-area .abstract ul {
        margin-left: initial; } }
        .sub-container .text-area .abstract ul li {
      display: flex;
      flex-direction: row;
      justify-content: flex-start;
      align-items: flex-start;
      font-size: 1.5rem;
      margin-bottom: 2rem; }
      @media screen and (max-width: 780px) {
        .sub-container .text-area .abstract  ul li {
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: flex-start; } }
          .sub-container .text-area .abstract ul li .front {
        font-weight: 600;
        color: #000000;
        width: 12em; }
        .sub-container .text-area .abstract ul li .bottom {
        font-size: 1.2rem;
        font-weight: 500;
        color: #000000;
        width: 100%; }
        .sub-container .text-area .abstract ul li .bottom span {color:  #b81c22; font-weight: 600;}
        .sub-container .text-area .abstract ul li .bottom ul.bottom-list li {
          font-size: 1.0rem; margin-bottom: 0; }

   @media (min-width: 600px) and  (max-width: 1023px) {}
  
   @media (min-width: 320px) and  (max-width: 599px) {
    .sub-container .text-area .abstract ul li .bottom {font-size: 0.9rem;}
    .sub-container .text-area .abstract .title {font-size: 1.3rem;}
   }

   /* ----------- */
   .sub-container .text-area .program{}
   .sub-container .text-area .program .program-wrap {width: 100%;}
   .sub-container .text-area .program .program-wrap .time-wrap {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
    width: min(100%, 78rem);
    margin: 2rem 0;}
   .sub-container .text-area .program .program-wrap .time-wrap .time-line {
    width: 7rem; }
   .sub-container .text-area .program .program-wrap .time-wrap .time-line  p {
    font-size: 1.5rem; 
    font-weight: 600;
    margin-bottom: 2rem;}


   .sub-container .text-area .program .program-wrap .time-wrap .prog-cont {width: calc(100% - 2rem); display: flex; flex-direction: column;}
   .sub-container .text-area .program .program-wrap .time-wrap .prog-cont h3.heading {
    border-bottom: #000000 solid 0.5px;
    color: #000000; font-weight: 600;
    padding: 0 0rem;
    margin-bottom: 2rem;
    font-size: 1.5rem; text-align: left !important; margin: 0 0 2rem 0;
}
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont h3.heading span {
  font-size: 1.0rem;
  margin-left: 1em;
}
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont h3.heading.noUnderline {border-bottom: none !important; margin: 3% 0 2% 0;}

.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 1rem;
}

.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer .name {
   width: 5.2em; text-align: left !important; margin: 0 0.5rem 0 0; font-size: 1.1rem; font-weight: 600;}
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer p.post {font-size: 1.1rem; font-weight: 500; }
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer p.part {width: 4.5em; font-size: 1.1rem; font-weight: 600; margin-left: 0%;}
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer p.part span {font-weight: 500;}

.sub-container .text-area .program .program-wrap .time-wrap .subject {
  display: flex;
    flex-direction: row;
    justify-content: flex-start;
    align-items: baseline;
    margin-bottom: 1rem;
}
.sub-container .text-area .program .program-wrap .time-wrap .subject h4.general {font-size: 1.2rem; text-align: justify; margin: 0; color: #000000; font-weight: 500;}
.sub-container .text-area .program .program-wrap .time-wrap .prog-cont .subject p.title-x {
  width: 100%; font-weight: 600; font-size: 1.4rem;}
  .sub-container .text-area .program .program-wrap .time-wrap .subject p.part {width: 4.5em; font-size: 1.2rem; font-weight: 600;  margin-left: 0%;}


    .sub-container .text-area .program .program-wrap .time-wrap .rest { width: 100%;
      margin-bottom: 1.5rem;}
      .sub-container .text-area .program .program-wrap .time-wrap .rest p.minits {
        font-size: 1.2rem; font-weight: 590; color:#000; border-bottom: rgb(0, 0, 0) solid 1px; text-align: right;
      }



   @media (min-width: 600px) and  (max-width: 1023px) {
    .sub-container .text-area .program .program-wrap .time-wrap {flex-direction: column; width: 100%;}
    .sub-container .text-area .program .program-wrap .time-wrap .prog-cont {width: 98%;}

   }
  
   @media (min-width: 320px) and  (max-width: 599px) {
    .sub-container .text-area .program .program-wrap .time-wrap {flex-direction: column; width: 100%;}
    .sub-container .text-area .program .program-wrap .time-wrap .time-line  p {margin-bottom: 0;}
    .sub-container .text-area .program .program-wrap .time-wrap .prog-cont {width: 100%;}
    .sub-container .text-area .program .program-wrap .time-wrap .prog-cont  h3.heading {font-size:1.2rem; margin: 0 0 1rem 0;}
      .sub-container .text-area .program .program-wrap .time-wrap .prog-cont .performer {flex-direction: column; align-items:flex-start; margin-bottom: 5%;}
      .sub-container .text-area .program .program-wrap .time-wrap .subject {flex-direction: column;}
      .sub-container .text-area .program .program-wrap .time-wrap .subject p.part {margin-bottom: 1rem;}
      .sub-container .text-area .program .program-wrap .time-wrap .prog-cont .subject p.title-x {font-size: 1rem;}
      .sub-container .text-area .program .program-wrap .time-wrap .subject h4.general {font-size: 1rem;}
      
      
   }

   /* ----------- */
   .sub-container .text-area .registration {}

   .registration-due {width: 100%; display: flex; flex-direction: column;}
   .registration-due .registration-due_info {display: block; margin: 3% 0;; text-align: center;}
   .registration-due .registration-due_info .title p {font-size: 1.7rem; text-align: center;}
   .registration-due .registration-due_info .title p span {font-size: 1.2rem;}
   .registration-due .registration-due_info .desc dl {padding: 0 3%;  margin: 3% 0 0 0; text-align: justify; font-weight: 500;}
   .registration-due .registration-due_info .desc dl dt {margin: 2% 0 0 0;}
   .registration-due .registration-due_info .desc dl dt span {color:  #b81c22; font-weight: 600;}
   .registration-due .registration-due_info .desc dl dd {margin: 2% 0 0 0;}

   .sub-container .text-area .registration .registration-wrap {width: 100%;}

   .tab {
    overflow: hidden;
    border: none;
    background-color: #47bbb080;
    margin-bottom: 5%;
    padding: 2% 0;
    text-align: center;
  }
  .tab button {
    width: 46%;
    float: left;
    border: none;
    outline: none;
    cursor: pointer;
    padding: 1% 4%;
    margin: 0 2%;
    transition: 0.3s;
    font-size: 1.5rem;
    color: #ffffff;
    font-weight: 600;
  }
 
  .tab button.active {
    opacity: 1;
  }

  .btn-color-blue {background-color: rgb(18, 108, 104); opacity: 0.5;}
  .btn-color-org {background-color: #FF9800;  opacity: 0.5;}

  .tabcontent {
    display: none; padding: 0%; border-top: none;} 

  .tabcontent .tabcontent-wrap {
    width: 75%; display: flex; flex-direction: row; margin: 7% auto;}

        .tabcontent .tabcontent-wrap .tab-link-second {
      width: min(50%); background:linear-gradient(to bottom, #d0d0d0 5%, #d0d0d0 100%);    
      margin: auto 2%; padding: 3% 0; text-align: center; box-shadow: 0px 10px 14px -7px #9e9d9d;}      
    .tabcontent .tabcontent-wrap .tab-link-second a {font-size: 1.2rem; color: rgb(0, 0, 0) !important; font-weight: 600; text-decoration: none;}
    /*.tabcontent .tabcontent-wrap .tab-link:hover {
      background-image: linear-gradient(to right, #ffc07f,  #fff7f7); font-weight: 600;}*/
      .tabcontent .tabcontent-wrap .tab-link {
      width: min(50%); background:linear-gradient(to bottom, #fff5e4 5%, #f9e1bb, #fbb54c 100%); border-radius: 4px;    
      margin: auto 2%; padding: 3% 0; text-align: center; border: 1px solid #fbba58; box-shadow: 0px 10px 14px -7px #9e9d9d;}      
    .tabcontent .tabcontent-wrap .tab-link a {font-size: 1.2rem; color: rgb(0, 0, 0) !important; font-weight: 600; text-decoration: none;}
    .tabcontent .tabcontent-wrap .tab-link:hover {
      background-image: linear-gradient(to right, #ffc07f,  #fff7f7); font-weight: 600;}

      .tabcontent .participation_fee {width: 98%; margin:  5% auto;}
      .tabcontent .participation_fee ul li {font-size: 1.2rem; margin-bottom: 3%;}
      .tabcontent .participation_fee ul li h4 {font-size: 1.2rem; padding-left: 2%; }

      .tabcontent .participation_fee ul li span {color: #000000; font-weight: 600; }
      .tabcontent .participation_fee ul li .tab-btn {width: 75%; margin: 0;}

  /* 展開されるコンテンツ内の締切情報スタイル */
  .tabcontent .tabcontent-registration-due {width: 98%; margin: 5% auto;}
  .tabcontent .tabcontent-registration-due .title p {font-size: 1.2rem; text-align: center;}
  .tabcontent .tabcontent-registration-due .title p span {font-size: 1.2rem !important; font-weight: 500;}
  .tabcontent .tabcontent-registration-due .desc dl {padding: 0 3%; margin: 3% 0 0 0; text-align: justify; font-weight: 500;}
  .tabcontent .tabcontent-registration-due .desc dl dt {margin: 2% 0 0 0; font-size: 1.2rem;}
  .tabcontent .tabcontent-registration-due .desc dl dd {margin: 2% 0 0 0; font-size: 1.2rem;}

  @media (min-width: 1250px) and  (max-width: 3500px) {
    .registration-due .registration-due_info .desc dl {padding: 0 6%;}
  }
   @media (min-width: 600px) and  (max-width: 1023px) {}
  
   @media (min-width: 320px) and  (max-width: 599px) {
    .tabcontent .tabcontent-wrap {flex-direction: column; width: 100%;}
    .tabcontent .tabcontent-wrap .tab-link  {width: 100%; margin: 1% auto; }

    .tabcontent .participation_fee ul {margin: auto 2%;}

    .tabcontent .participation_fee ul li h4 {font-size: 1rem; }
    .tabcontent .participation_fee ul li {font-size: 1rem;}
    .tabcontent .participation_fee ul li .tab-btn {width: 100%;}

    .tabcontent .tabcontent-wrap .tab-link a {font-size: 1rem;}

    .registration-due .registration-due_info .title p span {font-size: 1rem !important;}
    .registration-due .registration-due_info .desc dl {padding: 0%;}
    
    /* 展開されるコンテンツ内の締切情報のモバイル対応 */
    .tabcontent .tabcontent-registration-due .title p {font-size: 1rem;}
    .tabcontent .tabcontent-registration-due .title p span {font-size: 1rem !important;}
    .tabcontent .tabcontent-registration-due .desc dl dt {font-size: 1rem;}
    .tabcontent .tabcontent-registration-due .desc dl dd {font-size: 1rem;}
   }

   /* ----------- */
    .sub-container .text-area .credit {}
    .sub-container .text-area .credit .credit-wrap {width: 100%;}

    .sub-container .text-area .credit .credit-text {width: 100%;}
    .sub-container .text-area .credit .credit-text ul li {font-size: 1.2rem; list-style-type: square; margin-bottom: 5%;}
    .sub-container .text-area .credit .credit-text ul li span{margin-left: 2%; font-size: 1rem;}
  

    @media (min-width: 600px) and  (max-width: 1023px) {}
  
    @media (min-width: 320px) and  (max-width: 599px) {
      .sub-container .text-area .credit .credit-text ul {margin: auto 2%;}
      .sub-container .text-area .credit .credit-text ul li { font-size: 1rem;}
    }
 
   /* ----------- */


/* ###################################################################### */
.wave-container {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 350px;
  overflow: hidden;
  z-index: 0;
}

.wave {
  position: absolute;
  width: 200%;
  height: 100%;
  animation: moveX 8s linear infinite;
}

.wave svg {
  width: 100%;
  height: 100%;
}

.wave path {
  fill: none;
  stroke: #ffffff;
  stroke-width: 0.75;
  animation: wavePulse 2s ease-in-out infinite alternate;
}

.wave.wave1 {
  top: 0;
  animation-duration: 16s;
}

.wave.wave2 {
  top: 5cqb;
  animation-duration: 12s;
}

.wave.wave3 {
  top: 10px;
  animation-duration: 8s;
}

@keyframes moveX {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

@keyframes wavePulse {
  0% {
    transform: translateY(0);
    stroke-opacity: 0.3;
  }
  100% {
    transform: translateY(-4px);
    stroke-opacity: 0.6;
  }
}
/*-- FOOTER -----------------------*/
.footer {
  position: fixed;   
  bottom: 0;
  width: 100%;
  height: 4%;
  padding: 0.5% 0 0 15%;
  background-color: #eba899;
}
 .footer p {
    text-align: center;
    color: #000000;
    font-size: 0.8rem;
    font-weight: 500;
    letter-spacing: 0.2rem;
    line-height: 1;
  }
  .footer p span {
    font-size: 0.7rem;
    font-weight: 600;
    letter-spacing: 0;
  }

  @media (min-width: 600px) and  (max-width: 1023px) {
    .footer {padding: 1% 2%;}
  }  
  @media (min-width: 320px) and  (max-width: 599px) {
    .footer {padding: 1% 2%;}
    .footer p {line-height: 0.9; margin: 0.5% 0;}
    .footer p span {font-size: 0.6rem; letter-spacing: 0; padding: 0 1%;}
    .wave-container {height: 250px;}
  } 


/*
   @media (min-width: 600px) and  (max-width: 1023px) {}  
   @media (min-width: 320px) and  (max-width: 599px) {}
*/

    /* ----------- */
 

.tabcontent .tabcontent-registration-due > span {
  font-size: 1.2rem;
  font-weight: 500;
  display: block;
  margin-bottom: 1em;
}
@media (min-width: 320px) and (max-width: 599px) {
  .tabcontent .tabcontent-registration-due > span {
    font-size: 1rem;
  }
}

.tabcontent .tabcontent-registration-due > span::first-letter {
  font-size: 1.2rem;
  font-weight: 500;
}
@media (min-width: 320px) and (max-width: 599px) {
  .tabcontent .tabcontent-registration-due > span::first-letter {
    font-size: 1rem;
  }
}

#registration.text-cont.registration {
  min-height: 40vh !important;
  padding-bottom: 0 !important;
}

/* プログラム（CSSグリッド）用スタイル - 追加要望対応 */
.program-grid {
  display: grid;
  grid-template-columns: 4em 5.5em 2fr;
  grid-template-rows: auto auto auto;
  gap: 0.2em 1em;
  width: 100%;
  margin: 1.5rem 0 2rem 0;
  font-size: 1.1rem;
}
.program-grid .label,
.program-grid .value,
.program-grid .affiliation {
  background: none;
  border: none;
  padding: 0.4em 0.2em;
  font-weight: 600;
  color: #222;
}
.program-grid .title-label {
  grid-row: 1;
  grid-column: 1;
}
.program-grid .title-value {
  grid-row: 1;
  grid-column: 2;
  font-weight: 700 !important;
  font-size: 1.3rem;
  padding-top: 3px;
}
.program-grid .person-label {
  grid-row: 2 / span 2;
  grid-column: 1;
  font-weight: 600;
  color: #000;
  white-space: pre-line;
}
.program-grid .value {
  font-weight: 400;
  color: #222;
}
.program-grid .value.name-bold {
  font-weight: 700;
}
.program-grid .affiliation {
  font-weight: 400;
  color: #222;
}
.program-grid .label,
.program-grid .title-value {
  align-self: start;
}
@media (max-width: 800px) {
  .program-grid {
    grid-template-columns: 5em 7em 1.5fr;
    font-size: 1.05rem;
  }
}
@media (max-width: 500px) {
  .program-grid {
    grid-template-columns: 1fr;
    font-size: 0.92rem;
  }
  .program-grid .label,
  .program-grid .value,
  .program-grid .affiliation {
    padding: 0.5em 0.4em;
  }
  .program-grid .title-label,
  .program-grid .person-label {
    grid-row: auto;
    grid-column: 1;
  }
  .program-grid .title-value {
    grid-row: auto;
    grid-column: 1;
  }
}

@media (max-width: 599px) {
  .program-grid {
    display: block;
    margin-bottom: 2.5em;
  }
  .program-grid .label,
  .program-grid .value,
  .program-grid .affiliation {
    display: block;
    width: 100%;
    padding: 0.2em 0;
    font-size: 1.1rem;
  }
  .program-grid .label {
    font-weight: 600;
    margin-top: 1.1em;
    margin-bottom: 0.2em;
  }
  .program-grid .title-label {
    margin-top: 0;
  }
  .program-grid .title-value {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 0.5em;
  }
  .program-grid .affiliation {
    font-size: 1.1rem;
    color: #222;
    margin-bottom: 1em;
  }
}


/* Contenedor del póster */
.poster-container {
  text-align: center;
}

/* Imagen del póster responsive */
.poster {
  width: 100%;
  max-width: 300px;
  height: auto;
  cursor: pointer;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
  transition: transform 0.3s ease;
}

.poster:hover {
  transform: scale(1.03);
}

/* Móviles */
@media (max-width: 600px) {
  .poster {
    max-width: 90%;
  }
}

.closing-note-new {
  width: 100%;
    box-shadow: 0px 10px 14px -7px #9e9d9d;
    background: linear-gradient(to bottom, #86daff 5%, #77c9ed, #0b77cd 100%);
    background-color: transparent;
    border-radius: 4px;
    border: 1px solid #03a9f4;
    display: inline-block;
    cursor:default;    
    padding: 3%;
    margin: 0;
    align-items: center;
    text-decoration: none;
}
.closing-note-new p {text-align: center !important; font-size: 1.3rem !important; color: #063d69; font-weight: 600; margin: 0;}

