@charset "utf-8";
@import url("https://fonts.googleapis.com/css2?family=Quattrocento&display=swap");
/* CSS Document */ 
:root {
  --font-size-sm: clamp(0.7rem, 0.09vw + 0.68rem, 0.75rem);
  --font-size-base: clamp(0.88rem, 0.23vw + 0.82rem, 1rem);
  --font-size-md: clamp(1.09rem, 0.43vw + 0.98rem, 1.33rem);
  --font-size-lg: clamp(1.37rem, 0.74vw + 1.18rem, 1.78rem);
  --font-size-xl: clamp(1.71rem, 1.2vw + 1.41rem, 2.37rem);
  --font-size-xxl: clamp(2.14rem, 1.86vw + 1.67rem, 3.16rem);
  --font-size-xxxl: clamp(2.67rem, 2.8vw + 1.97rem, 4.21rem);
  --color-rightblue: #2dd36f;
  --color-white: #ffffff;

}
/* 共通スタイル------------------------- */
body {
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
  font-size: var(--font-size-base);
  line-height: 1.4;
  color: #001d52;
  height: 100%;
  margin: 0;
  font-feature-settings: "palt";
}
h2 {
  font-family: Quattrocento;
  font-weight: normal;
  font-size: var(--font-size-xl);
  text-align: center;
  padding-bottom: 20px;
  color: var(--color-white);
}
h2 span {
  color: var(--color-rightblue);
}
h2.pt20 {
  padding-top: 2rem;
}
a {
  text-decoration: none;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
  color: #001d52;
}
ul {
  list-style: none;
}
img {
  width: 100%;
  height: 100%;
}
header {
  position: relative;
}


#contents-wrap {
  margin: 0 auto;
  padding: 0;
  line-height: 1.6;
background: rgb(0,0,0);
/* background: linear-gradient(90deg, rgba(0,0,0,1) 0%, rgba(2,6,43,1) 17%, rgba(73,155,240,1) 36%, rgba(5,12,84,1) 79%, rgba(214,132,155,1) 100%); */
background:linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgb(2 43 17) 17%, rgb(0 93 51) 36%, rgb(3 93 69) 79%, rgba(228, 175, 62, 1) 100%);
}
.PCmain {
  display: block;
}
.SPmain {
  display: none;
}
/* btn  */

.head-btn {
    padding: 3rem 0;
}
.btn-wrap {
  text-align: center;
  width: 40%;
  margin: 0 auto;
  color: var(--color-white);
  padding-bottom: 1.5rem;
}
.btn-wrap p.deadline {
  color: var(--color-white);
  font-weight: bold;
}
.btn-wrap p.deadline02 {
  color: var(--color-white);
  font-size: var(--font-size-md);
}
.btn-wrap.mt30 {
  margin-top: 30px;
}
.btn-wrap.pb0 {
  padding-bottom: 0;
}


/* main */
#main-contents {
  width: 100%;
  margin: 0 auto;
}
.greeting-wrap {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
  padding: 1rem;
  color: var(--color-white);
}
.greeting-text {
  text-align: left;
  font-size: var(--font-size-base);
}


.about-wrap {
  width: 100%;
  margin: 30px auto 0;
  padding: 0 10px;
}
.about-list {
  max-width: 1100px;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: auto;
  padding-bottom: 4rem;
}
.about-list dt {
  display: block;
  width: 15%;
  text-align: center;
  font-weight: bold;
  padding-top: 10px;
  border-top: 1px solid #f4f8f9;
  color: var(--color-white);
}
.about-list dt.pt20 {
  padding-top: 23px;
}
.about-list dt.pt20bt {
  border: none;
}
.about-list dt.pt20bt02 {
  padding-top: 23px;
}
.about-list dd {
  width: 85%;
  padding: 10px 20px 3px;
  background-color: #000d4a30;
}


.instructor-wrap {
  width: 100%;
  margin: 0 auto 30px;
}
.instructor-intro {
  padding: 60px 0 30px;
}
.instructor-intro.bg-white {
  background: #00000060;
  max-width: 1100px;
  width: 100%;
  margin: auto;
}
.instructor-list {
  background-color: var(--color-white);
  margin: 30px 0 0 0;
  padding: 15px;
  max-width: 100%;
  width: 100%;
}


.program-wrap {
  width: 100%;
  margin: 0 auto 3rem;
  padding: 60px 10px;
  background: #ececec;
}
.program-wrap h2 {
  color: #000d4a80;
}
.program-list {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: .5rem 0;
}
.program-list ul {
  list-style: none;
  color: var(--color-white);
  display: flex;
  justify-content: flex-start;
}
.program-list-box {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  padding: 2rem 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.program-list-box .guests-list {
  color: var(--color-white);
  width: 25%;
  margin-bottom: 2rem;
}
.proguram-time {
  border-top: 3px solid #CCCCCC50;
  font-family: Quattrocento;
  width: 20%;
  font-size: var(--font-size-lg);
  padding: 1.5rem 0;
}
.proguram-guests {
  padding: 1.5rem 2rem 1rem 1rem;
  width: 80%;
  border-top: 3px solid #CCCCCC50;
}
.program-title {
  word-break: break-all;
  font-size: var(--font-size-lg);
}
.border-top {
  /*border-top:1px solid #CCCCCC50;*/
  padding: 1rem 0;
}
.guests-link {
  display: flex;
  justify-content: flex-start;
  color: var(--color-white);
}
.guests-list a:hover {
  opacity: 0.6;
}
.guests-linktext {
  margin-left: 2rem;
}
 .guests-link-2{
  color: var(--color-white);
  margin: 0 auto;
  display: block;
  width: 200px;
}
.guests-linktext-2 {
  margin-top: 1rem;
}
.sponsor .guests-link-2 {
  max-width: 180px;
}

.guests-link-2 .anchor{
    text-align: center;
    width: 100%;
    display: block;
    border-radius: 20px;
    background: #2dd36f;
    margin: 1rem 0;
}


.gaiyo {
  width: 100%;
}
.gaiyo-label {
  margin-top: 1rem;
  width: 120px;
  padding: 0.25rem 1rem;
  color: var(--color-white);
  border: 1px solid #2dd36f;
  background: rgb(73 155 240 / 31%);
}
.gaiyo-txt {
  word-break: break-all;
  font-size: 0.825rem;
  padding: 1rem;
  border: 1px solid #cccccc80;
  background: #4f400440;
  color: var(--color-white);
}
.popup-wrap {
  display: flex;
  justify-content: flex-start;
  padding: 1rem;
  border-bottom: 1px solid #CCCCCC50;
}
.popup-wrap div:nth-child(2) {
  padding-left: 1rem;
}
.guests-name {
  font-size: 1.25rem;
  font-weight: bold;
}
.popup-text {
  padding-top: 1rem;
}
.popup-wrap img {
  max-width: 150px;
  max-height: 150px;
  width: 100%;
  height: 100%;
}
.program-title {
  color: #ffeb78;
}
.program-title-label {
  border-bottom: 1px solid var(--color-white);
  font-weight: bold;
  padding: 0.5rem;
  margin-bottom: 0.25rem;
  color:var(--color-white);
  display: block;
}
.guests-label {
  background: #2dd36f;
  font-weight: bold;
  padding: 0 0.5rem;
  margin-bottom: 0.25rem;
  color: var(--color-white);
  display: block;
  width: 58px;
}
span.title {
  color: #000d4a;
}
.box01 {
  position: relative;
  margin: 1em auto;
  padding: 25px 10px 7px;
  border: dotted 2px #000d4a60;
}
.box01 .box-title {
  position: absolute;
  display: inline-block;
  top: -1px;
  left: -1px;
  padding: 0 9px;
  height: 25px;
  line-height: 25px;
  font-size: 0.875rem;
  background: #000d4a60;
  color: var(--color-white);
  font-weight: normal;
}
.box01 p {
  font-size: 0.9rem;
  padding-top: 0.4rem;
}
.notes {
  font-size: 0.9rem;
  text-align: right;
  margin: 0.4rem auto 2rem;
  max-width: 900px;
}


.footer-wrap {
  width: 100%;
  background-color: #0f0e37;
  color: var(--color-white);
  text-align: center;
  /*margin-top: 40px;*/
  padding: 2rem 0 1rem;
}
p.mail a {
  display: inline;
  padding: 16px 0;
  color: var(--color-white);
  text-align: center;
  text-decoration: none;
  border: 0px;
  width: 40%;
  margin: 12px auto 30px;
}
p.mail img {
  display: inline;
  vertical-align: middle;
  padding-right: 10px;
  width: 35px;
}
p.mail {
  position: relative;
  display: inline;
  vertical-align: middle;
  padding-right: 10px;
  width: 35px;
}
p.mail .active {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  transition: 0.5s;
}
p.mail:hover .active {
  opacity: 1;
}
.ft-name {
  font-size: 1.125rem;
  line-height: 1.4;
  font-weight: bold;
  margin-bottom: 20px;
}
p.copyright {
  margin-top: 20px;
}
.mail a:hover {
  text-decoration: underline;
  color: #04bd08;
}
dd.right-block {
  color: var(--color-white);
  border-top: 1px solid #90a5e1;
}
dd.rightBlock_top {
  color: var(--color-white);
}
dd.right-block.darktext, dd.rightBlock_top.darktext {
  color: #000d4a80;
}

p.attention{
  color: #ffffff;
  font-size: var(--font-size-sm);
  text-align: right;
}

#page_top {
  width: 50px;
  height: 50px;
  position: fixed;
  right: -50px;
  bottom: 50px;
  background: var(--color-rightblue);
  border-radius: 50%;
}
#page_top a {
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  content: "\f102";
  font-size: 25px;
  color: var(--color-white);
  position: absolute;
  width: 25px;
  height: 25px;
  top: -15px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}

/*========= 各社ロゴ ===============*/

.brandlogo-wrap {
  width: 100%;
  background: var(--color-white);
  margin: 0 auto;
  padding: 3rem 1rem;
}
.brandlogo-wrap h2 {
  color: #121212;
  border-bottom: 1px solid var(--color-rightblue);
  padding: 0;
}
.brandlogo-wrap ul {
  display: flex;
  justify-content:center;
  margin: 2rem auto;
  flex-wrap: wrap;
}
.brandlogo-wrap li {
  width: 33.333%;
}

@media screen and (max-width: 768px) {
  .PCmain {
    display: none;
  }
  .SPmain {
    display: block;
  }
  .head-btn {
    position: static;
    top: 0;
    left: 0;
    transform: translateX(0);
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    width: 100%;
  }
  p.label {
    font-size: 1.1rem;
  }
  .greeting-wrap, .about-wrap, .program-wrap {
    padding: 1rem 10px;
    line-height: 1.4;
  }
  .program-list-box {
    width: 90%;
    justify-content: space-between;
    margin: 0 auto;
  }
  .program-list-box .guests-list {
    width: 50%;
    flex-wrap: wrap;
  }
  .program-list-box .guests-list img {
    width: 100%;
    height: 100%;
  }
  .guests-link-2 {
    max-width: 90%;
    width: 100%;
  }
  .sponsor .guests-link-2 {
    max-width: 80%;
    width: 100%;
  }
  .instructor-box {
    display: block;
    justify-content: center;
    padding: 20px 0 0;
  }
  .footer-wrap {
    font-size: 0.75rem;
  }
  .ft-name {
    font-size: 0.875rem;
    line-height: 1.2;
  }
  .program-list {
    font-size: 0.875rem;
  }
  .program-list dt {
    width: 25%;
  }
  .program-list dd {
    width: 75%;
  }
  .program-list dt.pt12p {
    padding-top: 4%;
  }
  .program-list dt.pt9p {
    padding-top: 4%;
  }
  .instructor-list.mr0 {
    margin-right: auto;
  }
  .instructor-list {
    margin: 10px auto 0;
    max-width: 95%;
  }
  .instructor-intro h3 {
    width: 80%;
  }
  .instructor-intro02 h3 {
    width: 80%;
  }
  .instructor-intro:first-of-type {
    padding: 20px 0;
  }
  .instructor-box.last {
    padding-top: 0;
    margin-top: 10px;
  }
  .instructor-list.last {
    margin: 0 auto 30px;
  }
  .instructor-intro02 {
    padding-top: 30px;
  }
  .instructor-box02 {
    padding: 0;
  }
}


@media screen and (max-width: 640px) {
  .guests-link-2 {
    width: 96%;
  }
  .program-list-box .guests-list img {
    width: 90%;
    height: 90%;
  }
  .greeting-wrap, .about-wrap, .program-wrap {
    padding: 1rem 10px;
    line-height: 1.4;
  }
  .btn-wrap {
    width: 90%;
    padding-bottom: 1rem;
  }
  .brandlogo-wrap ul {
    display: block;
  }
  .brandlogo-wrap li {
    width: 100%;
    margin-bottom: 3rem;
  }
.popup-wrap {
  display: block;
  padding: 1rem;
  border-bottom: 1px solid #CCCCCC50;
}
.popup-wrap div:nth-child(2) {
  padding-left: 1rem;
}
    .popup-wrap img{
        margin: 1rem auto;
    }
}

/*========= fadeUp ===============*/
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.bgappearTrigger, .fadeUpTrigger {
  opacity: 0;
}


@media screen and (min-width: 667px) {
  .sp_br {
    display: none;
  }
}


/*========= モーダル ===============*/
.hide-area {
  display: none;
}
.modaal-close:after, .modaal-close:before {
  background: #ccc;
}
.modaal-close:focus:after, .modaal-close:focus:before, .modaal-close:hover:after, .modaal-close:hover:before {
  background: #666;
}
#modaal-title {
  font-size: 1.2rem;
  text-align: center;
  margin: 0 0 20px 0;
}
.modaal-container {
  border: 5px solid #2dd36f;
  border-radius: 15px !important;
}
.bdr-blue {
  border: 5px solid var(--color-rightblue);
}

/*========= アコーディオン ===============*/
.box {
  display: none; 
}


/*footer-area///////////////////////////////////*/


.footer-area{
    position: sticky;
    position: -webkit-sticky;
    bottom:0;
    opacity: 0;
    transition: opacity 1s;
    z-index: 99999;
    background: rgba(182, 192, 199, 0.5);
    padding: 2rem 0 0;
}

.footer-area .day-anchor{
    background: #e0cdaa;
}

.btn-wrap .btn-conts li{
    margin: 0.5rem auto;
    text-align: center;
    width: 100%;
    max-width: 800px;
}

        .btn-wrap .entry-btn a{
                  background: #ffd43f;
                  text-align: center;
                  font-weight: bold;
                  display: block;
                  padding: 14px 0 12px;
                  font-size: 1.4rem;
                  text-decoration: none;
                  transition: 0.8s;
                  position: relative;
                  z-index: 1;
            }

             .btn-wrap .entry-btn a::before {
              content: "";
              width: 100%;
              height: 100%;
              position: absolute;
              top: 0;
              left: 0;
              z-index: -1;
              background: var(--color-rightblue);
              transform-origin: 50% 0%;
              transform: scaleY(0);
              transition: transform ease 0.3s;
            }
             .btn-wrap .entry-btn a:hover::before {
              transform-origin: 50% 100%;
              transform: scaleY(1);
            }





    .btn-conts .inquiries-btn{
        width: 300px;
        margin-top: 0.25rem;
        background: rgb(0,5,8);
        background: linear-gradient(159deg, rgba(255,255,255,1) 0%, rgba(198,198,198,1) 100%);
        padding: 0.25rem;
        border-radius: 50px;
    }

        .btn-wrap .inquiries-btn a{
              background: rgb(0,5,8);
              background: linear-gradient(159deg, rgba(198,198,198,0.98) 0%, rgba(255,255,255,0.98)  100%);
              padding: 0.5rem;
              border-radius: 50px;
              font-size: 1rem;
              font-weight: bold;
              color: #000;
       }


.btn-wrap .close{
  background: #ccc;
  border: #000;
  border-radius: 50px;
  padding: 0.5rem;
  font-size: 0.825rem;
}   
.btn-wrap .close.mainbtn{
    text-align: center;
    color: white;
    margin: 10px auto;
    width: 80%;
    padding: 1rem;
}

/* fadein */

/* リード下btn*/
.button a {
  background: #ffd43f;
  text-align: center;
  font-weight: bold;
  display: block;
  padding: 14px 0 12px;
  font-size: 1.4rem;
  text-decoration: none;
  transition: 0.8s;
  position: relative;
  z-index: 1;
}
.button a:hover {
  color: var(--color-white);
}
.button a::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: var(--color-rightblue);
  transform-origin: 50% 0%;
  transform: scaleY(0);
  transition: transform ease 0.3s;
}
.button a:hover::before {
  transform-origin: 50% 100%;
  transform: scaleY(1);
}
/*.button_top a {
  background: #ffd43f;
  text-align: center;
  display: block;
  padding: 10px 0;
  font-size: var(--font-size-lg);
  font-weight: bold;
  color: var(--color-white);
  text-decoration: none;
  transition: 0.8s;
  position: relative;
  z-index: 1;
}
.button_top a:hover {
  color: var(--color-white);
}
.button_top a::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: var(--color-rightblue);
  transform-origin: 50% 0%;
  transform: scaleY(0);
  transition: transform ease 0.3s;
}
.button_top a:hover::before {
  transform-origin: 50% 100%;
  transform: scaleY(1);
}*/
.mb20 {
  margin-bottom: 20px;
}
.btn-closed {
  background: #ccc;
  margin: 0 auto;
  padding: 16px;
  font-size: 1.2rem;
}
