@charset "UTF-8";
/*色*/
/*背景画像*/
/*メディアクエリ*/
/*width*/
h1.sp-125 {
  font-size: clamp(2.1rem, 3vw, 2.6rem) !important;
  font-family: "Noto Serif JP", sans-serif !important;
  font-weight: 600;
  color: #001f6f;
  margin: initial !important;
  margin-bottom: 2rem !important;
}

.wrappernomal p {
  font-size: clamp(1.4rem, 3vw, 1.6rem) !important;
  font-family: 'Noto Serif JP', sans-serif;
  margin: initial !important;
  margin: 0 2rem !important;
}

#forum-body {
  width: 100%;
  padding: 2rem 0;
}

#forum-body .category {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  background-image: url(../img/gold-bg-001.jpg);
  margin: 0 2rem 3rem 2rem;
}

#forum-body .category .medal {
  position: relative;
  margin-left: 2rem;
  padding: 1rem 0;
}

#forum-body .category .medal img {
  width: 120px;
}

#forum-body .category .medal .medal-text {
  background: linear-gradient(122deg, black 0%, #0160ba 100%);
  padding: 0.8rem 0.5rem;
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 1.8rem;
  width: 100%;
  text-align: center;
  position: absolute;
  top: 40%;
  left: -5%;
}

#forum-body .category h2 {
  font-size: clamp(2.1rem, 3vw, 2.6rem);
  font-family: 'Noto Serif JP', sans-serif;
  background: linear-gradient(122deg, black 0%, #0160ba 100%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  margin: initial !important;
  margin-left: 2rem !important;
}

#forum-body .category h2 span {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
}

@media screen and (max-width: 480px) {
  #forum-body .category {
    margin: 0 0 3rem 0;
  }
  #forum-body .category .medal {
    margin-left: 1rem;
  }
  #forum-body .category .medal img {
    width: 80px;
  }
  #forum-body .category .medal .medal-text {
    font-size: 1.2rem;
    line-height: 1.2rem;
    top: 38%;
  }
  #forum-body .category h2 {
    font-size: 1.8rem;
  }
  #forum-body .category h2 span {
    font-size: 1.4rem;
  }
}

#forum-body .award-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 1rem 2rem;
  margin-bottom: 8rem;
  position: relative;
}

#forum-body .award-wrap::before {
  content: "";
  display: block;
  width: 4px;
  height: 100%;
  background-color: #001f6f;
  position: absolute;
  top: 0;
  left: 2rem;
}

#forum-body .award-wrap .award {
  margin-left: 2rem;
  margin-bottom: 5rem;
  position: relative;
}

#forum-body .award-wrap .award .tri {
  width: 15px;
  height: 15px;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background-color: #001f6f;
  position: absolute;
  top: 1rem;
  left: -2rem;
}

@media screen and (max-width: 480px) {
  #forum-body .award-wrap .award .tri {
    top: 0.5rem;
  }
}

#forum-body .award-wrap .award .year {
  font-size: clamp(1.6rem, 3vw, 2.1rem);
  font-family: 'Noto Serif JP', sans-serif;
  color: #001f6f;
  margin-bottom: 2rem;
}

#forum-body .award-wrap .award .year span {
  font-size: clamp(1.2rem, 3vw, 1.4rem);
}

@media screen and (max-width: 1000px) {
  #forum-body .award-wrap .award .year {
    left: 0;
  }
}

#forum-body .award-wrap .award .award-title {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
  margin-bottom: 1rem;
}

#forum-body .award-wrap .award .award-disc {
  font-size: clamp(1.2rem, 3vw, 1.4rem);
  font-weight: 600;
}

#forum-body .award-wrap .award .b-bottom {
  width: 100%;
  margin-top: 2rem;
  border-bottom: #001f6f solid 3px;
}

#forum-body .performance {
  margin-left: 2rem;
  margin-bottom: 3rem;
}

#forum-body .performance .perform-title {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 2rem;
}

#forum-body .performance .perform-title span {
  background: linear-gradient(90deg, #ab8c1f, #e6b422);
  color: #ffffff;
  padding: 0.5rem 1rem;
  margin-right: 1rem;
}

#forum-body .performance .perform-title h3 {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
  font-family: 'Noto Serif JP', sans-serif;
  font-weight: 600;
  color: #001f6f;
  margin: initial !important;
}

#forum-body .performance .perform-title h3 span {
  font-size: clamp(1.5rem, 3vw, 1.8rem);
  font-weight: 400;
  background: initial;
  color: #001f6f;
  padding: initial;
}

@media screen and (max-width: 480px) {
  #forum-body .performance .perform-title {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
  }
  #forum-body .performance .perform-title span {
    margin-bottom: 2rem;
  }
}

#forum-body .performance .performar {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
  font-family: 'Noto Serif JP', sans-serif;
  font-weight: 600;
  line-height: 2rem;
  border-bottom: #404040 solid 2px;
  margin-bottom: 2rem;
}

#forum-body .performance .performar span {
  font-size: clamp(1.2rem, 3vw, 1.4rem);
  font-weight: 600;
}

#forum-body .performance .perform {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#forum-body .performance .perform p {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-family: 'Noto Serif JP', sans-serif;
  margin: initial !important;
  padding: 2rem;
}

#forum-body .performance .perform img {
  width: 100%;
}

#forum-body .performance .perform .b-bottom {
  width: 100%;
  margin-top: 2rem;
  border-bottom: #001f6f solid 3px;
}

#forum-body .panel-wrap .panel-title {
  display: block;
  background-image: url(../img/gold-bg-001.jpg);
  padding: 2rem;
  margin-bottom: 0;
}

#forum-body .panel-wrap .panel-title h4 {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
  color: #001f6f;
  margin-bottom: 1rem !important;
  margin-left: 2rem !important;
}

#forum-body .panel-wrap .panel-title h2 {
  font-size: clamp(2.1rem, 3vw, 2.6rem);
  font-family: 'Noto Serif JP', sans-serif;
  background: linear-gradient(122deg, black 0%, #0160ba 100%);
  background-clip: text;
  -webkit-background-clip: text;
  color: transparent;
  margin: initial !important;
  margin-left: 2rem !important;
  margin-bottom: 3rem !important;
}

#forum-body .panel-wrap .panel-title h2 span {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
}

#forum-body .panel-wrap ul {
  display: flex;
  gap: 2rem;
  margin-bottom: initial !important;
}

#forum-body .panel-wrap ul li {
  color: #ffffff;
  font-weight: 600;
}

#forum-body .panel-wrap img {
  margin-bottom: 3rem;
}

#forum-body .panel-wrap p {
  font-family: 'Noto Serif JP', sans-serif;
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  color: #404040;
}

#forum-body .panel-wrap p span {
  font-family: initial;
  font-weight: 600;
}

/*マルシェ*/
#ac-marche {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  position: relative;
}

#ac-marche .deco-l {
  width: 100%;
  max-width: 35%;
  z-index: 10;
  position: absolute;
  top: 0;
  left: 0;
}

#ac-marche .deco-r {
  width: 100%;
  max-width: 35%;
  z-index: 10;
  position: absolute;
  top: 0;
  right: 0;
}

#ac-marche .marche-lead {
  font-size: clamp(1.6rem, 3vw, 1.8rem);
  font-weight: 600;
  line-height: clamp(2.8rem, 3vw, 3.2rem);
  text-align: center;
  padding-top: 8rem;
  margin-bottom: 5rem;
}

#ac-marche h2.marche-title {
  display: block;
  width: 80%;
  font-size: clamp(1.6rem, 3vw, 1.8rem);
  font-weight: 600;
  color: #ffffff;
  text-align: center;
  clip-path: polygon(0 0, 100% 0, 98% 50%, 100% 100%, 0 100%, 2% 50%);
  padding: 0.5rem 2rem;
  margin-bottom: 5rem !important;
}

#ac-marche h2.marche-title.orange {
  background-color: #ab8c1f;
}

#ac-marche h2.marche-title.green {
  background-color: #009d5f;
}

#ac-marche .booth {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 90%;
  padding-bottom: 3rem;
  margin-bottom: 5rem;
  border-bottom: #001f6f solid 3px;
}

#ac-marche .booth h3 {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
  font-weight: 600;
}

#ac-marche .booth h3.orange {
  color: #ab8c1f;
}

#ac-marche .booth h3.green {
  color: #009d5f;
}

#ac-marche .booth h5 {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
}

#ac-marche .booth .booth-cap {
  display: flex;
  width: 100%;
}

#ac-marche .booth .booth-cap p.caption {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  line-height: clamp(2.8rem, 3vw, 3.2rem);
  font-weight: 600;
  margin-bottom: 2rem;
}

#ac-marche .booth .booth-cap img {
  width: 100%;
  max-width: 15rem;
  object-fit: contain;
}

@media screen and (max-width: 780px) {
  #ac-marche .booth .booth-cap {
    flex-wrap: wrap;
  }
  #ac-marche .booth .booth-cap img {
    max-width: 60%;
    margin: 0 auto;
  }
}

#ac-marche .booth p.caption-mini {
  font-size: clamp(1rem, 3vw, 1.2rem);
  line-height: clamp(1.8rem, 3vw, 2rem);
  font-weight: 600;
  margin-bottom: 2rem;
}

#ac-marche .booth .booth-img {
  margin-bottom: 3rem;
  position: relative;
}

#ac-marche .booth .booth-img img {
  width: 100%;
}

#ac-marche .booth .booth-img .baloon {
  position: absolute;
  top: -5%;
  left: -5%;
  z-index: 30;
}

#ac-marche .booth .booth-img .baloon .baloon-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 22rem;
  height: 22rem;
  background-image: url(../img/fukidashi-001.svg);
  background-repeat: no-repeat;
  background-size: 100%;
}

#ac-marche .booth .booth-img .baloon .baloon-wrap p {
  font-size: clamp(1.2rem, 3vw, 1.6rem);
  text-align: center;
  margin: 0;
  padding: 0 2rem;
}

@media screen and (max-width: 480px) {
  #ac-marche .booth .booth-img .baloon .baloon-wrap {
    width: 18rem;
    height: 18rem;
  }
}

#ac-marche .booth .img-box {
  display: flex;
  flex-direction: row;
  justify-content: space-around;
  align-items: flex-end;
  gap: 1rem;
  width: 100%;
  overflow: hidden;
}

#ac-marche .booth .img-box img {
  max-height: 28rem;
}

@media screen and (max-width: 780px) {
  #ac-marche .booth .img-box img {
    max-height: 18rem;
  }
}

#ac-marche .booth .img-three {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: stretch;
  gap: 1rem;
}

#ac-marche .booth .img-three .left-img {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 50%;
}

#ac-marche .booth .img-three .left-img img {
  margin-bottom: 1rem;
}

#ac-marche .booth .img-three .right-img {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  width: 50%;
}

#ac-marche .booth .img-three .right-img img {
  margin-bottom: 1rem;
}

@media screen and (max-width: 1000px) {
  #ac-marche .booth .img-three {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  #ac-marche .booth .img-three .left-img {
    width: 90%;
  }
  #ac-marche .booth .img-three .right-img {
    width: 90%;
  }
}

#ac-marche .booth-waku {
  width: 90%;
  border: #ab8c1f solid 3px;
  border-radius: 10px;
  background-color: #fffcdb;
  padding: 15rem 1rem 3rem 1rem;
  margin-bottom: 8rem;
  position: relative;
}

#ac-marche .booth-waku .deco-circle {
  width: 100%;
  max-width: 23rem;
  height: 100%;
  max-height: 23rem;
  background-color: #ab8c1f;
  clip-path: circle(50% at 50% 50%);
  position: absolute;
  top: -5%;
  left: -3%;
}

#ac-marche .booth-waku .deco-circle .circle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 23rem;
  height: 100%;
  max-height: 23rem;
}

#ac-marche .booth-waku .deco-circle .circle .circle-text {
  font-size: clamp(1.2rem, 3vw, 1.8rem);
  line-height: clamp(3rem, 3vw, 3.2rem);
  font-weight: 600;
  text-align: center;
  color: #ffffff;
  border: #ffffff dotted 5px;
  border-radius: 50%;
  padding: 3.5rem;
  box-sizing: border-box;
  transform: rotate(-25deg);
}

@media screen and (max-width: 780px) {
  #ac-marche .booth-waku .deco-circle {
    width: 100%;
    max-width: 18rem;
    height: 100%;
    max-height: 18rem;
    top: -3%;
    left: -3%;
  }
  #ac-marche .booth-waku .deco-circle .circle {
    width: 100%;
    max-width: 18rem;
    height: 100%;
    max-height: 18rem;
  }
  #ac-marche .booth-waku .deco-circle .circle .circle-text {
    padding: 1.5rem;
  }
}

#ac-marche .booth-waku ul li {
  box-shadow: 0px 0px 8px -1px #e0e0e0;
  padding: 2rem;
}

#ac-marche .booth-waku ul li.waku-list {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 3rem;
  background-color: #ffffff;
  border-radius: 10px;
}

#ac-marche .booth-waku ul li.waku-list:nth-child(2n) {
  flex-direction: row-reverse;
}

#ac-marche .booth-waku ul li.waku-list .waku-img {
  width: 100%;
  max-width: 36rem;
  text-align: center;
}

#ac-marche .booth-waku ul li.waku-list .waku-img img {
  max-height: 28rem;
}

#ac-marche .booth-waku ul li.waku-list .waku-right {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  padding: 1rem 2rem;
}

#ac-marche .booth-waku ul li.waku-list .waku-right .waku-title {
  font-size: clamp(1.6rem, 3vw, 1.8rem);
  font-weight: 600;
  text-align: center;
}

@media screen and (max-width: 1000px) {
  #ac-marche .booth-waku ul li.waku-list {
    flex-direction: column;
  }
  #ac-marche .booth-waku ul li.waku-list:nth-child(2n) {
    flex-direction: column;
  }
  #ac-marche .booth-waku ul li.waku-list .waku-img {
    max-width: 100%;
    order: 2;
  }
  #ac-marche .booth-waku ul li.waku-list .waku-right {
    order: 1;
  }
}

/*アカデミックデイ*/
#ac-day {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#ac-day .day-section {
  width: 100%;
  padding-top: 2rem;
  position: relative;
}

#ac-day .day-section .day-title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background-image: url(../img/day-bg-001.jpg);
  background-repeat: repeat-x;
  border-radius: 0 25px 25px 0;
  padding: 1rem 4rem;
  margin-bottom: 5rem;
  width: 50%;
}

#ac-day .day-section .day-cont {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

#ac-day .day-section .day-cont .day-lead {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  margin: 0 2rem 5rem 2rem;
}

#ac-day .day-section .day-cont .day-lead p {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
  padding: 1rem;
}

#ac-day .day-section .day-cont .day-lead img {
  width: 55%;
}

@media screen and (max-width: 780px) {
  #ac-day .day-section .day-cont .day-lead {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  #ac-day .day-section .day-cont .day-lead img {
    width: 95%;
  }
}

#ac-day .day-section .day-cont .day-booth {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 90%;
  padding-bottom: 3rem;
  margin-bottom: 8rem;
  border-bottom: #001f6f solid 3px;
}

#ac-day .day-section .day-cont .day-booth h3 {
  font-size: clamp(1.8rem, 3vw, 2.1rem);
  font-weight: 600;
}

#ac-day .day-section .day-cont .day-booth h3.orange {
  color: #ab8c1f;
}

#ac-day .day-section .day-cont .day-booth h3.green {
  color: #009d5f;
}

#ac-day .day-section .day-cont .day-booth h5 {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
}

#ac-day .day-section .day-cont .day-booth .day-cap {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  gap: 1rem;
}

#ac-day .day-section .day-cont .day-booth .day-cap .caption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 45%;
  gap: 1rem;
}

#ac-day .day-section .day-cont .day-booth .day-cap .caption.wide {
  width: 100%;
  margin-bottom: 2rem;
}

#ac-day .day-section .day-cont .day-booth .day-cap .caption p {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  line-height: clamp(2.6rem, 3vw, 3rem);
  font-weight: 600;
  margin: initial !important;
}

#ac-day .day-section .day-cont .day-booth .day-cap .caption img {
  width: 100%;
  max-width: 100%;
  margin: initial;
  border-radius: 8px;
}

#ac-day .day-section .day-cont .day-booth .day-cap .cap-img {
  width: 55%;
}

#ac-day .day-section .day-cont .day-booth .day-cap .cap-img img {
  aspect-ratio: 4 / 3;
  border-radius: 8px;
}

@media screen and (max-width: 780px) {
  #ac-day .day-section .day-cont .day-booth .day-cap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  #ac-day .day-section .day-cont .day-booth .day-cap .caption {
    width: 100%;
  }
  #ac-day .day-section .day-cont .day-booth .day-cap .cap-img {
    width: 100%;
  }
}

#ac-day .day-section .day-cont .day-booth .day-single-img {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  overflow: hidden;
  margin-bottom: 3rem;
}

#ac-day .day-section .day-cont .day-booth .day-single-img img {
  width: 100%;
  border-radius: 8px;
}

#ac-day .day-section .day-cont .day-booth .day-duo-img {
  display: flex;
  flex-direction: row;
  justify-content: space-evenly;
  align-items: center;
  width: 100%;
  overflow: hidden;
  margin-bottom: 3rem;
}

#ac-day .day-section .day-cont .day-booth .day-duo-img img {
  height: 100%;
  max-height: 32rem;
}

@media screen and (max-width: 780px) {
  #ac-day .day-section .day-cont .day-booth .day-duo-img {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}

#ac-day .day-section .day-cont .b-bottom {
  width: 90%;
  margin-bottom: 5rem;
  border-bottom: #001f6f solid 3px;
}

#ac-day .day-section .day-other {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  margin-bottom: 5rem;
  position: relative;
}

#ac-day .day-section .day-other .other-title {
  background: #ff7f50;
  clip-path: polygon(5% 0, 100% 0, 95% 100%, 0% 100%);
  padding: 1rem 4rem;
  position: absolute;
  top: -1rem;
  transform: translate(0, -1rem);
  -webkit-transform: translate(0, -1rem);
}

#ac-day .day-section .day-other .other-title h4 {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
  color: #ffffff;
  margin: initial;
}

#ac-day .day-section .day-other .other-cont {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 90%;
  border: #ff7f50 solid 3px;
  border-radius: 25px;
  padding: 4rem 1rem;
}

/*下部リンク*/
.sp-link {
  box-sizing: border-box;
}

.sp-link h4 {
  font-size: clamp(1.4rem, 3vw, 1.6rem);
  font-weight: 600;
  color: #001f6f;
  margin-left: 2rem;
  margin-bottom: 1rem;
}

.sp-link .link-wrap {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
}

.sp-link .link-wrap .left-link {
  width: 50%;
  padding: 1rem;
}

.sp-link .link-wrap .left-link a img {
  width: 100%;
  max-width: 100%;
}

.sp-link .link-wrap .right-link {
  width: 50%;
  padding: 1rem;
}

.sp-link .link-wrap .right-link a img {
  width: 100%;
  max-width: 100%;
}

@media screen and (max-width: 780px) {
  .sp-link .link-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
  .sp-link .link-wrap .left-link {
    width: 95%;
  }
  .sp-link .link-wrap .right-link {
    width: 95%;
  }
}
