@charset "UTF-8";

/*----------------------------------
  result
----------------------------------*/
.result {
  font-family: var(--font2);
}

.result-section__title {
  font-size: 36px;
  font-weight: 700;
  text-align: center;
}

.result-section__subtitle {
  color: var(--color02);
  font-size: 32px;
  font-weight: 700;
  text-align: center;
  padding-bottom: 0.37em;
  position: relative;
  line-height: 1.2;
}

.result-section__subtitle::after {
  background-color: var(--color02);
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  height: 3px;
  width: 2em;
}

/*----------------------------------
  lead
----------------------------------*/
.lead {
  margin-top: 100px;
}

/* title */
.title {
  max-width: 806px;
  margin-left: auto;
  margin-right: auto;
}

/* theme */
.theme {
  background-color: #fff;
  border: 3px solid var(--color02);
  border-radius: 25px;
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 120px;
  padding-top: 40px;
  padding-bottom: 40px;
  position: relative;
}

.theme-subtitle {
  position: absolute;
  top: 0;
  left: 50%;
  max-width: 608px;
  transform: translate(-50%, -45%);
  width: 100%;
}

.theme-title {
  font-size: 32px;
  font-weight: 700;
  text-align: center;
}

.theme-text {
  font-size: 36px;
  font-weight: 700;
  text-align: center;
  margin-top: 15px;
}

/*----------------------------------
  work
----------------------------------*/
.work {
  margin-top: 100px;
}

.work-award__items {
  display: flex;
  flex-wrap: wrap;
  margin-top: 50px;
}

.work-award__item {
  width: 31.166%;
}

.work-award__item:not(:nth-child(3n)) {
  margin-right: 3.25%;
}

.work-award__item:not(:nth-child(-n + 3)) {
  margin-top: 60px;
}

.work-award__cap {
  background-color: #fff;
  margin-top: 20px;
  padding: 20px;
}

.work-award__cap__title,
.work-award__cap__name {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  padding-left: 4em;
  text-indent: -4em;
}

.work-award__cap__label {
  color: var(--color02);
  font-weight: 700;
  margin-right: 1em;
}

.work-award__cap__text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  margin-top: 1em;
  text-align: justify;
}

/* work-award__excellence */
.work-award__excellence {
  margin-top: 28px;
}

.work-award__excellence .work-award__title {
  background-image: url(../images/result/deco-02.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center bottom;
  display: block;
  margin-left: auto;
  margin-right: auto;
  line-height: 1;
  padding-top: 1em;
  padding-left: 1.44em;
  padding-right: 1.44em;
  padding-bottom: 0.44em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.work-award__excellence .work-award__title::before {
  background-image: url(../images/result/deco-01.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center top;
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  height: 0.56em;
  width: 0.94em;
}

.work-award__excellence .result-section__subtitle::after {
  display: none;
}

.work-award__excellence .work-award__items {
  justify-content: center;
}

.work-award__excellence .work-award__item {
  width: 41.666%;
}

.work-award__excellence .work-award__item:not(:nth-child(3n)) {
  margin-right: 0;
}

/* work-award__grand */
.work-award__grand {
  margin-top: 80px;
}

/* work-modal */
.result .modal-wrap {
  max-width: 1000px;
  width: 73.206%;
}

.result .modal-inner {
  margin-left: auto;
  margin-right: auto;
  padding-top: 15px;
  padding-bottom: 15px;
  width: 75%;
}

.work-award__img {
  transition: opacity 0.3s;
}

.work-award__img:hover {
  opacity: 0.6;
}

.result .work-award__cap {
  margin-top: 10px;
  padding: 0;
}

.modal-item .work-award__cap__text {
  margin-top: 0;
}
/*----------------------------------
  info
----------------------------------*/
.info {
  margin-top: 120px;
}

.info-inner {
  background-color: #fff;
  border: 3px solid var(--color02);
  border-radius: 25px;
  margin-top: 40px;
  margin-left: auto;
  margin-right: auto;
  max-width: 960px;
  padding-top: 40px;
  padding-left: 50px;
  padding-right: 50px;
  padding-bottom: 40px;
}

.info-img {
  margin-top: 30px;
}

.info-img img {
  border-radius: 15px;
}

.info-text {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
}

.info-btn {
  margin-top: 46px;
  margin-left: auto;
  margin-right: auto;
  max-width: 300px;
}

.info-btn__link {
  align-items: center;
  display: flex;
  background-color: var(--color03);
  border: 3px solid var(--color03);
  border-radius: 50px;
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  justify-content: center;
  position: relative;
  height: 3.27em;
  transition: 0.2s;
  width: 100%;
}

.info-btn__link::after {
  background: #fff;
  -webkit-clip-path: polygon(0 0, 0 100%, 100% 50%);
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  content: "";
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  height: 20px;
  width: 16px;
}

.info-btn__link:hover {
  background-color: #fff;
  color: var(--color03);
}

.info-btn__link:hover::after {
  background: var(--color03);
}

/*----------------------------------
  calendar
----------------------------------*/
.calendar {
  max-width: 990px;
  margin-top: 100px;
  margin-left: auto;
  margin-right: auto;
}

.calendar-text {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 40px;
}

.calendar-text:not(:first-child) {
  margin-top: 1em;
}

.calendar-link {
  border-bottom: 2px solid var(--color02);
  color: var(--color02);
  font-weight: 500;
  line-height: 1.5;
  transition: 0.2s;
}

.calendar-link:hover {
  opacity: 0.8;
}

.calendar-img {
  margin-top: 40px;
}

/*----------------------------------
  sp
----------------------------------*/
@media not all and (min-width: 768px) {
  /* result */
  .result-section__title {
    font-size: 22px;
  }

  .result-section__subtitle {
    font-size: 20px;
    line-height: 1.6;
  }

  /* lead */
  .lead {
    margin-top: 50px;
  }

  /* title */
  .title {
    max-width: 345px;
  }

  /* theme */
  .theme {
    border-radius: 15px;
    max-width: none;
    margin-top: 50px;
    padding-top: 25px;
    padding-bottom: 25px;
  }

  .theme-subtitle {
    max-width: 332px;
  }

  .theme-title {
    font-size: 20px;
  }

  .theme-text {
    font-size: 22px;
    margin-top: 10px;
    line-height: 1.5;
  }

  /* work */
  .work {
    margin-top: 60px;
  }

  .work-award__items {
    display: block;
    margin-top: 35px;
  }

  .work-award__item {
    width: 100%;
  }

  .work-award__item:not(:nth-child(3n)) {
    margin-right: 0;
  }

  .work-award__item:not(:nth-child(-n + 3)) {
    margin-top: 40px;
  }

  .work-award__item:not(:first-child) {
    margin-top: 40px;
  }

  .work-award__cap {
    margin-top: 15px;
  }

  .work-award__cap__title,
  .work-award__cap__name {
    font-size: 14px;
  }

  .work-award__cap__text {
    font-size: 14px;
  }

  /* work-award__excellence */
  .work-award__excellence {
    margin-top: 16px;
  }

  .work-award__excellence .work-award__item {
    width: 100%;
  }

  /* work-award__grand */
  .work-award__grand {
    margin-top: 60px;
  }

  /* work-modal */
  .result .modal-wrap {
    width: 92%;
  }

  .result .modal-inner {
    padding-top: 40px;
    padding-bottom: 40px;
    width: 93.623%;
  }

  .result .work-award__cap {
    margin-top: 15px;
  }

  /* info */
  .info {
    margin-top: 60px;
  }

  .info-inner {
    border-radius: 15px;
    margin-top: 20px;
    max-width: none;
    padding-top: 35px;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 35px;
  }

  .info-img {
    margin-top: 20px;
  }

  .info-img img {
    border-radius: 10px;
  }

  .info-text {
    font-size: 14px;
  }

  .info-btn {
    margin-top: 30px;
  }

  .info-btn__link {
    font-size: 16px;
  }

  .info-btn__link::after {
    height: 15px;
    width: 12px;
  }

  /* calendar */
  .calendar {
    max-width: none;
    margin-top: 60px;
  }

  .calendar-text {
    font-size: 16px;
    font-weight: 500;
    margin-top: 20px;
  }

  .calendar-link {
    border-bottom: 1px solid var(--color02);
  }
}
