@charset "UTF-8";

/*--------------------------------
  トップページ
--------------------------------*/

/* ----- Main visual ----- */
.kv {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.kv__bg {
  overflow: hidden;
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.kv__bg-base {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 100%;
  min-width: 192rem;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

@media screen and (max-width: 768px) {
  .kv__bg-base {
    min-width: auto;
  }
}

.kv__bg-front-wrap {
  position: absolute;
  left: 50%;
  top: 0.5rem;
  transform: translateX(-50%);
  width: 100%;
  min-width: 192rem;
  height: 110.6rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .kv__bg-front-wrap {
    min-width: auto;
    height: 100%;
  }
}

.kv__bg-front {
  position: absolute;
  left: 0;
  top: -0.7rem;
  width: 100%;
  height: 103.2rem;
  object-fit: cover;
  object-position: 1% 0;
}

@media screen and (max-width: 768px) {
  .kv__bg-front {
    transform: translateX(-50%);
    width: 162%;
    height: 100%;
    margin-left: 50%;
    object-fit: contain;
    object-position: center center;
  }
}

.kv__hero {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  padding-top: 24.7rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .kv__hero {
    padding-top: 16rem;
    padding-inline: 1.6rem;
  }
}

.kv__catch {
  font-size: 3.2rem;
  letter-spacing: 0.1em;
  line-height: 4rem;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .kv__catch {
    font-size: 2rem;
    line-height: 1.3;
  }
}

.kv__title-wrap {
  margin-top: 6.7rem;
  padding-top: 3.2rem;
  border-top: 0.1rem solid var(--page-border);
}

@media screen and (max-width: 768px) {
  .kv__title-wrap {
    margin-top: 3.2rem;
    padding-top: 2rem;
  }
}

.kv__title {
  margin: 0;
  font-size: 9rem;
  font-weight: 400;
  line-height: 13.2rem;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 768px) {
  .kv__title {
    font-size: 4rem;
    line-height: 1.2;
  }
}

.kv__panel {
  position: relative;
  z-index: 1;
  margin: 18.7rem auto -13.1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4.9rem;
}

@media screen and (max-width: 768px) {
  .kv__panel {
    margin: 10rem auto -7rem;
    gap: 2.4rem;
    padding-inline: var(--page-container-padding);
  }
}

.kv__monthly-label {
  margin: 0;
  font-size: 4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .kv__monthly-label {
    font-size: 2rem;
  }
}

.kv__monthly-desc {
  margin: 0;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
  line-height: calc(40 / 24);
  text-align: center;
  margin-top: 3.6rem;
}

@media screen and (max-width: 768px) {
  .kv__monthly-desc {
    font-size: 1.4rem;
    line-height: 1.8;
    margin-top: 1.6rem;
  }
}

.kv__status {
  width: 100%;
  max-width: 99rem;
  padding-bottom: 2.5rem;
  background: #f5f5f2;
  border: 0.1rem solid var(--page-border);
  border-radius: 1rem;
  overflow: hidden;
  box-shadow: 0 0.3rem 0 0 #4E4E4E;
}

@media screen and (max-width: 768px) {
  .kv__status {
    max-width: 100%;
    padding-bottom: 1.6rem;
  }
}

.kv__status-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.8rem 2.4rem 1.3rem;
}

@media screen and (max-width: 768px) {
  .kv__status-head {
    padding: 1.2rem 1.4rem 1rem;
  }
}

.kv__accent {
  display: flex;
  gap: 1.1rem;
  mix-blend-mode: multiply;
}

@media screen and (max-width: 768px) {
  .kv__accent {
    gap: 0.4rem;
  }
}

.kv__accent--flip {
  transform: scaleX(-1);
}

.kv__accent span {
  display: block;
  width: 9.27rem;
  height: 0.57rem;
}

@media screen and (max-width: 768px) {
  .kv__accent span {
    width: 1.6rem;
    height: 0.3rem;
  }
}

.kv__accent span:nth-child(1) {
  background: #cfeaf5;
}

.kv__accent span:nth-child(2) {
  background: #f9d2d1;
}

.kv__accent span:nth-child(3) {
  background: #faf9d0;
}

.kv__status-title {
  margin: 0;
  font-size: 3.2rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .kv__status-title {
    font-size: 1.8rem;
  }
}

.kv__status-body {
  margin: 0;
  background: #fff;
  padding: 3rem 2.4rem 2.8rem;
  font-size: 2.4rem;
  line-height: calc(40 / 24);
  letter-spacing: 0.1em;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .kv__status-body {
    padding: 1.6rem 1.2rem;
    font-size: 1.2rem;
  }
}

/* ----- 3 cards ----- */
.quick-links {
  background: var(--page-bg);
  padding: 22.9rem 0 10.6rem;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 768px) {
  .quick-links {
    padding: 12rem var(--page-container-padding) 5.6rem;
  }
}

.quick-links__band {
  background: #fff;
  padding: 0;
}

.quick-links__inner {
  display: flex;
  justify-content: center;
  gap: 5rem;
  height: 13.6rem;
  background: #ffff;
}

@media screen and (max-width: 768px) {
  .quick-links__inner {
    flex-direction: column;
    gap: 1.6rem;
    height: auto;
    background: none;
  }
}

.quick-links__card {
  width: 36.3rem;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: -4.7rem 0;
  padding: 0.9rem 0 2.9rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .quick-links__card {
    width: 100%;
    gap: 1.6rem;
    margin: 0;
    padding: 2rem 1.2rem 2.4rem;
  }
}

/* 青 */
.quick-links__card--accent-blue {
  box-shadow: 0.8rem 0.8rem 0 var(--page-shadow-blue);
}

.quick-links__card--accent-blue .quick-links__more {
  background: #CCE0E8;
}

/* ピンク */
.quick-links__card--accent-pink {
  box-shadow: 0.8rem 0.8rem 0 var(--page-shadow-pink);
}

.quick-links__card--accent-pink .quick-links__more {
  background: #E9CBC7;
}

/* 黄 */
.quick-links__card--accent-yellow {
  box-shadow: 0.8rem 0.8rem 0 var(--page-shadow-yellow);
}

.quick-links__card--accent-yellow .quick-links__more {
  background: #F0EFC9;
}

.quick-links__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.7rem;
  padding: 0 0.5rem;
}

.quick-links__title {
  margin: 0;
  font-size: 3rem;
  letter-spacing: 0.3rem;
  line-height: 4rem;
}

@media screen and (max-width: 768px) {
  .quick-links__title {
    font-size: 2rem;
    line-height: 1.4;
    letter-spacing: 0.08rem;
  }
}

.quick-links__desc {
  margin: 0;
  font-size: 1.6rem;
  line-height: calc(24 / 16);
}

@media screen and (max-width: 768px) {
  .quick-links__desc {
    font-size: 1.2rem;
  }
}

.quick-links__more {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 9.6rem;
  min-height: 2.74rem;
  border-radius: 100em;
}

.quick-links__more img.quick-links__more-pill {
  position: absolute;
  inset: 0;
  width: 9.6rem;
  height: 2.74rem;
  object-fit: fill;
}

.quick-links__more-text {
  position: relative;
  z-index: 1;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.05em;
}

.quick-links__more-chevs {
  position: absolute;
  right: 0.6rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 0;
  z-index: 1;
  opacity: 0.85;
}

.quick-links__more-chevs img {
  width: 0.82rem;
  height: 0.87rem;
}

/* ----- About ----- */
.section-about {
  position: relative;
  z-index: 10;
  background: #fff;
  padding: 13.6rem var(--page-container-padding) 8.6rem;
  mix-blend-mode: multiply;
}

@media screen and (max-width: 768px) {
  .section-about {
    padding: 7rem var(--page-container-padding) 4.5rem;
  }
}

.section-about__decor {
  pointer-events: none;
  position: absolute;
  z-index: 10;
  top: 0;
  width: calc(1920 / 2 * 0.1rem);
  pointer-events: none;
  mix-blend-mode: multiply;
}

@media screen and (max-width: 768px) {
  .section-about__decor {
    z-index: -1;
    width: 60vw;
  }
}

.section-about__decor--left {
  right: 50%;
}

@media screen and (max-width: 768px) {
  .section-about__decor--left {
    top: 0;
    right: unset;
    left: 0;
  }
}

.section-about__decor--right {
  left: 50%;
}

@media screen and (max-width: 768px) {
  .section-about__decor--right {
    top: unset;
    bottom: 0;
    left: unset;
    right: 0;
  }
}

.section-about__inner {
  position: relative;
  z-index: 1;
  max-width: var(--page-container);
  margin: 0 auto;
  text-align: center;
}

.section-about__heading {
  font-size: 4rem;
  font-weight: 400;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .section-about__heading {
    font-size: 2.4rem;
    line-height: 1.4;
  }
}

.section-about__body {
  margin: 0;
  font-size: 2.2rem;
  line-height: 4rem;
  margin-top: 6.2rem;
}

@media screen and (max-width: 768px) {
  .section-about__body {
    font-size: 1.6rem;
    line-height: 1.9;
    margin-top: 2.8rem;
  }
}

.section-about__body em {
  font-style: italic;
}

/* ----- CTA ----- */
.apply-cta {
  position: relative;
  z-index: 1;
  text-align: center;
}

.apply-cta__head::before,
.apply-cta__head::after {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  right: 0;
  content: "";
  display: block;
  width: 100%;
  height: calc(100% - 2.5rem);
  background: #F5F5F2;
  mix-blend-mode: multiply;
}

.apply-cta__head::after {
  top: unset;
  bottom: 0;
}

.apply-cta__head {
  position: relative;
  padding: 8rem 0 7.95rem;
}

@media screen and (max-width: 768px) {
  .apply-cta__head {
    padding: 5rem 1.6rem 5.2rem;
  }
}

.apply-cta__lead {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: 3rem;
  line-height: 4.5rem;
}

@media screen and (max-width: 768px) {
  .apply-cta__lead {
    font-size: 2rem;
    line-height: 1.8;
  }
}

.apply-cta__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.2rem;
  margin: -3.8rem auto 0;
  position: relative;
  z-index: 2;
}

.apply-cta__button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40rem;
  height: 8.5rem;
  background: #fff;
  border-radius: 100em;
  border: solid 0.1rem #707070;
  box-shadow: 0 0.4rem 0 0 #707070;
}

@media screen and (max-width: 768px) {
  .apply-cta__button {
    width: 30rem;
    height: 6.8rem;
  }
}

.apply-cta__button-label {
  position: relative;
  z-index: 1;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
}

@media screen and (max-width: 768px) {
  .apply-cta__button-label {
    font-size: 2rem;
  }
}

.apply-cta__button-arrows {
  position: absolute;
  right: 3.6rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 2.12rem;
}

@media screen and (max-width: 768px) {
  .apply-cta__button-arrows {
    right: 1.6rem;
  }
}

.apply-cta__note {
  margin: 0;
  font-size: 2.2rem;
  line-height: 4rem;
}

@media screen and (max-width: 768px) {
  .apply-cta__note {
    font-size: 1.6rem;
    line-height: 1.9;
  }
}

/* ----- Rules box ----- */
.rules-section {
  max-width: var(--page-container);
  margin: 7.6rem auto 0;
}

@media screen and (max-width: 768px) {
  .rules-section {
    margin-top: 4.2rem;
    padding-inline: 1.6rem;
  }
}

.rules-section__box {
  border: 0.1rem solid var(--page-border);
  background: var(--page-bg);
  padding: 2rem;
  box-shadow: 0 0.4rem 0 0 #4E4E4E;
}

.rules-section__box-inner {
  padding: 5.3rem 3.5rem 4.9rem;
  background: #fff;
}

@media screen and (max-width: 768px) {
  .rules-section__box-inner {
    padding: 2.8rem 1.6rem;
  }
}

.rules-section__title {
  margin: 0 0 4.6rem;
  font-size: 4rem;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .rules-section__title {
    font-size: 2.8rem;
    margin-bottom: 2.4rem;
  }
}

.rules-section__text {
  margin: 0;
  font-size: 2rem;
  line-height: calc(29 / 20);
}

@media screen and (max-width: 768px) {
  .rules-section__text {
    font-size: 1.6rem;
    line-height: 1.8;
  }
}

.rules-section__text strong {
  font-weight: 500;
}

/* ----- X flow ----- */
.post-guide {
  padding: 5.6rem var(--page-container-padding) 8rem;
}

.post-guide__inner {
  max-width: var(--page-container);
  margin: 0 auto;
}

.post-guide__title {
  font-size: 2.8rem;
  text-align: center;
}

.post-guide__steps {
  display: flex;
  gap: 3.6rem;
  justify-content: center;
  margin-top: 3.1rem;
}

@media screen and (max-width: 768px) {
  .post-guide__steps {
    flex-direction: column;
  }
}

.post-guide__step {
  --stepColor: #ccc;
  flex: 1;
  display: flex;
  position: relative;
}

.post-guide__step-box {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: normal;
  border: 0.1rem solid var(--page-border);
  background: var(--page-bg);
  padding: 1.8rem 1.2rem 2rem;
  border-radius: 1rem;
  box-shadow: 0 0.4rem 0 0 #4E4E4E;
}

.post-guide__step-label {
  text-align: center;
  font-size: 2.2rem;
  line-height: calc(47 / 22);
  margin: 0 -1.2rem 1.4rem;
  background: var(--stepColor);
  border: solid 0 var(--page-border);
  border-width: 0.1rem 0;
}

.post-guide__step-text {
  font-size: 2rem;
  line-height: calc(29 / 20);
  text-align: center;
  margin: auto;
}

.post-guide__action {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 1.1rem 3rem 1.2rem 1.3rem;
  border-radius: 100em;
  background: #4E4E4E;
  margin: 1.4rem auto 0;
}

.post-guide__action-icon {
  flex-basis: 1.9rem;
}

.post-guide__action-text {
  font-size: 1.4rem;
  line-height: calc(20 / 14);
  color: #fff;
}

.post-guide__action:hover {
  opacity: 0.9;
}

.post-guide__note {
  font-size: 1.4rem;
  line-height: calc(20 / 14);
  text-align: center;
  margin: 1.4rem -0.5em 0;
}

.post-guide__connector {
  position: absolute;
  left: 100%;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 2.4rem 0 2.4rem 2.4rem;
  border-color: transparent transparent transparent var(--page-border);
}

@media screen and (max-width: 768px) {
  .post-guide__connector {
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 2.4rem 2.4rem 0 2.4rem;
    border-color: var(--page-border) transparent transparent transparent;
  }
}

.post-guide__step:last-child .post-guide__connector {
  display: none;
}

.post-guide__step:nth-child(1) {
  --stepColor: #CFEAF5;
}

.post-guide__step:nth-child(2) {
  --stepColor: #F9D2D1;
}

.post-guide__step:nth-child(3) {
  --stepColor: #FAF9D0;
}

/* ----- Examples ----- */
.sample-posts {
  padding: 3rem 0 6rem;
  background: var(--page-bg);
}

.sample-posts__head {
  text-align: center;
  margin-bottom: 2rem;
}

.sample-posts__title {
  font-size: 2.5rem;
  line-height: calc(59 / 25);
  text-align: center;
  width: 100%;
  margin: 0;
  background:
    #fff url("../images/top/sample-posts_head-bg_repeat.png") repeat-x center center / auto 100%;
}

.sample-posts__title-text {
  position: relative;
  display: inline-block;
  padding: 0 1.5rem;
  width: 100%;
  max-width: calc(62rem + (6.4rem * 2));
  background: #fff;
}

.sample-posts__title-text::before,
.sample-posts__title-text::after {
  position: absolute;
  top: 0;
  bottom: 0;
  content: "";
  display: inline-block;
  width: 50%;
  height: 100%;
  background: url("../images/top/sample-posts_head-bg_tip.png") no-repeat left center / auto 100%;
}

.sample-posts__title-text::before {
  left: 0;
}

.sample-posts__title-text::after {
  right: 0;
  transform: scaleX(-1);
}

.sample-posts__sub {
  text-align: center;
  font-size: 1.4rem;
  line-height: calc(20 / 14);
  margin: 2rem 0 0;
}

.sample-posts__grid {
  display: flex;
  gap: 2rem;
  margin: 4rem auto 0;
  max-width: var(--page-container);
  padding: 0 1rem;
  border-right: solid 0.1rem var(--page-border);
}

@media screen and (max-width: 768px) {
  .sample-posts__grid {
    flex-direction: column;
    gap: 1.2rem;
    border-right: 0;
    padding: 0 1.6rem;
  }
}

.sample-posts__col {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 1.6rem;
  background: #fff;
  padding: 2rem 1rem 3rem;
}

.sample-posts__col::before {
  position: absolute;
  top: 0;
  left: -1rem;
  content: "";
  display: block;
  width: 0.1rem;
  height: 100%;
  background: var(--page-border);
}

@media screen and (max-width: 768px) {
  .sample-posts__col::before {
    display: none;
  }
}

.sample-posts__term {
  font-weight: 500;
  font-size: 2rem;
  line-height: calc(29 / 20);
}

.sample-posts__def {
  font-size: 1.6rem;
  line-height: calc(23 / 16);
  text-align: center;
}

/* ----- Wide button ----- */
.archive-link-wrap {
  text-align: center;
  padding: 5rem var(--page-container-padding);
}

.archive-link-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40rem;
  height: 8.5rem;
  background: #fff;
  border-radius: 100em;
  border: solid 0.1rem #707070;
  box-shadow: 0 0.4rem 0 0 #707070;
}

@media screen and (max-width: 768px) {
  .archive-link-button {
    width: 30rem;
    height: 6.8rem;
  }
}

.archive-link-button-label {
  position: relative;
  z-index: 1;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
}

@media screen and (max-width: 768px) {
  .archive-link-button-label {
    font-size: 2rem;
  }
}

.archive-link-button-arrows {
  position: absolute;
  right: 3.6rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 2.12rem;
}

@media screen and (max-width: 768px) {
  .archive-link-button-arrows {
    right: 1.6rem;
  }
}

/* ----- Agreement ----- */
.terms-section {
  padding: 2rem 0;
  background: var(--page-bg);
  border: solid 0.1rem var(--page-border);
  box-shadow: 0 0.5rem 0 0 #4E4E4E;
}

.terms-section__inner {
  border: 0.1rem solid #ddd;
  padding: 0 var(--page-container-padding);
  background: #fff;
}

.terms-section__body {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: var(--page-container);
  margin: 0 auto;
  padding: 9.7rem 3.8rem 9.6rem;
}

@media screen and (max-width: 768px) {
  .terms-section__body {
    padding: 4.2rem 1.6rem;
  }
}

.terms-section__body::before,
.terms-section__body::after {
  pointer-events: none;
  position: absolute;
  left: 0;
  right: 0;
  content: "";
  display: block;
  height: 100%;
  background: url("../images/top/terms_bg.svg") no-repeat top center / 100% auto;
}

.terms-section__body::before {
  top: 0;
}

.terms-section__body::after {
  bottom: 0;
  transform: scaleY(-1);
}

.terms-section__title {
  text-align: center;
  font-size: 4rem;
  line-height: calc(58 / 40);
}

@media screen and (max-width: 768px) {
  .terms-section__title {
    font-size: 2.8rem;
    line-height: 1.4;
  }
}

.terms-section__list {
  margin-top: 3.1rem;
}

.terms-section__term {
  font-weight: 600;
  font-size: 2rem;
  line-height: calc(29 / 20);
}

.terms-section__term:not(:first-child) {
  margin-top: 4.7rem;
}

.terms-section__desc {
  margin: 1.6rem 0 0;
  font-size: 1.6rem;
  line-height: calc(23 / 16);
}

.terms-section__consent {
  display: flex;
  align-items: center;
  gap: 0.25em;
  margin: 4.3rem 0 0;
  font-size: 2rem;
  line-height: calc(29 / 20);
}

.terms-section__consent-input {
  display: none;
}

.terms-section__consent-check {
  position: relative;
}

.terms-section__consent-input:checked+.terms-section__consent-check::before {
  content: "✓";
  color: #000;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
}

.terms-section__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6rem;
  justify-content: center;
  margin-top: 5.6rem;
}

@media screen and (max-width: 768px) {
  .terms-section__actions {
    gap: 1.6rem;
    margin-top: 3rem;
  }
}

.terms-section__submit {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40rem;
  height: 8.5rem;
  background: #fff;
  border-radius: 100em;
  border: solid 0.1rem #707070;
  box-shadow: 0 0.4rem 0 0 #707070;
}

@media screen and (max-width: 768px) {
  .terms-section__submit {
    width: 30rem;
    height: 6.8rem;
  }
}

.terms-section__submit-label {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 0.8rem;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: 0.1rem;
}

@media screen and (max-width: 768px) {
  .terms-section__submit-label {
    font-size: 2rem;
  }
}

.terms-section__submit-label__icon {
  width: calc(1em / 25 * 30);
}

.terms-section__submit-arrows {
  position: absolute;
  right: 3.6rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 2.12rem;
}

@media screen and (max-width: 768px) {
  .terms-section__submit-arrows {
    right: 1.6rem;
  }
}

/* ----- Opus ----- */
.winners-section {
  position: relative;
  padding: 7rem var(--page-container-padding) 8.8rem;
  background: url("../images/top/archives_section-bg.jpg") repeat-x top center / 192rem auto;
}

@media screen and (max-width: 768px) {
  .winners-section {
    padding: 4.5rem 0 4.5rem;
  }
}

.winners-section__box {
  display: flex;
  flex-direction: column;
  max-width: var(--page-container);
  margin: 0 auto;
  padding: 2rem;
  background: var(--page-bg);
  border: 0.1rem solid var(--page-border);
}

@media screen and (max-width: 768px) {
  .winners-section__box {
    padding: 2rem 0;
    border-width: 0.1rem 0;
  }
}

.winners-section__box-inner {
  display: flex;
  flex-direction: column;
  background: #fff;
}

.winners-section__box-bg {
  width: 100%;
}

.winners-section__box-bg.--reverse {
  transform: scale(-1);
}

.winners-section__title {
  font-size: 4rem;
  line-height: calc(58 / 40);
  text-align: center;
  margin-top: 0.6rem;
}

@media screen and (max-width: 768px) {
  .winners-section__title {
    font-size: 2.4rem;
    line-height: 1.4;
  }
}

.winners-section__layout {
  display: flex;
  padding: 2.9rem 4.1rem 2.2rem;
}

@media screen and (max-width: 768px) {
  .winners-section__layout {
    flex-direction: column;
    padding: 2rem 0;
  }
}

.winners-section__tabs {
  flex-basis: 24rem;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  padding-top: 0.5rem;
}

@media screen and (max-width: 768px) {
  .winners-section__tabs {
    flex-basis: auto;
    flex-direction: row;
    overflow-x: auto;
    gap: 0.8rem;
    padding: 0 var(--page-container-padding);
    border-right: none;
    border-bottom: 0.1rem solid var(--page-border);
  }
}

.winners-section__tab {
  transition: transform 0.3s ease;
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  width: 18rem;
  height: 4rem;
  padding: 0 0 0 2.2rem;
  font-size: 1.8rem;
  line-height: 1;
  cursor: pointer;
  background: #FFFFFF;
  background-image: url("../images/top/archives_button-bg.svg");
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: left center;
  border: solid 0.1rem #707070;
  box-shadow: 0.2rem 0.2rem 0 #707070;
}

@media screen and (max-width: 768px) {
  .winners-section__tab {
    font-size: 1.4rem;
    width: 14rem;
    min-width: 14rem;
  }
}

.winners-section__tab::after {
  display: block;
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 2.6rem;
  height: 100%;
  background-image: url("../images/common/arrow-bluered_right.svg");
  background-repeat: no-repeat;
  background-size: 1.2rem auto;
  background-position: center;
}

.winners-section__tab.is-active {
  transform: translateX(1.4rem);
  background-image: url("../images/top/archives_button-bg_active.svg");
}

@media screen and (max-width: 768px) {
  .winners-section__tab.is-active {
    transform: unset;
  }
}

.winners-section__tab.is-active::after {
  background-image: url("../images/top/archives_button-bg_active.svg");
  background-size: auto 100%;
  background-position: left center;
  transform: scaleX(-1);
}

.winners-section__tab:hover {
  transform: translateX(1.4rem);
}

@media screen and (max-width: 768px) {
  .winners-section__tab:hover {
    transform: unset;
  }
}

.winners-section__panel {
  flex: 1;
  display: none;
}

@media screen and (max-width: 768px) {
  .winners-section__panel {
    padding: 3.6rem var(--page-container-padding);
  }
}

.winners-section__panel.is-active {
  display: block;
}

.winners-section__panel h3 {
  font-size: 3rem;
  line-height: calc(45 / 30);
  padding-bottom: 2.6rem;
  border-bottom: solid 0.1rem #707070;
}

@media screen and (max-width: 768px) {
  .winners-section__panel h3 {
    font-size: 2rem;
    line-height: 1.4;
  }
}

.winners-section__items {
  display: flex;
  flex-direction: column;
  gap: 3.5rem;
  margin: 2.6rem 0 6.4rem;
}

.winners-section__item {
  display: flex;
  align-items: flex-start;
}

.winners-section__badge {
  flex-basis: 7.2rem;
  font-size: 2.8rem;
  line-height: calc(45 / 28);
}

.winners-section__entry {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding-top: 0.3rem;
}

.winners-section__keyword {
  font-size: 2rem;
  line-height: calc(29 / 20);
}

.winners-section__description {
  font-size: 1.6rem;
  line-height: calc(23 / 16);
}

.winners-section__note,
.winners-section__ranking {
  margin-top: 2.4rem;
  font-size: 1.6rem;
  line-height: calc(23 / 16);
}

.winners-section__detail {
  font-size: 1.6rem;
  line-height: calc(23 / 16);
  text-align: center;
  margin-top: 3.2rem;
}

.winners-section__detail a {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.5em 0 0.5em 1em;
  border: solid var(--page-border);
  border-width: 0.1rem 0;
}

.winners-section__detail a::after {
  display: inline-block;
  content: "";
  vertical-align: bottom;
  width: 0.8em;
  height: 0.8em;
  background-image: url("../images/common/arrow-bluered_right.svg");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}