/* ========== ベーススタイル（PC向け） ========== */
.fv {
  height: 75.1rem;
  background: linear-gradient(90deg, var(--color-white) 0%, #dbf1ff 100%);
  padding-top: 2.8rem;
  font-family: "Noto Sans JP", sans-serif;
  position: relative;
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.5s ease-out;
}

/* ローディング状態 */
.fv--loading {
  opacity: 0;
}

.fv--loaded {
  opacity: 1;
}

/* ヘッダー部分は layout/_header.css に移管済み */

/* 背景飾り画像 */
.fv__decoration {
  position: absolute;
  z-index: 0;
  pointer-events: none;
}

.fv__decoration-1 {
  top: 0.9rem;
  left: 4.6rem;
  width: 9.9rem;
  height: 10.2rem;
  background-image: url("../../../img/DotGrid-1.png");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 1;
  z-index: 2;
}

.fv__decoration-2 {
  top: 64.3rem;
  left: 14.3rem;
  width: 23.174rem;
  height: 23.82rem;
  background-image: url("../../../img/DotGrid-2.png");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 1;
  z-index: 2;
}

.fv__decoration-3 {
  top: 50rem;
  left: 132.7rem;
  width: 14.6rem;
  height: 15rem;
  background-image: url("../../../img/DotGrid-3.png");
  background-size: contain;
  background-repeat: no-repeat;
  opacity: 1;
  z-index: 2;
}

.fv__decoration-4 {
  --decoration-top: 35.946rem;
  --decoration-left: 55.538rem;
  --decoration-width: 117.01691920084302rem;
  --decoration-height: 22.64702000795052rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-4-clone {
  --decoration-top: 35.946rem;
  --decoration-left: 55.538rem;
  --decoration-width: 117.01691920084302rem;
  --decoration-height: 22.64702000795052rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

/* 追加の装飾要素の例 */
.fv__decoration-5 {
  --decoration-top: -11.534rem;
  --decoration-left: -27.867rem;
  --decoration-width: 71.902rem;
  --decoration-height: 24.871rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-5-clone {
  --decoration-top: -11.534rem;
  --decoration-left: -27.867rem;
  --decoration-width: 71.902rem;
  --decoration-height: 24.871rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

.fv__decoration-6 {
  --decoration-top: 60.7rem;
  --decoration-left: -15.3rem;
  --decoration-width: 26.66250310998087rem;
  --decoration-height: 6.913720718222531rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-6-clone {
  --decoration-top: 60.7rem;
  --decoration-left: -15.3rem;
  --decoration-width: 26.66250310998087rem;
  --decoration-height: 6.913720718222531rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

.fv__decoration-7 {
  --decoration-top: -0.5rem;
  --decoration-left: 89.4rem;
  --decoration-width: 35.431359940652914rem;
  --decoration-height: 3.531483848654104rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-7-clone {
  --decoration-top: -0.5rem;
  --decoration-left: 89.4rem;
  --decoration-width: 35.431359940652914rem;
  --decoration-height: 3.531483848654104rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

.fv__decoration-8 {
  --decoration-top: 48.4rem;
  --decoration-left: 123.8rem;
  --decoration-width: 39.19602669692071rem;
  --decoration-height: 2.2814205219497243rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-8-clone {
  --decoration-top: 48.4rem;
  --decoration-left: 123.8rem;
  --decoration-width: 39.19602669692071rem;
  --decoration-height: 2.2814205219497243rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(
    90deg,
    var(--color-primary) 0%,
    var(--color-white) 100%
  );
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

.fv__decoration-9 {
  --decoration-top: 59.3rem;
  --decoration-left: 123.8rem;
  --decoration-width: 39.19602669692071rem;
  --decoration-height: 10.396060203365998rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(90deg, var(--color-primary) 0%, #ffffff 100%);
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite 0s;
}

.fv__decoration-9-clone {
  --decoration-top: 59.3rem;
  --decoration-left: 123.8rem;
  --decoration-width: 39.19602669692071rem;
  --decoration-height: 10.396060203365998rem;
  --decoration-rotate: -41.82deg;
  --decoration-duration: 3s;

  top: var(--decoration-top);
  left: var(--decoration-left);
  width: var(--decoration-width);
  height: var(--decoration-height);
  background: linear-gradient(90deg, var(--color-primary) 0%, #ffffff 100%);
  transform: rotate(var(--decoration-rotate));
  opacity: 1;
  z-index: 1;
  animation: decorationMoveRotate var(--decoration-duration) ease-in-out
    infinite -1.5s;
}

@keyframes decorationMoveRotate {
  0% {
    transform: translate(
        calc(-1 * var(--decoration-move-x, 89.4rem)),
        var(--decoration-move-y, 80.04rem)
      )
      rotate(var(--decoration-rotate, -41.82deg));
    opacity: 0;
  }
  99.8% {
    transform: translate(
        var(--decoration-move-x, 89.4rem),
        calc(-1 * var(--decoration-move-y, 80.04rem))
      )
      rotate(var(--decoration-rotate, -41.82deg));
    opacity: 1;
  }
  99.9% {
    transform: translate(
        var(--decoration-move-x, 89.4rem),
        calc(-1 * var(--decoration-move-y, 80.04rem))
      )
      rotate(var(--decoration-rotate, -41.82deg));
    opacity: 0;
  }
  100% {
    transform: translate(
        calc(-1 * var(--decoration-move-x, 89.4rem)),
        var(--decoration-move-y, 80.04rem)
      )
      rotate(var(--decoration-rotate, -41.82deg));
    opacity: 0;
  }
}

/* ファーストビュー */
.fv__inner {
  margin: 0 auto;
  height: 65.3rem;
  padding: 8.2rem 15.7rem;
  position: relative;
  overflow: hidden;
  z-index: 2;
}

.fv__catch-copy {
  font-size: 6.606rem;
  font-weight: 700;
  margin-bottom: 5.3rem;
  line-height: 1.3;
  color: #0f3c58;
  clip-path: polygon(0 0, 0 100%, 0 100%, 0 0);
  /* アニメーションは初期状態で停止 */
}

.fv__catch-copy--animate {
  animation: clipReveal 1.5s ease-out forwards;
}

@keyframes clipReveal {
  0% {
    clip-path: polygon(0 0, 0 100%, 0 100%, 0 0);
  }
  100% {
    clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0);
  }
}

.fv__sub {
  margin: 0 0 10rem -16.9rem;
  padding: 0 0 0 14rem;
  width: 92.8rem;
  height: 5.1rem;
  font-size: 2.8rem;
  font-weight: 700;
  color: #07314b;
  background-color: #fff;
  transform: skew(25deg);
  display: flex;
}

.fv__sub-text {
  margin: -0.7rem 0 0 3.4rem;
  transform: skew(-25deg);
  display: inline-block;
}

.fv__emphasis {
  display: inline-block;
}

.fv__emphasis-char {
  position: relative;
  display: inline-block;
}

.fv__emphasis-char::before {
  content: "•";
  position: absolute;
  top: -1.5rem;
  left: 55%;
  transform: translateX(-50%);
  font-size: 2.1rem;
  color: #07314b;
}

.fv__badge {
  font-size: 3.4rem;
  color: #fff;
  margin: 0 0.2rem;
  padding: 0.4rem 1.7rem;
  font-weight: 700;
  display: inline-block;
  position: relative;
  top: 0.2rem;
}

.fv__badge-text {
  clip-path: polygon(0 0, 0 100%, 0 100%, 0 0);
  display: inline-block;
  /* アニメーションは初期状態で停止 */
}

.fv__badge-text--animate {
  animation: clipReveal 0.5s ease-out 1s forwards;
}

.fv__badge::before {
  content: "";
  position: absolute;
  top: 0.2rem;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--color-primary);
  transform: rotate(2.2deg);
  z-index: -1;
  /* アニメーションは初期状態で停止 */
}

.fv__badge--animate::before {
  animation: badgeRotate 0.5s ease-out 1.5s forwards;
}

@keyframes badgeRotate {
  0% {
    transform: rotate(2.8deg);
  }
  100% {
    transform: rotate(-2.8deg);
  }
}

.fv__cta {
  display: inline-flex;
  align-items: center;
  gap: 1.1rem;
  background: linear-gradient(to left, #f48c41, #fe6c03);
  color: #fff;
  font-size: 2.862rem;
  font-weight: 700;
  margin: 0 0 0 -0.2rem;
  padding: 2.6rem 5.6rem 2.6rem 5.8rem;
  border-radius: 99.9rem;
  text-decoration: none;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  border: 0.2rem solid #fff;
  z-index: 3;
}

.fv__cta::before {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(
    -60deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 0.875) 12.5%,
    rgba(255, 255, 255, 0.75) 25%,
    rgba(255, 255, 255, 0.625) 37.5%,
    rgba(255, 255, 255, 0.5) 50%,
    rgba(255, 255, 255, 0.375) 62.5%,
    rgba(255, 255, 255, 0.25) 75%,
    rgba(255, 255, 255, 0.125) 87.5%,
    transparent 100%
  );
  transform: rotate(-30deg);
  animation: glossMove 2.5s ease-in-out infinite;
}

.fv__cta-arrow {
  position: relative;
  display: inline-block;
  width: 3.577rem;
  height: 3.577rem;
  transform: rotate(-90deg);
  opacity: 1;
  transition: transform 0.3s ease;
}

.fv__cta-arrow::before,
.fv__cta-arrow::after {
  content: "";
  position: absolute;
  background-color: #fff;
  width: 0.5rem;
  height: 2rem;
  top: 50%;
  left: 48%;
  transform-origin: bottom center;
  transition: background-color 0.3s ease;
}

.fv__cta-arrow::before {
  transform: translateX(-35%) translateY(-50%) rotate(-45deg);
}

.fv__cta-arrow::after {
  transform: translateX(-65%) translateY(-50%) rotate(45deg);
}

@keyframes glossMove {
  0% {
    transform: translateX(-100%) rotate(-30deg);
  }
  50% {
    transform: translateX(150%) rotate(-30deg);
  }
  100% {
    transform: translateX(150%) rotate(-30deg);
  }
}

.fv__cta:hover {
  background: #fff;
  color: #f48c41;
  border-color: #f48c41;
}

.fv__cta:hover .fv__cta-arrow::before,
.fv__cta:hover .fv__cta-arrow::after {
  background-color: #f48c41;
}

.fv__cta:hover::before {
  animation: none;
  transform: translateX(-100%) rotate(-30deg);
}

.fv__cta:active {
  opacity: 1 !important;
  background: linear-gradient(to left, #f48c41, #fe6c03) !important;
  color: #fff !important;
  border-color: #fff !important;
}

.fv__cta:active .fv__cta-arrow::before,
.fv__cta:active .fv__cta-arrow::after {
  background-color: #fff !important;
}

.fv__visual {
  position: absolute;
  top: -19.2rem;
  right: 0.1rem;
  height: 73.1rem;
  width: 64.488rem;
}

.fv__image {
  width: 100%;
  height: auto;
}

.fv__caption {
  position: absolute;
  top: 70.2rem;
  left: 20.6rem;
  background: transparent;
  padding: 0.8rem 1.2rem;
  font-size: 0.9rem;
  color: #ffffff;
  font-weight: bold;
  text-align: center;
  text-shadow: -0.1rem -0.1rem 0 var(--color-primary),
    0.1rem -0.1rem 0 var(--color-primary), -0.1rem 0.1rem 0 var(--color-primary),
    0.1rem 0.1rem 0 var(--color-primary);
}

.fv__caption-university {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.5;
  text-align: center;
  vertical-align: middle;
}

.fv__caption-name {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 3.2rem;
  line-height: 1.4;
  text-align: center;
  vertical-align: middle;
}

/* ========== SP表示（〜768px = 768px） ========== */
@media screen and (max-width: 768px) {
  .fv {
    max-height: 75.1rem;
    min-height: 58rem;
    height: var(--fv-height-sp, 100dvh);
    padding-top: 2.6rem;
    transition: height 0.35s ease;
  }

  .fv__inner {
    height: 100%;
    flex-direction: column;
    align-items: center;
    padding: 3.9rem 1.2rem;
    gap: 3rem;
  }

  .fv__decoration-1 {
    display: none;
  }
  .fv__decoration-2 {
    top: 60.8rem;
    left: -2.8rem;
    width: 14.6rem;
    height: 14.5rem;
    background-image: url("../../../img/DotGrid-2-sp.png");
    background-repeat: no-repeat;
    background-size: contain;
  }
  .fv__decoration-3 {
    top: 49.3rem;
    left: 35.3rem;
    width: 8.7rem;
    height: 8.9rem;
  }
  .fv__decoration-4 {
    --decoration-top: 43.1rem;
    --decoration-left: -11rem;
    --decoration-width: 71.853rem;
    --decoration-height: 15.569rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-4-clone {
    --decoration-top: 43.1rem;
    --decoration-left: -11rem;
    --decoration-width: 71.853rem;
    --decoration-height: 15.569rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-5 {
    --decoration-top: -1.9rem;
    --decoration-left: -7.2rem;
    --decoration-width: 19.973rem;
    --decoration-height: 6.909rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-5-clone {
    --decoration-top: -1.9rem;
    --decoration-left: -7.2rem;
    --decoration-width: 19.973rem;
    --decoration-height: 6.909rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-6 {
    --decoration-top: 0.5rem;
    --decoration-left: 26rem;
    --decoration-width: 19.653rem;
    --decoration-height: 2.346rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-6-clone {
    --decoration-top: 0.5rem;
    --decoration-left: 26rem;
    --decoration-width: 19.653rem;
    --decoration-height: 2.346rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-7 {
    --decoration-top: 46.5rem;
    --decoration-left: -10.6rem;
    --decoration-width: 19.342rem;
    --decoration-height: 3.329rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-7-clone {
    --decoration-top: 46.5rem;
    --decoration-left: -10.6rem;
    --decoration-width: 19.342rem;
    --decoration-height: 3.329rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-8 {
    --decoration-top: 62.2rem;
    --decoration-left: 29.3rem;
    --decoration-width: 19.186rem;
    --decoration-height: 3.195rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-8-clone {
    --decoration-top: 62.2rem;
    --decoration-left: 29.3rem;
    --decoration-width: 19.186rem;
    --decoration-height: 3.195rem;
    --decoration-rotate: -41.82deg;
    top: var(--decoration-top);
    left: var(--decoration-left);
    width: var(--decoration-width);
    height: var(--decoration-height);
    transform: rotate(var(--decoration-rotate));
  }
  .fv__decoration-9 {
    display: none;
  }

  .fv__content {
    max-width: 100%;
  }

  .fv__catch-copy {
    font-size: 2.8rem;
    margin-bottom: 4.1rem;
  }

  .fv__sub {
    width: 51.4rem;
    font-size: 1.6rem;
    margin: 0 0 0 -17rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-end;
    gap: 0.5rem;
    height: 3rem;
  }

  .fv__sub-text {
    margin: -0.7rem 0 0 3.6rem;
  }

  .fv__sub-line1 {
    display: block;
    margin-bottom: -0.1rem;
  }

  .fv__sub-line2 {
    display: flex;
    align-items: center;
    gap: 0.2rem;
    flex-wrap: wrap;
    margin: -0.1rem 0 0 -0.1rem;
  }

  .fv__emphasis-char::before {
    font-size: 1.2rem;
    top: -1rem;
    left: 100%;
  }

  .fv__badge {
    position: relative;
    top: 0.1rem;
    left: -0.1rem;
    font-size: 2rem;
    display: inline-flex;
    align-items: center;
    padding: 0.16rem 0.9rem;
    font-weight: 500;
    margin-bottom: 0;
    flex-shrink: 0;
  }

  .fv__badge::before {
    content: "";
    position: absolute;
    top: 0rem;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--color-primary);
    transform: rotate(2.2deg);
    z-index: -1;
    animation: badgeRotate 0.5s ease-out 1.5s forwards;
  }

  .fv__visual {
    top: 7.3rem;
    right: -2.7rem;
    width: 44.9rem;
    height: calc(var(--fv-height-sp, 100dvh) - 14rem);
    min-height: calc(58rem - 14rem);
  }

  .fv__caption {
    background: none;
    padding: 0;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    top: 16.2rem;
    left: 34.6rem;
    text-align: start;
  }

  .fv__caption-university {
    font-size: 1.5rem;
    letter-spacing: 0.3rem;
    line-height: 1.6;
  }

  .fv__caption-name {
    font-size: 2.04rem;
    letter-spacing: 0.3rem;
    margin-top: 3.4rem;
  }

  .fv__cta {
    position: absolute;
    bottom: 9.4rem;
    gap: 0.4rem;
    width: 36.9rem;
    height: 6.5rem;
    font-size: 1.8rem;
    padding: 1.3rem 0 1.2rem 4.2rem;
    margin: 0 0 0 0rem;
  }

  .fv__cta-arrow {
    width: 2.8rem;
    height: 2.8rem;
  }

  .fv__cta-arrow::before,
  .fv__cta-arrow::after {
    width: 0.3rem;
    height: 1.4rem;
  }
}
