@charset "UTF-8";
/* =================================
   TopPage
==================================== */
.cf {
  *zoom: 1;
}
.cf:after {
  content: "";
  display: block;
  clear: both;
  height: 0;
}

form ::-webkit-input-placeholder {
  color: #C6C6C6;
}
form :-moz-placeholder {
  opacity: 1;
  color: #C6C6C6;
}
form ::-moz-placeholder {
  opacity: 1;
  color: #C6C6C6;
}
form :-ms-input-placeholder {
  color: #C6C6C6;
}

::-moz-selection {
  color: #FFF;
  background: rgba(22, 65, 125, 0.7);
}

::selection {
  color: #FFF;
  background: rgba(22, 65, 125, 0.7);
}

.tp-header {
  position: relative;
}
.tp-header .tp-header-en {
  font-size: min(8em, 17vw);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 600;
  line-height: 1;
  padding-bottom: 0.25em;
  margin-bottom: 0.5em;
  text-transform: capitalize;
  color: #e9f0f9;
  opacity: 0;
  -webkit-transition: opacity 1.5s 0.5s ease-out;
  transition: opacity 1.5s 0.5s ease-out;
}
.tp-header .tp-header-jp {
  font-size: min(1.5em, 4.35vw);
  font-weight: 700;
  line-height: 1.2;
  color: #16417d;
  position: absolute;
  top: 0;
  left: 2em;
  bottom: 0;
  margin: auto;
  height: 1em;
}
.tp-header .tp-header-jp span {
  opacity: 0;
  -webkit-transition: opacity 1.5s 0.5s ease-out;
  transition: opacity 1.5s 0.5s ease-out;
}
.tp-header .tp-header-jp:before {
  content: "";
  width: 0;
  height: 1px;
  background: #16417d;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc((100vw - min(100%, 1200px + 12%) + 1.8em) * -1);
  margin: auto;
  -webkit-transition: width 0.5s;
  transition: width 0.5s;
}
.tp-header.visible .tp-header-en {
  opacity: 1;
}
.tp-header.visible .tp-header-jp span {
  opacity: 1;
}
.tp-header.visible .tp-header-jp:before {
  width: calc(100vw - 0.625rem - min(100%, 1200px + 12%) + 1.8em);
}

.tp-header-02 {
  position: relative;
  text-align: center;
  margin-bottom: 1.6em;
}
.tp-header-02 .tp-header-en {
  font-size: min(8em, 17vw);
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 600;
  line-height: 1;
  padding-bottom: 0.25em;
  text-transform: capitalize;
  color: #fff;
}
.tp-header-02 .tp-header-jp {
  font-size: min(1.5em, 4.35vw);
  font-weight: 700;
  line-height: 1.2;
  color: #16417d;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  height: 1em;
}

/*==============================
TOP contents
==============================*/
.l-mv {
  position: relative;
}
.l-mv .mv-txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin-top: 5.625rem;
  position: relative;
  font-size: min(1em, 1.55vw);
  z-index: 1;
}
.l-mv .mv-txt h2 {
  font-size: min(7.375em, 11.2vw);
  color: #fff;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.1em;
  text-shadow: 0px 0px 8px #16417d;
}
.l-mv .mv-txt h2 span {
  display: inline-block;
  padding: 0 0.125em;
  margin: 0 -0.125em;
}
.l-mv .mv-txt h2 .outer {
  position: relative;
  overflow: hidden;
}
.l-mv .mv-txt h2 .outer:after {
  background: #0a1b31;
  bottom: 0;
  content: "";
  display: block;
  left: 0;
  position: absolute;
  right: 0;
  top: 0;
  -webkit-transform: translate(0, 100%);
          transform: translate(0, 100%);
  opacity: 0;
}
.l-mv .mv-txt h2 .outer:first-child .inner {
  padding-left: 0.2em;
}
.l-mv .mv-txt h2 .inner {
  visibility: hidden;
}
.l-mv .mv-txt p {
  margin-top: 0.5em;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  color: #16417d;
  font-size: 2.125em;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
  -webkit-transition: opacity 2s 2.5s;
  transition: opacity 2s 2.5s;
}
.l-mv .mv-scroll {
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-left: auto;
  overflow: hidden;
  right: 6%;
  width: min(12.5em, 16.666vw);
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.l-mv .mv-scroll::before {
  content: "";
  width: 65%;
  height: calc(65% - 5em);
  background: url(../img/top/scroll_arw.svg) no-repeat center center/contain;
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  margin: auto;
}
.l-mv .mv-scroll img {
  -webkit-animation: mv-scroll 10s linear infinite;
          animation: mv-scroll 10s linear infinite;
}
@media only screen and (min-width: 768px) and (max-width: 1200px) {
  .l-mv .mv-scroll {
    opacity: 0;
  }
}
.l-mv.is-show h2 .outer:first-of-type:after {
  -webkit-animation: mask-bg 1s cubic-bezier(0.8, 0, 0.17, 1);
          animation: mask-bg 1s cubic-bezier(0.8, 0, 0.17, 1);
}
.l-mv.is-show h2 .outer:first-of-type .inner {
  visibility: visible !important;
  -webkit-transition: visibility 0s 0.5s;
  transition: visibility 0s 0.5s;
}
.l-mv.is-show h2 .outer:nth-of-type(2):after {
  -webkit-animation: mask-bg 1.4s 0.45s cubic-bezier(0.8, 0, 0.17, 1);
          animation: mask-bg 1.4s 0.45s cubic-bezier(0.8, 0, 0.17, 1);
}
.l-mv.is-show h2 .outer:nth-of-type(2) .inner {
  visibility: visible !important;
  -webkit-transition: visibility 0s 1s;
  transition: visibility 0s 1s;
}
.l-mv.is-show h2 .outer:nth-of-type(3):after {
  -webkit-animation: mask-bg 1.4s 0.9s cubic-bezier(0.8, 0, 0.17, 1);
          animation: mask-bg 1.4s 0.9s cubic-bezier(0.8, 0, 0.17, 1);
}
.l-mv.is-show h2 .outer:nth-of-type(3) .inner {
  visibility: visible !important;
  -webkit-transition: visibility 0s 1.6s;
  transition: visibility 0s 1.6s;
}
.l-mv.is-show p {
  opacity: 1 !important;
}
@media only screen and (min-width: 768px) {
  .l-mv {
    min-height: max(100dvh, 45em);
  }
  .l-mv .mv-txt {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    height: calc(max(100dvh, 45em) - 5.625rem);
  }
  .l-mv .mv-txt p {
    padding: 0.25em 0.75em;
    background: rgba(255, 255, 255, 0.75);
  }
  .l-mv .mv-scroll {
    position: sticky;
    padding-bottom: 5em;
    bottom: 0;
    width: min(12.5em, 16.666vw);
  }
  .l-mv .mv-scroll::before {
    height: calc(65% - 5em);
    bottom: 5em;
  }
}
@media only screen and (max-width: 767px) {
  .l-mv {
    overflow: hidden;
    min-height: max(100dvh, 40em);
    font-size: 1em;
  }
  .l-mv .mv-txt {
    height: calc(max(100dvh, 40em) - 5.625rem);
    padding-top: min(11dvh, 10em);
  }
  .l-mv .mv-txt h2 {
    white-space: nowrap;
  }
  .l-mv .mv-txt p span {
    display: inline-block;
    padding: 0.25em 0.75em;
    background: rgba(255, 255, 255, 0.75);
    font-size: min(5vw, 1.25em);
  }
  .l-mv .mv-txt p span + span {
    margin-top: 0.625rem;
  }
  .l-mv .mv-scroll {
    position: absolute;
    width: min(12.5em, 20vw);
    top: calc(95dvh - min(12.5em, 20vw));
  }
  .l-mv .mv-scroll::before {
    height: 50%;
    bottom: 0;
  }
}

@-webkit-keyframes mv-scroll {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes mv-scroll {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@-webkit-keyframes mask-bg {
  0% {
    opacity: 1;
    -webkit-transform: translate(-101%, 0);
            transform: translate(-101%, 0);
  }
  43%, 57% {
    -webkit-transform: translate(0, 0%);
            transform: translate(0, 0%);
  }
  99% {
    -webkit-transform: translate(100%, 0);
            transform: translate(100%, 0);
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes mask-bg {
  0% {
    opacity: 1;
    -webkit-transform: translate(-101%, 0);
            transform: translate(-101%, 0);
  }
  43%, 57% {
    -webkit-transform: translate(0, 0%);
            transform: translate(0, 0%);
  }
  99% {
    -webkit-transform: translate(100%, 0);
            transform: translate(100%, 0);
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.mask {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -4;
  background: #fff;
}

.mv-img {
  width: 100%;
  height: 100dvh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -5;
}
.mv-img .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: -webkit-transform 0s 3s;
  transition: -webkit-transform 0s 3s;
  transition: transform 0s 3s;
  transition: transform 0s 3s, -webkit-transform 0s 3s;
}
@media only screen and (min-width: 768px) {
  .mv-img .swiper-slide .mv-inner {
    display: contents;
  }
  .mv-img .swiper-slide.swiper-slide-visible img {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-transition: -webkit-transform 7s ease-out;
    transition: -webkit-transform 7s ease-out;
    transition: transform 7s ease-out;
    transition: transform 7s ease-out, -webkit-transform 7s ease-out;
  }
}
@media only screen and (max-width: 767px) {
  .mv-img .swiper-slide .mv-inner {
    height: 100%;
    width: 120%;
    left: 0;
    position: relative;
    top: 0;
    -webkit-transition: left 0s 3s;
    transition: left 0s 3s;
  }
  .mv-img .swiper-slide.swiper-slide-visible .mv-inner {
    left: -20%;
    -webkit-transition: left 7s ease-out;
    transition: left 7s ease-out;
  }
}

.tp-mission {
  position: relative;
  padding-bottom: min(12.5em, 26vw);
}
.tp-mission:after {
  content: "";
  width: 100%;
  height: calc(100% + 3em);
  left: 0;
  bottom: 0;
  position: absolute;
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(23, 66, 125, 0)), color-stop(80%, #17427D));
  background: linear-gradient(180deg, rgba(23, 66, 125, 0) 0%, #17427D 80%);
  z-index: -1;
}
.tp-mission h2 {
  text-transform: capitalize;
  font-weight: 600;
  font-size: min(1.25em, 3.625vw);
  line-height: 1.2;
  color: #fff;
  position: relative;
}
.tp-mission h2 span {
  opacity: 0;
  -webkit-transition: opacity 1.5s 0.5s ease-out;
  transition: opacity 1.5s 0.5s ease-out;
}
.tp-mission h2:before {
  content: "";
  width: 0;
  height: 1px;
  background: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc((100vw - min(100%, 1200px + 12%)) * -1);
  margin: auto;
  -webkit-transition: width 0.5s;
  transition: width 0.5s;
}
.tp-mission h2.visible span {
  opacity: 1;
}
.tp-mission h2.visible:before {
  width: calc(100vw - 0.625rem - min(100%, 1200px + 12%));
}
.tp-mission p, .tp-mission a {
  color: #fff;
}
.tp-mission .tp-mission-copy {
  font-size: min(2em, 6.1vw);
  margin-top: 0.2em;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.2;
}
.tp-mission .tp-mission-body {
  font-size: 1.125em;
  letter-spacing: 0.05em;
  margin-top: 3.2em;
  max-width: 620px;
}
.tp-mission .tp-mission-body span {
  display: inline-block;
}
.tp-mission .tp-mission-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.42em 1.5625em;
  margin-top: 2.1em;
  max-width: 620px;
}
.tp-mission .tp-mission-list li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.tp-mission .tp-mission-list a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  text-align: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 5em;
  border: 1px solid;
  background: rgba(255, 255, 255, 0.05);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
}
@media (hover: hover) {
  .tp-mission .tp-mission-list a {
    -webkit-transition: background 0.3s;
    transition: background 0.3s;
  }
  .tp-mission .tp-mission-list a:hover, .tp-mission .tp-mission-list a:active, .tp-mission .tp-mission-list a:focus {
    background: rgba(91, 146, 223, 0.5);
  }
}
.tp-mission .tp-mission-en {
  font-size: 1.25em;
  font-weight: 600;
  line-height: 1;
  text-transform: capitalize;
}
.tp-mission .tp-mission-jp {
  font-size: 0.875em;
  font-weight: 700;
  line-height: 1.5;
}
@media only screen and (min-width: 768px) {
  .tp-mission {
    margin-bottom: calc(-5em - min(12.5em, 16.666vw));
  }
}
@media only screen and (max-width: 767px) {
  .tp-mission .tp-mission-list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.l-contents {
  background: #fff;
}

.tp-about {
  position: relative;
  padding-top: 20.5em;
  padding-bottom: min(9.375em, 19.5vw);
  background: #16417d url(../img/top/tp_about_bg@2x.jpg) no-repeat center bottom/cover;
}
.tp-about p, .tp-about a {
  color: #fff;
}
.tp-about .tp-about-en {
  text-transform: capitalize;
  font-weight: 600;
  line-height: 1.1;
}
.tp-about h2 {
  color: #5b92df;
  font-size: 1.25em;
  font-weight: 700;
}
.tp-about h2:before {
  content: "";
  width: 2em;
  height: 1px;
  background: #5b92df;
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.5em;
}
.tp-about .tp-about-copy {
  font-size: 1.75em;
  font-weight: 700;
  letter-spacing: 0.075em;
  margin-top: 1.7em;
}
.tp-about .tp-about-body {
  font-size: 1.125em;
  margin-top: 2em;
  letter-spacing: 0.05em;
}
.tp-about .more-btn {
  margin-top: 3.75em;
}
.tp-about .more-btn a {
  color: #16417d;
  background: #e9f0f9;
  border-color: #e9f0f9;
}
.tp-about .more-btn a:after {
  background: #16417d;
}
@media (hover: hover) {
  .tp-about .more-btn a:hover, .tp-about .more-btn a:active, .tp-about .more-btn a:focus {
    color: #fff;
    background: rgba(255, 255, 255, 0.3);
  }
  .tp-about .more-btn a:hover:after, .tp-about .more-btn a:active:after, .tp-about .more-btn a:focus:after {
    background: #fff;
  }
}
.tp-about .tp-about-img ul li {
  overflow: hidden;
}
.tp-about .tp-about-img ul img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.tp-about .tp-about-img ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.25em;
  display: flex;
  height: 100%;
}
.tp-about .tp-about-img ul li {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media only screen and (min-width: 961px) {
  .tp-about .tp-about-txt {
    max-width: 55%;
  }
  .tp-about .tp-about-en {
    font-size: min(8em, 9.8vw);
  }
  .tp-about .tp-about-copy {
    font-size: min(1.75em, 2.3vw);
  }
  .tp-about .tp-about-body {
    font-size: min(1.125em, 1.6vw);
  }
  .tp-about .tp-about-img {
    position: absolute;
    right: 6%;
    top: 0;
    bottom: 0;
    margin: auto;
    width: min(36%, 640px);
    max-height: 780px;
    height: 100%;
  }
  .tp-about .tp-about-img ul li:first-child {
    margin-top: 9.375em;
  }
  .tp-about .tp-about-img ul li:last-child {
    margin-bottom: 9.375em;
  }
}
@media only screen and (max-width: 960px) {
  .tp-about {
    padding-top: min(9.375em, 19.5vw);
  }
  .tp-about .tp-about-en {
    font-size: min(8em, 17vw);
  }
  .tp-about h2 {
    font-size: min(1.25em, 3.625vw);
  }
  .tp-about .tp-about-copy {
    font-size: min(1.75em, 4.1vw);
  }
  .tp-about .tp-about-body {
    font-size: min(1.125em, 4vw);
  }
  .tp-about .tp-about-img {
    margin-top: 3.75em;
  }
  .tp-about .tp-about-img ul li:first-child {
    margin-top: 3.75em;
  }
  .tp-about .tp-about-img ul li:last-child {
    margin-bottom: 3.75em;
  }
  .tp-about .more-btn {
    margin-left: auto;
  }
}

.tp-strengths {
  position: relative;
  z-index: 1;
}
.tp-strengths .wrap {
  max-width: 100%;
}
.tp-strengths .tp-strengths-bg {
  position: sticky;
  top: 0;
  width: 100%;
  height: 100dvh;
  z-index: -1;
}
.tp-strengths .tp-strengths-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.tp-strengths .tp-strengths-content {
  margin-top: -100dvh;
  padding: min(8.1em, 16.848vw) 0 min(10.2em, 21.21vw) 0;
  color: #fff;
  margin-left: auto;
}
.tp-strengths .tp-strengths-header {
  text-align: right;
  margin-bottom: 2.3em;
}
.tp-strengths .tp-strengths-en {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-weight: 600;
  line-height: 1;
  padding-bottom: 0.25em;
  text-transform: capitalize;
}
.tp-strengths .tp-strengths-jp {
  font-size: min(1.5em, 4.35vw);
  font-weight: 700;
  line-height: 1.2;
  height: 1em;
}
.tp-strengths .tp-strengths-intro {
  margin-bottom: min(4.5em, 13vw);
  font-size: min(1.37em, 4.1vw);
  letter-spacing: 0.01em;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  -webkit-margin-start: auto;
          margin-inline-start: auto;
}
.tp-strengths .strengths-item {
  width: min(94%, 41.25em);
  padding: 1.875em 4%;
  background: rgba(23, 66, 125, 0.3);
}
.tp-strengths .strengths-item:nth-child(even) {
  margin-left: auto;
}
.tp-strengths .strengths-item + .strengths-item {
  margin-top: min(2.5em, 5.2vw);
}
.tp-strengths .strengths-item .strengths-en {
  font-family: "Plus Jakarta Sans", sans-serif;
  font-size: 2.5em;
  font-weight: 600;
  line-height: 1.1;
  padding-bottom: 0.25em;
  text-transform: capitalize;
}
.tp-strengths .strengths-item .strengths-jp {
  font-size: min(1.5em, 5.1vw);
  letter-spacing: 0.05em;
  line-height: 1.1;
  font-weight: 700;
}
.tp-strengths .strengths-item .strengths-body {
  margin-top: 1em;
  font-size: 1.25em;
  line-height: 1.5;
  letter-spacing: 0.05em;
}
.tp-strengths .strengths-item .strengths-body span {
  display: inline-block;
}
@media only screen and (min-width: 768px) {
  .tp-strengths .tp-strengths-content {
    width: min(80%, 47.5em);
  }
  .tp-strengths .tp-strengths-en {
    font-size: min(6.25em, 17vw);
  }
}
@media only screen and (max-width: 767px) {
  .tp-strengths .tp-strengths-content {
    width: 100%;
  }
  .tp-strengths .tp-strengths-en {
    font-size: min(6.25em, 17vw);
  }
  .tp-strengths .strengths-item {
    background: rgba(23, 66, 125, 0.5);
  }
}

.tp-service {
  padding: min(8.1em, 16.848vw) 0 min(10.2em, 21.21vw) 0;
}
.tp-service .ttl-en {
  color: #e9f0f9;
  font-size: min(6.25em, 17vw);
}
.tp-service .tp-service-intro {
  font-weight: 700;
  margin: max(-4.5em, -13vw) auto min(3.2em, 11vw);
  color: #16417d;
}
@media only screen and (min-width: 768px) {
  .tp-service .tp-service-intro {
    font-size: min(1.75em, 2.5vw);
    line-height: 2;
    max-width: 870px;
  }
  .tp-service .tp-service-intro span {
    display: inline-block;
  }
}
@media only screen and (max-width: 767px) {
  .tp-service .tp-service-intro {
    font-size: min(1.6em, 4.5vw);
    text-align: left;
    line-height: 1.75;
  }
}

.tp-acc {
  height: 12.5em;
  background: url(../img/top/tp_acc_txt.svg) repeat-x left center/2998px;
  -webkit-animation: scroll-bg 30s infinite linear;
          animation: scroll-bg 30s infinite linear;
}

@-webkit-keyframes scroll-bg {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -2998px 0;
  }
}

@keyframes scroll-bg {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: -2998px 0;
  }
}
.tp-faq {
  padding: min(8.075em, 16.796vw) 0 min(9.375em, 19.5vw);
  background: #e9f0f9;
}
.tp-faq .tp-faq-list {
  max-width: 860px;
  margin: auto;
}
.tp-faq .tp-faq-list > div > dt {
  position: relative;
  padding: 1.21em 4em 1.21em min(5.44em, 18vw);
  font-size: 1.125em;
  font-weight: 700;
  color: #16417d;
  line-height: 1.5;
  background: #fff;
}
.tp-faq .tp-faq-list > div > dt::before {
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  height: 100%;
  width: min(2em, 12vw);
  font-size: min(2em, 12vw);
  background: #16417d;
}
.tp-faq .tp-faq-list > div > dt::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "Q";
  height: 100%;
  width: min(2em, 12vw);
  font-size: min(2em, 12vw);
  color: #fff;
  font-weight: 600;
  font-family: "Plus Jakarta Sans", sans-serif;
  text-align: center;
  padding-top: 0.15em;
}
@media (hover: hover) {
  .tp-faq .tp-faq-list > div > dt {
    -webkit-transition: color 0.3s;
    transition: color 0.3s;
    cursor: pointer;
  }
  .tp-faq .tp-faq-list > div > dt:hover {
    color: #5b92df;
  }
}
.tp-faq .tp-faq-list > div > dd {
  padding: 1.25em 3em 1.25em min(6.12em, 18vw);
  background: #fff;
  border-top: 6px solid #e9f0f9;
  position: relative;
  display: none;
}
.tp-faq .tp-faq-list > div > dd::after {
  position: absolute;
  left: 0;
  top: 0;
  content: "A";
  width: min(2em, 12vw);
  font-size: min(2em, 12vw);
  color: #5b92df;
  font-weight: 600;
  font-family: "Plus Jakarta Sans", sans-serif;
  text-align: center;
  padding-top: 0.25em;
}
.tp-faq .tp-faq-list > div + div {
  margin-top: 1.25em;
}
.tp-faq .tp-faq-list .icon-pm {
  display: inline-block;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  position: relative;
  width: 2.22em;
  height: 1em;
  position: absolute;
  right: 0;
  top: 1.4em;
}
.tp-faq .tp-faq-list .icon-pm:before, .tp-faq .tp-faq-list .icon-pm:after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1em;
  border-radius: 2px;
  height: 2px;
  background: #16417d;
}
.tp-faq .tp-faq-list .icon-pm:after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}
.tp-faq .tp-faq-list .icon-pm.open:after {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
.tp-faq .faq-detail dt {
  margin-top: 1em;
  font-weight: 700;
}
.tp-faq .faq-detail dd {
  padding-left: 1.25em;
  position: relative;
  line-height: 1.5;
}
.tp-faq .faq-detail dd::before {
  position: absolute;
  content: "・";
  left: 0.25em;
  top: 0.125em;
}
.tp-faq a {
  color: #16417d;
  text-decoration: underline;
}
@media (hover: hover) {
  .tp-faq a:hover, .tp-faq a:active {
    text-decoration: none;
  }
}

.tp-magazine {
  padding: min(9.375em, 19.5vw) 0 min(11.875em, 24.7vw) 0;
}

.l-footer {
  background: #fff;
}