@charset "UTF-8";
body {
  font-family: "Noto Serif JP", serif;
}

em {
  font-style: normal;
}

.content__inner {
  max-width: none;
}

.event-name-inserted {
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  text-align: center;
}
.event-name-inserted .name {
  display: block;
  -webkit-text-stroke: 1px #000;
  color: #fff;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 3.125rem;
  font-weight: bold;
}
.event-name-inserted .explanation {
  display: inline-block;
  margin-top: 4px;
  white-space: nowrap;
  font-size: 1.1875rem;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
}

#fv {
  position: relative;
  padding: 0;
}
#fv .fv__inner {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  max-width: none;
  padding: 0;
  margin: 0;
}
#fv .logo {
  width: 33vw;
  margin-left: auto;
}
@media screen and (min-width: 769px) {
  #fv .logo {
    position: absolute;
    top: 8px;
    right: 8px;
    width: 11.94vw;
  }
}
#fv h1 {
  position: absolute;
  right: 8.06vw;
  bottom: 17.36vw;
  color: #fff;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
}
#fv h1 .target {
  font-size: 1.12vw;
}
#fv h1 .explanation {
  display: block;
  width: 19.17vw;
  margin-top: 3px;
  font-size: 1.39vw;
}
#fv h1 .name {
  display: block;
  width: 19.51vw;
  margin-top: 6px;
  -webkit-text-stroke: 0.5px #fff;
  color: transparent;
  font-size: 5.91vw;
  line-height: 1;
}
#fv .copy {
  width: 88.5vw;
  margin-left: auto;
  margin-right: auto;
  writing-mode: vertical-rl;
  color: #fff;
  font-size: 9.7vw;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #fv .copy {
    width: 37.5vw;
    margin-top: 12px;
    font-size: 4.12vw;
  }
}
#fv .copy em {
  color: #f0ff96;
  font-size: 12.36vw;
}
@media screen and (min-width: 769px) {
  #fv .copy em {
    font-size: 5.24vw;
  }
}
#fv .recommend {
  position: absolute;
  left: 3vw;
  bottom: 2.27vw;
  width: 74vw;
}
#fv .recommend img:not(:first-child) {
  margin-top: -16%;
  margin-left: 16%;
}

#intro {
  overflow: hidden;
  padding: 6px 8px;
}
@media screen and (min-width: 769px) {
  #intro {
    padding: 40px 36px;
  }
}
#intro .intro__inner {
  border: 1px solid #000;
}

#appeal {
  position: relative;
  z-index: 1;
}
#appeal h2 {
  margin-top: -2px;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
}
#appeal h2 span {
  display: block;
  width: -moz-max-content;
  width: max-content;
  margin-inline: auto;
}
#appeal h2 .name {
  background-color: #fff;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 4.5rem;
  font-weight: bold;
  text-shadow: 0 0 1px #000;
  color: #fff;
}
#appeal h2 .explanation {
  display: block;
  padding: 6px 10px;
  margin-top: 8px;
  background-image: linear-gradient(98deg, #0077a2 -5.5%, #000000 25%);
  color: #fff;
  font-size: 1.1875rem;
  font-weight: bold;
  line-height: 1;
}
#appeal h2 .explanation b {
  font-size: 1.6875rem;
  font-weight: 400;
}
#appeal h2 .target {
  margin-top: 12px;
  font-size: 0.71875rem;
}
#appeal h2 .target small {
  font-size: 0.46875rem;
}
#appeal .special-offers {
  display: flex;
  justify-content: center;
  gap: 9px;
  margin-top: 24px;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers {
    gap: 24px;
  }
}
#appeal .special-offers li {
  box-sizing: border-box;
  font-size: 0.9375rem;
  width: 10.1em;
  padding: 0.8em 0.5em;
  background-image: linear-gradient(349deg, #000000 68%, #0077a2 98%);
  aspect-ratio: 1/1;
  border-radius: 50%;
  list-style: none;
  text-align: center;
  color: #fff;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers li {
    font-size: 1.4125rem;
  }
}
#appeal .special-offers p {
  font-family: "Noto Serif JP", serif;
  font-size: 1.125rem;
  line-height: 1.3;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers p {
    font-size: 1.6875rem;
  }
}
#appeal .special-offers p em {
  color: #f0ff96;
}
#appeal .special-offers hr {
  position: relative;
  height: 12.5px;
  margin-top: 0.3em;
  background: none;
  border: none;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers hr {
    height: 18px;
  }
}
#appeal .special-offers hr::after {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  width: 45px;
  height: 100%;
  background-image: url('data:image/svg+xml;utf8,<svg width="13" height="13" viewBox="0 0 13 13" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M6.39589 0.851746L7.79376 5.15395L12.3174 5.15395L8.6577 7.81286L10.0556 12.1151L6.39589 9.45616L2.73621 12.1151L4.13409 7.81286L0.474411 5.15395L4.99802 5.15395L6.39589 0.851746Z" fill="white"/></svg>');
  background-size: 15px 100%;
  background-position: center;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers hr::after {
    width: 81px;
    background-size: 27px 100%;
  }
}
#appeal .special-offers .eligible {
  margin-top: 1em;
  font-size: 0.375rem;
}
@media screen and (min-width: 769px) {
  #appeal .special-offers .eligible {
    font-size: 0.5625rem;
  }
}
#appeal .recommend {
  position: absolute;
  top: 70px;
  right: 5vw;
  width: 27vw;
}
#appeal .recommend img:not(:first-child) {
  margin-top: -16%;
  margin-left: 16%;
}

@keyframes scrollTextLeft {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}
#about-us h2 {
  display: flex;
  gap: 0.2em;
  width: -moz-max-content;
  width: max-content;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 10.625rem;
  white-space: nowrap;
  -webkit-text-stroke: 0.5px #000;
  color: transparent;
  animation: scrollTextLeft 30s linear infinite;
}
@media screen and (min-width: 769px) {
  #about-us h2 {
    margin-inline: auto;
    text-align: center;
    font-size: 12.8125rem;
    animation: none;
  }
}
#about-us h2 span {
  width: 930px;
}
#about-us .explanation {
  box-sizing: border-box;
  max-width: 539px;
  padding-inline: 23px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 1.125rem;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #about-us .explanation {
    font-size: 1.5625rem;
  }
}
#about-us .explanation img {
  width: 83vw;
}

#voices {
  padding: 0;
  margin-inline: -1px;
}
#voices .voices {
  list-style: none;
}
#voices li {
  position: relative;
}
#voices li::before {
  content: "";
  position: absolute;
  top: -64px;
  right: -2px;
  width: 4px;
  height: 64px;
  background-color: #fff;
}
#voices li.--rev::before {
  right: auto;
  left: -2px;
}
#voices li.--rev .bio {
  flex-direction: row-reverse;
  padding: 12px 0 0 12px;
}
@media screen and (min-width: 769px) {
  #voices li.--rev .bio {
    padding: 40px 0 0 100px;
  }
}
#voices li.--rev .bio::before {
  left: auto;
  right: -2px;
}
#voices li.--rev .bio::after {
  left: auto;
  right: 0;
}
#voices li.--rev figure {
  margin-left: 0;
  margin-right: -9px;
}
@media screen and (min-width: 769px) {
  #voices li.--rev figure {
    margin-right: -37px;
  }
}
#voices li.--rev .profile {
  padding: 12px 0 0 6px;
}
#voices .bio {
  display: flex;
  align-items: center;
  gap: 24px;
  position: relative;
  padding: 12px 12px 0 0;
  border: 1px solid #000;
}
@media screen and (min-width: 769px) {
  #voices .bio {
    gap: 140px;
    padding: 40px 100px 0 0;
  }
}
#voices .bio::before {
  content: "";
  position: absolute;
  top: 0;
  left: -2px;
  width: 4px;
  height: calc(100% + 1px);
  background-color: #fff;
}
#voices .bio::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: calc(100% - 60px);
  height: 4px;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  #voices .bio::after {
    width: calc(100% - 180px);
  }
}
#voices figure {
  position: relative;
  z-index: 10;
  margin: 0;
  margin-left: -9px;
}
@media screen and (min-width: 769px) {
  #voices figure {
    margin-left: -37px;
  }
}
#voices .profile {
  padding: 12px 6px 0 0;
  writing-mode: vertical-rl;
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
}
#voices .profile h3 {
  display: inline-block;
  font-size: 2.1875rem;
  padding-block-end: 0.1em;
  margin-block-end: 0.1em;
  border-block-end: 1px solid #000;
}
@media screen and (min-width: 769px) {
  #voices .profile h3 {
    font-size: 4.5rem;
  }
}
#voices .profile p {
  font-size: 1rem;
  margin-top: -0.5em;
}
@media screen and (min-width: 769px) {
  #voices .profile p {
    font-size: 2.125rem;
  }
}
#voices .profile p .h {
  width: 2em;
  text-align: center;
  writing-mode: horizontal-tb;
  word-break: break-all;
  line-height: 1;
}
#voices .comment {
  position: relative;
  z-index: 1;
  padding-inline: 13px;
  margin-top: 20px;
  font-family: "Noto Serif JP", serif;
}
@media screen and (min-width: 769px) {
  #voices .comment {
    padding-inline: 36px;
    margin-top: 46px;
  }
}
#voices .comment::before {
  content: "";
  position: absolute;
  top: -20px;
  left: -2px;
  z-index: -1;
  width: calc(100% + 4px);
  height: 32px;
  background-color: #fff;
}
@media screen and (min-width: 769px) {
  #voices .comment::before {
    top: -46px;
    height: 90px;
  }
}
#voices .comment .summary {
  font-size: 1.375rem;
  font-weight: 900;
  background: linear-gradient(278deg, #000000 60%, #0077a2 90%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media screen and (min-width: 769px) {
  #voices .comment .summary {
    font-size: 2.75rem;
  }
}
#voices .comment .detail {
  margin-top: 10px;
  font-size: 0.875rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #voices .comment .detail {
    font-size: 1.125rem;
  }
}
#voices .comment .detail p:not(:first-child) {
  margin-block-start: 1em;
}
#voices .comment .detail p em {
  display: inline-block;
  color: #08506b;
  vertical-align: bottom;
}
#voices .comment .detail p .emphasize {
  font-size: 0.9375rem;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  #voices .comment .detail p .emphasize {
    font-size: 1.3125rem;
  }
}
#voices .view-more-button {
  padding-left: 2.5em;
  margin-top: 50px;
  border: none;
  color: #000;
  font-family: "Noto Serif JP", serif;
  font-size: 1rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #voices .view-more-button {
    margin-top: 60px;
  }
}
#voices .view-more-button::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  translate: 0 -50%;
  box-sizing: border-box;
  width: 1.7em;
  height: 1.7em;
  border: 1px solid #000;
  border-radius: 50%;
}
#voices .view-more-button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.85em;
  translate: -50% -50%;
  transform: none;
  width: 0.85em;
  height: 0.85em;
  border: none;
  background-image: linear-gradient(to right, transparent calc(50% - 0.5px), #000 calc(50% - 0.5px), #000 calc(50% + 0.5px), transparent calc(50% + 0.5px)), linear-gradient(to bottom, transparent calc(50% - 0.5px), #000 calc(50% - 0.5px), #000 calc(50% + 0.5px), transparent calc(50% + 0.5px));
}
#voices .view-more-button.show::after {
  background-image: linear-gradient(to bottom, transparent calc(50% - 0.5px), #000 calc(50% - 0.5px), #000 calc(50% + 0.5px), transparent calc(50% + 0.5px));
}
#voices .read-more {
  justify-content: center;
  align-items: center;
  position: relative;
  box-sizing: border-box;
  height: auto;
  padding: 19px;
  margin: 50px 24px 0;
  background: linear-gradient(355deg, #000000 32%, #0077a2 97%);
  border: 1px solid;
  -o-border-image: linear-gradient(355deg, #000000 32%, #0077a2 97%) 1;
     border-image: linear-gradient(355deg, #000000 32%, #0077a2 97%) 1;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 0.9375rem;
  font-weight: bold;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: #000;
}
@media screen and (min-width: 769px) {
  #voices .read-more {
    max-width: 30em;
    margin: 60px auto 0;
    font-size: 1.125rem;
  }
}
#voices .read-more__deco {
  width: 2.2rem;
  height: 2.2rem;
  border: 0.5rem solid #cde0e7;
  border-radius: 50%;
  position: relative;
  background: linear-gradient(355deg, #000000 32%, #0077a2 97%);
}
#voices .read-more__deco::before {
  width: 0.3333rem;
  height: 0.3333rem;
  border-radius: 50%;
  content: "";
  display: block;
  position: absolute;
  top: calc(50% - 0.1666rem);
  left: calc(50% - 0.1666rem);
  background: #fff;
  transition: scale 0s cubic-bezier(0.39, 0.575, 0.565, 1), opacity 0.4s 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
#voices .read-more__deco::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 0.8rem;
  height: 0.75rem;
  background: url('data:image/svg+xml;utf8,<svg width="14" height="13" viewBox="0 0 14 13" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M0 7.41753H10.3149L6.18411 11.5483L7.5453 12.9095L14 6.45474L7.5453 0L6.18411 1.36119L10.3149 5.49194H0V7.41753Z" fill="white"/></svg>') center/contain no-repeat;
  translate: 0.7rem 0;
  opacity: 0;
  transition: translate 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}
@media screen and (max-width: 768px) {
  #voices .read-more__deco::before {
    scale: 10;
    opacity: 0;
    transition: scale 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.6s 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  #voices .read-more__deco::after {
    translate: 0;
    opacity: 1;
    transition: translate 0s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
}
#voices .read-more:hover .read-more__deco::before {
  scale: 10;
  opacity: 0;
  transition: scale 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.6s 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#voices .read-more:hover .read-more__deco::after {
  translate: 0;
  opacity: 1;
  transition: translate 0s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
}
#voices .about-above {
  position: relative;
  display: block;
  box-sizing: border-box;
  padding-inline: 30px;
  margin: 14px 20px 60px;
  text-decoration: none;
  color: #08506b;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #voices .about-above {
    display: flex;
    align-items: center;
    gap: 18px;
    max-width: 30em;
    margin-inline: auto;
    font-size: 1.125rem;
  }
}
#voices .about-above::before {
  content: "";
  position: absolute;
  bottom: 0.5em;
  left: 0;
  transform-origin: left bottom;
  transform: rotate(15deg);
  width: 1px;
  height: 100%;
  background-color: #08506b;
}
#voices .about-above::after {
  content: "";
  position: absolute;
  bottom: 0.5em;
  right: 0;
  transform-origin: right bottom;
  transform: rotate(-15deg);
  width: 1px;
  height: 100%;
  background-color: #08506b;
}
#voices .about-above .key {
  text-decoration: underline;
  font-size: 0.75rem;
}
@media screen and (min-width: 769px) {
  #voices .about-above .key {
    font-size: 0.9375rem;
  }
}
#voices .about-above .val {
  font-size: 0.875rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #voices .about-above .val {
    flex: 1;
    font-size: 1rem;
  }
}

.cta {
  padding: 15px 10px 22px;
  background: linear-gradient(180deg, #f6ffb8 0%, #c0c790 100%);
}
.cta p {
  position: relative;
  width: -moz-max-content;
  width: max-content;
  padding-inline: 1.4em;
  margin-inline: auto;
  background-image: linear-gradient(355deg, #000000 32%, #0077a2 97%);
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  text-align: center;
  font-size: 0.9375rem;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .cta p {
    padding-inline: 1.9em;
    font-size: 1.375rem;
  }
}
.cta p::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  translate: 0 -50%;
  height: 0.9em;
  width: 1.2em;
  background: url(../images/event-6812_internship-for-27-alumni/cta_deco.svg) left bottom/contain no-repeat;
}
.cta p::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  translate: 0 -50%;
  height: 0.9em;
  width: 1.2em;
  background: url(../images/event-6812_internship-for-27-alumni/cta_deco.svg) right bottom/contain no-repeat;
}
.cta a {
  display: block;
  max-width: 550px;
  padding: 13px 13px 15px;
  margin-top: 12px;
  margin-inline: auto;
  border-radius: 100px;
  background-image: linear-gradient(355deg, #000000 32%, #0077a2 97%);
  box-shadow: 0px 10px 0px 0px rgba(0, 0, 0, 0.2509803922);
  text-align: center;
  color: #fff;
  text-decoration: none;
  font-family: "Roboto", sans-serif;
  font-size: 1.0625rem;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .cta a {
    font-size: 1.25rem;
  }
}

.bg {
  background: url(../images/event-6812_internship-for-27-alumni/bg.svg) top left/cover, linear-gradient(179.13deg, #0077a2 -1.6%, #000000 5%);
  color: #fff;
}
@media screen and (min-width: 769px) {
  .bg {
    background: url(../images/event-6812_internship-for-27-alumni/bg-pc.svg) top left/cover, linear-gradient(179.13deg, #0077a2 -1.6%, #000000 5%);
  }
}

#concept {
  padding-bottom: 30px;
}
#concept h2 {
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  text-align: center;
}
#concept h2 .name {
  display: block;
  font-size: 6rem;
  font-weight: 900;
  line-height: 1;
}
#concept h2 .explanation {
  display: inline-block;
  max-width: 236px;
}
#concept h2 .en {
  display: block;
  font-size: 5.3125rem;
  font-weight: bold;
  line-height: 1;
}
#concept h2 .ja {
  display: block;
  margin-top: -0.4em;
  font-size: 0.6875rem;
  font-weight: bold;
}
#concept .copy {
  max-width: 313px;
  margin-top: 8px;
  margin-inline: auto;
}
@media screen and (min-width: 769px) {
  #concept .copy {
    max-width: 470px;
    margin-top: 40px;
  }
}
#concept .message {
  padding-bottom: 70px;
  margin-top: 14px;
}
@media screen and (min-width: 769px) {
  #concept .message {
    translate: 5% 0;
    width: -moz-fit-content;
    width: fit-content;
    padding-bottom: 124px;
    margin-top: 60px;
    margin-inline: auto;
  }
}
#concept .message p {
  font-size: 0.9375rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #concept .message p {
    font-size: 1.25rem;
  }
}
#concept .message p:not(:first-child) {
  margin-top: 1.5em;
}
#concept .message p em {
  font-size: 1.3125rem;
}
@media screen and (min-width: 769px) {
  #concept .message p em {
    font-size: 1.75rem;
  }
}

#why {
  position: relative;
  padding: 80px 8px 34px;
  background-color: #fff;
  color: #000;
}
@media screen and (min-width: 769px) {
  #why {
    padding: 90px 30px 60px;
  }
}
#why h2 {
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  box-sizing: border-box;
  width: calc(100% - 48px);
  padding: 17px 17px 23px;
  margin-inline: auto;
  background-color: #000;
  border: 1px solid #fff;
  text-align: center;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  #why h2 {
    max-width: calc(100% - 60px);
    width: -moz-max-content;
    width: max-content;
    padding: 20px 60px;
    font-size: 2rem;
  }
}
#why .summary {
  padding-inline: 16px;
  font-size: 1rem;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #why .summary {
    text-align: center;
    font-size: 1.25rem;
    line-height: 1.8;
  }
}
#why .detail {
  padding: 45px 15px 34px;
  margin-top: 24px;
  background-image: linear-gradient(337deg, #000000 70%, #0077a2 98%);
  color: #fff;
}
@media screen and (min-width: 769px) {
  #why .detail {
    padding: 64px 80px 60px;
  }
}
#why .detail ol {
  counter-reset: listnum;
}
@media screen and (min-width: 769px) {
  #why .detail ol {
    display: flex;
    gap: 32px;
  }
}
#why .detail li {
  position: relative;
  list-style: none;
  padding: 44px 22px 32px;
  border: 1px solid #fff;
}
@media screen and (min-width: 769px) {
  #why .detail li {
    flex: 1;
    padding: 72px 42px 24px;
  }
}
#why .detail li:not(:first-child) {
  margin-top: 40px;
}
@media screen and (min-width: 769px) {
  #why .detail li:not(:first-child) {
    margin: 0;
  }
}
#why .detail li::before {
  counter-increment: listnum;
  content: counter(listnum);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  width: 52px;
  height: 52px;
  background-color: #fff;
  border-radius: 50%;
  text-align: center;
  color: #000;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 1.875rem;
}
#why .detail h3 {
  position: relative;
  padding-bottom: 16px;
  text-align: center;
  color: #f0ff96;
  font-size: 1.3125rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #why .detail h3 {
    font-size: 1.5rem;
    line-height: 1.3;
  }
}
#why .detail h3::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-image: linear-gradient(to right, #f0ff96 calc(50% - 8px), transparent calc(50% - 8px), transparent calc(50% + 8px), #f0ff96 calc(50% + 8px));
}
#why .detail h3::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 50%;
  transform-origin: top right;
  transform: translate(2px, 100%) rotate(36deg);
  width: 2px;
  height: 13px;
  background-color: #f0ff96;
}
#why .detail p {
  margin-top: 28px;
  font-size: 0.9375rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #why .detail p {
    font-size: 1.1875rem;
  }
}
#why .visualized-conditions {
  margin-top: 46px;
  margin-left: -17px;
}
@media screen and (min-width: 769px) {
  #why .visualized-conditions {
    margin-top: 52px;
    margin-left: -40px;
  }
}
#why .explanations {
  margin-top: 36px;
}
@media screen and (min-width: 769px) {
  #why .explanations {
    margin-top: 60px;
  }
}
#why .conclusion {
  padding-inline: 16px;
  margin-top: 26px;
}
@media screen and (min-width: 769px) {
  #why .conclusion {
    margin-top: 45px;
  }
}
#why .conclusion p {
  font-size: 0.9375rem;
}
@media screen and (min-width: 769px) {
  #why .conclusion p {
    text-align: center;
    font-size: 1.25rem;
  }
}
#why .conclusion p:not(:first-child) {
  margin-top: 1.5em;
}
#why .conclusion p em {
  color: #08506b;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #why .conclusion p em {
    font-size: 1.375rem;
  }
}

#about-president {
  padding: 30px 32px 38px;
}
@media screen and (min-width: 769px) {
  #about-president {
    padding: 45px 126px 86px;
  }
}
@media screen and (min-width: 769px) {
  #about-president .about-president__inner {
    display: flex;
    gap: 46px;
  }
}
#about-president .bio {
  display: flex;
  gap: 40px;
  margin-right: -32px;
}
@media screen and (min-width: 769px) {
  #about-president .bio {
    flex: 1;
    justify-content: space-between;
    margin-right: 0;
  }
}
#about-president .profile {
  writing-mode: vertical-rl;
}
#about-president .jobtitle {
  font-size: 1.375rem;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #about-president .jobtitle {
    font-size: 2.125rem;
  }
}
#about-president .name {
  display: inline-block;
  padding-right: 10px;
  margin-right: 10px;
  border-right: 1px solid #fff;
  font-size: 2.75rem;
}
@media screen and (min-width: 769px) {
  #about-president .name {
    font-size: 4.5rem;
  }
}
#about-president figure {
  margin: 0;
}
@media screen and (min-width: 769px) {
  #about-president figure {
    max-width: 175px;
  }
}
#about-president .introduce {
  margin-top: 32px;
}
@media screen and (min-width: 769px) {
  #about-president .introduce {
    width: 50%;
    margin: 0;
  }
}
#about-president .introduce p {
  font-size: 0.9375rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #about-president .introduce p {
    font-size: 1.125rem;
  }
}
#about-president .introduce p:not(:first-child) {
  margin-top: 0.7em;
}

#conditions {
  overflow: hidden;
  padding: 72px 30px 112px;
}
@media screen and (min-width: 769px) {
  #conditions {
    padding-top: 144px;
  }
}

#do-not-expect {
  position: relative;
  padding-top: 54px;
  border: 2px solid #fff;
  -o-border-image: linear-gradient(to right, #fff calc(50% - 36px), transparent calc(50% - 36px), transparent calc(50% + 36px), #fff calc(50% + 36px)) 2;
     border-image: linear-gradient(to right, #fff calc(50% - 36px), transparent calc(50% - 36px), transparent calc(50% + 36px), #fff calc(50% + 36px)) 2;
}
@media screen and (min-width: 769px) {
  #do-not-expect {
    padding: 72px 56px 56px;
    border-image-source: linear-gradient(to right, #fff calc(50% - 150px), transparent calc(50% - 150px), transparent calc(50% + 150px), #fff calc(50% + 150px));
  }
}
#do-not-expect::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% -50%;
  transform: rotate(45deg);
  width: 78px;
  height: 78px;
  background-image: linear-gradient(to bottom, transparent calc(50% - 1px), #fff calc(50% - 1px), #fff calc(50% + 1px), transparent calc(50% + 1px)), linear-gradient(to right, transparent calc(50% - 1px), #fff calc(50% - 1px), #fff calc(50% + 1px), transparent calc(50% + 1px));
}
@media screen and (min-width: 769px) {
  #do-not-expect::before {
    width: 105px;
    height: 105px;
  }
}
#do-not-expect::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
}
#do-not-expect h2 {
  padding-inline: 12px;
  text-align: center;
  font-size: 1.3125rem;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #do-not-expect h2 {
    font-size: 2.125rem;
  }
}
#do-not-expect p {
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 12px;
  margin-top: 14px;
  margin-inline: auto;
  font-size: 0.875rem;
  font-weight: 900;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #do-not-expect p {
    font-size: 1.125rem;
  }
}
#do-not-expect .not-intended {
  margin-top: 25px;
}
@media screen and (min-width: 769px) {
  #do-not-expect .not-intended .item:not(:first-child) {
    margin-top: 28px;
  }
}
#do-not-expect .not-intended dt {
  display: flex;
  align-items: center;
  gap: 8px;
  box-sizing: border-box;
  min-height: calc(3em + 16px);
  padding: 8px;
  background-color: #08506b;
  font-size: 1.125rem;
  line-height: 1.5;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #do-not-expect .not-intended dt {
    min-height: 0;
    padding: 14px;
    padding-left: 40px;
    font-size: 1.375rem;
  }
}
#do-not-expect .not-intended dt::before {
  content: "";
  width: 25px;
  height: 25px;
  transform: rotate(45deg);
  background-image: linear-gradient(to bottom, transparent calc(50% - 1px), #fff calc(50% - 1px), #fff calc(50% + 1px), transparent calc(50% + 1px)), linear-gradient(to right, transparent calc(50% - 1px), #fff calc(50% - 1px), #fff calc(50% + 1px), transparent calc(50% + 1px));
}
@media screen and (min-width: 769px) {
  #do-not-expect .not-intended dt::before {
    width: 32px;
    height: 32px;
  }
}
#do-not-expect .not-intended dt .inner {
  flex: 1;
}
#do-not-expect .not-intended dd {
  padding: 14px 20px;
  background-color: #fff;
  color: #000;
  font-size: 0.9375rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #do-not-expect .not-intended dd {
    padding: 17px 29px 27px 41px;
    font-size: 1.125rem;
  }
}
#do-not-expect .not-intended dd em {
  color: #08506b;
  font-weight: 600;
  font-size: 1rem;
}
@media screen and (min-width: 769px) {
  #do-not-expect .not-intended dd em {
    font-size: 1.25rem;
    font-weight: bold;
  }
}

#target {
  position: relative;
  margin-top: 190px;
  color: #f0ff96;
}
@media screen and (min-width: 769px) {
  #target {
    margin-top: 296px;
  }
}
#target .illust {
  position: absolute;
  top: -56px;
  left: calc(50% + 10px);
  translate: -50% -50%;
  width: 375px;
  height: 124px;
  background: url(../images/event-6812_internship-for-27-alumni/target_illust.svg) center/contain no-repeat;
}
@media screen and (min-width: 769px) {
  #target .illust {
    top: -94px;
    width: 633px;
    height: 210px;
  }
}
#target h2 {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding-bottom: 24px;
  margin-inline: auto;
  text-align: center;
  color: #f0ff96;
  font-size: 1.3125rem;
  font-weight: 900;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #target h2 {
    font-size: 2.125rem;
    line-height: 1.3;
  }
}
#target h2::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-image: linear-gradient(to right, #f0ff96 calc(50% - 8px), transparent calc(50% - 8px), transparent calc(50% + 8px), #f0ff96 calc(50% + 8px));
}
#target h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 50%;
  transform-origin: top right;
  transform: translate(2px, 100%) rotate(36deg);
  width: 2px;
  height: 13px;
  background-color: #f0ff96;
}
#target .message {
  max-width: 968px;
  margin-top: 32px;
}
@media screen and (min-width: 769px) {
  #target .message {
    margin-inline: auto;
  }
}
#target .message p {
  text-align: center;
  font-size: 1rem;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #target .message p {
    font-size: 1.3125rem;
    line-height: 1.8;
  }
}
#target .message p:not(:first-child) {
  margin-top: 1.7em;
}

#special-offers {
  position: relative;
  padding: 67px 8px 42px;
  background-color: #fff;
  color: #000;
}
@media screen and (min-width: 769px) {
  #special-offers {
    padding: 66px 72px 95px;
  }
}
#special-offers .special-offers__inner {
  padding: 24px 22px 40px;
  border: 2px solid #000;
}
@media screen and (min-width: 769px) {
  #special-offers .special-offers__inner {
    padding: 42px 54px;
  }
}
#special-offers h2 {
  padding: 2px 4px 4px;
  background-color: #000;
  text-align: center;
  color: #fff;
  font-size: 1.25rem;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #special-offers h2 {
    font-size: 1.875rem;
  }
}
#special-offers dl .item {
  border: 2px solid #000;
}
#special-offers dl .item:not(:first-child) {
  margin-top: 20px;
}
#special-offers dt {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  padding: 12px 15px;
  border-bottom: 2px solid #000;
  font-size: 1.25rem;
  line-height: 1.4;
  font-weight: 900;
}
@media screen and (min-width: 769px) {
  #special-offers dt {
    gap: 16px;
    font-size: 1.75rem;
  }
}
#special-offers dt::before {
  content: "";
  display: block;
  width: 1.8em;
  height: 2.4em;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
@media screen and (min-width: 769px) {
  #special-offers dt::before {
    width: 1.3em;
    height: 1.7em;
  }
}
#special-offers dt.icon-1::before {
  background-image: url(../images/event-6812_internship-for-27-alumni/special-offers_icon-1.png);
}
#special-offers dt.icon-2::before {
  background-image: url(../images/event-6812_internship-for-27-alumni/special-offers_icon-2.png);
}
#special-offers dt.icon-3::before {
  background-image: url(../images/event-6812_internship-for-27-alumni/special-offers_icon-3.png);
}
#special-offers dd {
  padding: 8px 13px 14px;
}
@media screen and (min-width: 769px) {
  #special-offers dd {
    padding: 36px 45px;
  }
}
@media screen and (min-width: 769px) {
  #special-offers dd.has-list {
    padding: 0;
  }
}
#special-offers dd .title {
  display: block;
  font-size: 1.375rem;
  font-weight: bold;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #special-offers dd .title {
    display: inline-block;
    font-size: 1.625rem;
  }
}
#special-offers dd .title--sm {
  font-size: 1.25rem;
}
@media screen and (min-width: 769px) {
  #special-offers dd .title--sm {
    font-size: 1.625rem;
  }
}
#special-offers dd .title em {
  color: #0077a2;
}
#special-offers dd .detail {
  font-size: 1rem;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  #special-offers dd .detail {
    margin-top: 24px;
    font-size: 1.125rem;
  }
}
#special-offers .for-mvp {
  list-style: none;
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp {
    display: flex;
  }
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp li {
    flex: 1;
    padding: 20px 30px 30px 40px;
  }
}
#special-offers .for-mvp li:not(:first-child) {
  padding-top: 8px;
  margin-top: 14px;
  border-top: 2px solid #000;
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp li:not(:first-child) {
    padding-top: 20px;
    margin-top: 0;
    border-top: none;
    border-left: 2px solid #000;
  }
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp .summary {
    display: flex;
    align-items: flex-end;
  }
}
#special-offers .for-mvp .index {
  position: relative;
  color: #f0ff96;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 3.3125rem;
  -webkit-text-stroke: 1px #000;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp .index {
    margin-right: 1.4em;
  }
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp .index--far {
    margin-right: 1.6em;
  }
}
#special-offers .for-mvp .index::after {
  content: "";
  position: absolute;
  right: -0.4em;
  bottom: 0;
  transform-origin: left bottom;
  transform: rotate(45deg);
  width: 2px;
  height: 100%;
  background-color: #000;
}
#special-offers .for-mvp .title {
  margin-top: 24px;
}
@media screen and (min-width: 769px) {
  #special-offers .for-mvp .title {
    display: flex;
    align-items: flex-end;
    min-height: 2.6em;
    margin: 0;
    margin-bottom: -0.2em;
    line-height: 1.3;
  }
}

#intention {
  margin-top: 36px;
}
@media screen and (min-width: 769px) {
  #intention {
    margin-top: 80px;
  }
}
#intention .episode {
  position: relative;
  box-sizing: border-box;
  max-width: 970px;
  padding: 32px 19px 40px 25px;
  margin-inline: auto;
  background-color: #e7eff1;
  border-bottom: 2px solid #08506b;
}
@media screen and (min-width: 769px) {
  #intention .episode {
    padding: 51px 35px 52px 56px;
  }
}
#intention .episode::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 100%;
  height: 2px;
  background-image: linear-gradient(to right, #08506b calc(50% - 11px), transparent calc(50% - 11px), transparent calc(50% + 11px), #08506b calc(50% + 11px));
}
@media screen and (min-width: 769px) {
  #intention .episode::before {
    background-image: linear-gradient(to right, #08506b calc(50% - 16px), transparent calc(50% - 16px), transparent calc(50% + 16px), #08506b calc(50% + 16px));
  }
}
#intention .episode::after {
  content: "";
  position: absolute;
  bottom: 100%;
  left: calc(50% - 12px);
  transform-origin: bottom;
  transform: rotate(30.9637565321deg);
  width: 2px;
  height: 23.3238075794px;
  background-color: #08506b;
}
@media screen and (min-width: 769px) {
  #intention .episode::after {
    left: calc(50% - 17px);
    transform: rotate(29.5387822596deg);
    height: 34.4818792991px;
  }
}
#intention .episode h3 {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  padding-inline: 2.5em;
  margin-inline: auto;
  text-align: center;
  color: #08506b;
  font-size: 1rem;
  font-weight: bold;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #intention .episode h3 {
    font-size: 1.375rem;
  }
}
#intention .episode h3::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.5em;
  height: 1px;
  background-color: #08506b;
}
#intention .episode h3::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 1.5em;
  height: 1px;
  background-color: #08506b;
}
#intention .episode .summary {
  margin-top: 20px;
  font-size: 1.25rem;
  font-weight: 900;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #intention .episode .summary {
    margin-top: 36px;
    font-size: 1.5rem;
  }
}
#intention .episode .summary em {
  color: #08506b;
}
#intention .episode .detail {
  margin-top: 15px;
}
@media screen and (min-width: 769px) {
  #intention .episode .detail {
    margin-top: 20px;
  }
}
#intention .episode .detail p {
  font-size: 0.9375rem;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  #intention .episode .detail p {
    font-size: 1.125rem;
  }
}
#intention .episode .detail p:not(:first-child) {
  margin-top: 1.4em;
}
#intention .episode .detail p em {
  color: #08506b;
  font-weight: 600;
}
#intention .episode__image {
  position: absolute;
  bottom: 0;
  right: 32px;
  width: 184px;
}
#intention .conclusion {
  margin-top: 40px;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #intention .conclusion {
    margin-top: 30px;
  }
}
#intention .conclusion p {
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  #intention .conclusion p {
    font-size: 1.25rem;
  }
}
#intention .conclusion p:not(:first-child) {
  margin-top: 1.6em;
}

#about {
  padding: 50px 32px 100px;
}
@media screen and (min-width: 769px) {
  #about {
    padding: 87px 72px 143px;
  }
}
@media screen and (min-width: 769px) {
  #about .about__inner {
    display: flex;
    gap: 80px;
  }
}
#about .about__frame {
  position: relative;
  padding: 0 30px 36px;
  border: 2px solid #fff;
  -o-border-image: linear-gradient(to right, #fff calc(50% - 92px), transparent calc(50% - 92px), transparent calc(50% + 92px), #fff calc(50% + 92px)) 2;
     border-image: linear-gradient(to right, #fff calc(50% - 92px), transparent calc(50% - 92px), transparent calc(50% + 92px), #fff calc(50% + 92px)) 2;
}
@media screen and (min-width: 769px) {
  #about .about__frame {
    padding: 0 55px 34px;
    flex: 1;
    border-image-source: linear-gradient(to right, #fff calc(50% - 134px), transparent calc(50% - 134px), transparent calc(50% + 134px), #fff calc(50% + 134px));
  }
}
#about .about__frame:not(:first-child) {
  margin-top: 36px;
}
@media screen and (min-width: 769px) {
  #about .about__frame:not(:first-child) {
    margin: 0;
  }
}
#about .about__frame::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
}
#about .about__title {
  width: -moz-fit-content;
  width: fit-content;
  translate: 0 -50%;
  padding-inline: 20px;
  margin-inline: auto;
  text-align: center;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #about .about__title {
    font-size: 2rem;
  }
}
#about .about__content {
  font-size: 1rem;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  #about .about__content {
    font-size: 1.25rem;
  }
}

#overview dl .items {
  display: flex;
  flex-wrap: wrap;
}
#overview dl dt {
  position: relative;
  padding-right: 0.5em;
  margin-right: 0.5em;
}
#overview dl dt::after {
  content: "";
  position: absolute;
  top: 10%;
  bottom: 10%;
  right: 0;
  width: 1px;
  background-color: #fff;
}

#selection-process ol {
  list-style: none;
}
#selection-process li:not(:last-child) {
  position: relative;
  margin-bottom: 1.6em;
}
#selection-process li:not(:last-child)::after {
  content: "▼";
  position: absolute;
  bottom: -50%;
  left: 0;
  translate: 0 50%;
}
#selection-process .notes {
  margin-top: 20px;
}
#selection-process .notes small {
  font-size: 0.8125rem;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  #selection-process .notes small {
    font-size: 0.875rem;
  }
}

#entry {
  position: relative;
}
@media screen and (min-width: 769px) {
  #entry {
    padding-top: 120px;
  }
}
#entry h2 {
  text-align: center;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  #entry h2 {
    font-size: 1.5rem;
  }
}
#entry h2 span {
  display: block;
}
#entry .form {
  max-width: 664px;
  margin-top: 30px;
  margin-inline: auto;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 769px) {
  #entry .form_item {
    display: block;
  }
}
#entry .form_item:not(:first-child) {
  margin-top: 20px;
}
#entry .form_title {
  padding: 0;
  font-size: 0.9375rem;
  line-height: 1.3;
}
@media screen and (min-width: 769px) {
  #entry .form_title {
    width: auto;
  }
}
#entry .form_required {
  padding: 0.06em 0.2em;
  margin-left: 0.6em;
  background-color: #d15151;
  color: #fff;
}
#entry .form .wpcf7-form-control-wrap {
  margin-top: 7px;
}
#entry .form .form-text {
  font-size: 1rem;
  border: 1px solid #979797;
}
#entry .form .form-text::-moz-placeholder {
  color: #bdbdbd;
}
#entry .form .form-text::placeholder {
  color: #bdbdbd;
}
#entry .form .form-select {
  background: #fff;
  border: 1px solid #000;
  color: #000;
  font-size: 1rem;
}
#entry .form_item--has-btn {
  row-gap: 0;
}
@media screen and (min-width: 769px) {
  #entry .form_item--has-btn {
    display: grid;
    grid-template: auto auto/auto 1fr;
    -moz-column-gap: 10px;
         column-gap: 10px;
  }
}
@media screen and (min-width: 769px) {
  #entry .form_item--has-btn .form_title {
    grid-area: 1/1/2/3;
  }
}
@media screen and (min-width: 769px) {
  #entry .form_item--has-btn .form-zip-btn {
    justify-self: start;
    margin-top: 7px;
  }
}
@media screen and (min-width: 769px) {
  #entry .form_item--has-note .form_title {
    display: inline-block;
  }
  #entry .form_item--has-note .form_note {
    display: inline-block;
    margin-left: 0.8em;
  }
}
#entry .form_item--select .wpcf7-form-control-wrap::after {
  background-color: #000;
  height: 6px;
}
#entry .form .form-zip-btn {
  background-color: #fff;
  border: 1px solid #000;
  border-radius: 100px;
  color: #000;
}
#entry .form_note {
  color: #000;
  font-size: 0.8125rem;
}
#entry .form_privacy-policy-wrap {
  margin-top: 52px;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #entry .form_privacy-policy-wrap {
    margin-top: 40px;
  }
}
#entry .form_privacy-policy {
  display: inline-block;
  font-size: 0.75rem;
  line-height: 1.6;
  font-weight: 500;
}
#entry .form_privacy-policy a {
  color: #000;
}
#entry .form_submit-wrap {
  margin-top: 20px;
}
#entry .form_submit {
  width: auto;
  padding: 14px 23px;
  background-color: #000;
  border-radius: 100px;
  color: #fff;
  font-size: 0.9375rem;
}

footer {
  padding: 23px 32px 30px;
  background: linear-gradient(312deg, #000000 58%, #0077a2 104%);
  color: #fff;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  line-height: 1.6;
}
@media screen and (min-width: 769px) {
  footer {
    padding: 48px 128px 40px;
    font-size: 1rem;
  }
}
footer .items {
  margin-top: 1.6em;
}
@media screen and (min-width: 769px) {
  footer .items {
    display: flex;
    margin: 0;
  }
}
@media screen and (min-width: 769px) {
  footer dt {
    width: 6em;
  }
}
footer .copyright {
  margin-top: 56px;
  text-align: center;
}
footer .copyright small {
  font-size: 0.75rem;
  letter-spacing: 0.02em;
}

#thanks header {
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  padding: 28px;
}
#thanks header .header__inner {
  max-width: 910px;
  margin-inline: auto;
}
#thanks header h2 {
  width: -moz-max-content;
  width: max-content;
  margin-inline: auto;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #thanks header h2 {
    margin-left: 0;
  }
}
#thanks header .explanation {
  display: block;
  padding: 6px 10px;
  margin-top: 8px;
  background-image: linear-gradient(98deg, #0077a2 -5.5%, #000000 25%);
  color: #fff;
  font-size: 0.9375rem;
  font-weight: bold;
  line-height: 1;
}
#thanks header .explanation b {
  font-size: 1.375rem;
  font-weight: 400;
}
#thanks header .logo {
  display: inline-block;
  width: 143px;
  margin-top: 10px;
}
#thanks .thanks {
  padding-top: 32px;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
}
@media screen and (min-width: 769px) {
  #thanks .thanks {
    padding-top: 80px;
  }
}
#thanks .thanks .appreciate {
  color: #08506b;
  font-size: 1.375rem;
  font-weight: bold;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #thanks .thanks .appreciate {
    font-size: 1.75rem;
    line-height: 1.6;
  }
}
#thanks .thanks .get-in-touch {
  margin-top: 9px;
  font-size: 1rem;
  line-height: 2;
}
@media screen and (min-width: 769px) {
  #thanks .thanks .get-in-touch {
    margin-top: 16px;
    font-size: 1.25rem;
  }
}
#thanks .thanks .redirect-btn {
  display: block;
  position: relative;
  box-sizing: border-box;
  max-width: 425px;
  padding: 9px 18px;
  margin-top: 28px;
  margin-inline: auto;
  border: 1px solid #000;
  border-radius: 100px;
  background-color: #fff;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.2509803922);
  text-decoration: none;
  color: #08506b;
  font-family: "Roboto", "Noto Sans JP", sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  #thanks .thanks .redirect-btn {
    padding-block: 11px;
  }
}
#thanks .thanks .redirect-btn::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 11px;
  translate: 0 -50%;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  width: 9px;
  height: 13px;
  background-color: #08506b;
}
#thanks .thanks .progress-bar {
  max-width: 196px;
  height: 11px;
  margin-top: 23px;
  margin-inline: auto;
  background-color: #d9d9d9;
}
#thanks .thanks .progress-bar #progressBar {
  height: 100%;
  background-color: #212b2b;
}
#thanks .thanks .note {
  margin-top: 14px;
  font-size: 0.6875rem;
  font-weight: 500;
  line-height: 1.5;
}

.h {
  width: 1em;
  text-align: center;
  writing-mode: horizontal-tb;
  word-break: break-all;
  line-height: 1;
}

.before-bracket-start {
  letter-spacing: -0.4em;
}

.bracket-end {
  letter-spacing: -0.4em;
}

.bracket-first {
  text-indent: -0.4em;
}

.nowrap {
  white-space: nowrap;
}

.fadeup-seq > * {
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.5s;
}
.fadeup-seq > *.show {
  opacity: 1;
  transform: translateY(0);
}

.clip-in {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  transition: all 1s ease-out;
}
.clip-in.show {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.clip-in-seq > * {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  transition: all 1s;
}
.clip-in-seq > *.show {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}

.blur-in {
  opacity: 0;
  filter: blur(20px);
  transition: all 1.5s;
}
.blur-in.show {
  opacity: 1;
  filter: blur(0);
}

#back-to-top-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4px;
  position: fixed;
  z-index: 1000;
  bottom: 24px;
  right: 13px;
  box-sizing: border-box;
  width: 64px;
  height: 64px;
  padding: 8px;
  border-radius: 50%;
  background-color: #000;
  text-decoration: none;
}
@media screen and (min-width: 769px) {
  #back-to-top-btn {
    width: 93px;
    height: 93px;
  }
}
#back-to-top-btn::before {
  content: "";
  display: block;
  transform: rotate(45deg);
  width: 10px;
  height: 10px;
  border-top: 3px solid #fff;
  border-left: 3px solid #fff;
  background-image: linear-gradient(45deg, transparent calc(50% - 1.5px), #fff calc(50% - 1.5px), #fff calc(50% + 1.5px), transparent calc(50% + 1.5px));
}
@media screen and (min-width: 769px) {
  #back-to-top-btn::before {
    width: 15px;
    height: 15px;
  }
}
#back-to-top-btn::after {
  content: "TOP";
  text-align: center;
  color: #fff;
  font-family: "din-condensed", "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.05em;
}
@media screen and (min-width: 769px) {
  #back-to-top-btn::after {
    font-size: 32px;
  }
}

@keyframes shine {
  0% {
    left: -100%;
  }
  20% {
    left: 100%;
  }
  100% {
    left: 100%;
  }
}
.shine {
  position: relative;
  overflow: hidden;
}
.shine::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -100%;
  width: 100%;
  background-image: linear-gradient(to left, #fff, transparent);
  clip-path: polygon(0 0, 100% 0, 90% 100%, 0 100%);
  animation: shine 4s infinite;
}