@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;700;900&display=swap");

@keyframes fadeIn {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1 !important;
  }
}

@keyframes fadeLeft {
  0% {
    opacity: 0;
    transform: translateX(-20px);
  }

  100% {
    opacity: 1 !important;
    transform: translateX(0);
  }
}

@keyframes fadeRight {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }

  100% {
    opacity: 1 !important;
    transform: translateX(0);
  }
}

@keyframes fadeUp {
  0% {
    opacity: 0;
    transform: translateY(-20px);
  }

  100% {
    opacity: 1 !important;
    transform: translateY(0);
  }
}

@keyframes fadeBottom {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }

  100% {
    opacity: 1 !important;
    transform: translateY(0);
  }
}

@keyframes active_menu {
  from {
    top: -200vh;
  }

  to {
    top: 0;
  }
}

@keyframes hidden_menu {
  from {
    top: 0;
  }

  to {
    top: -200vh;
  }
}

.anim {
  opacity: 0;
}

.fadeIn {
  animation: fadeIn 1s ease-in 0s 1 normal backwards;
}

.fadeLeft {
  animation: fadeLeft 1s ease-in 0s 1 normal backwards;
}

.fadeRight {
  animation: fadeRight 1s ease-in 0s 1 normal backwards;
}

.fadeUp {
  animation: fadeUp 1s ease-in 0s 1 normal backwards;
}

.fadeBottom {
  animation: fadeBottom 1s ease-in 0s 1 normal backwards;
}

.testcontainer {
  container: my-container/inline-size;
}

/*
-- margin-top（ボタン直前）
   ・PC：100px  /  ・SP：35px
*/
/*
-- ボタンリンクの設定
*/
/*
header#Main {
  display: none !important;
}

.topicPath {
  display: none !important;
}*/
/*
main {
  padding-top: 0px !important;
}
*/
.twpr2504 .wrapper {
  background: #f5f5f5;
}

#works {
  background: #1B1B1B;
}

.appeal__list {
  margin-bottom: 75px !important;
}

.appeal__item {
  padding-left: 49px !important;
  margin-bottom: 20px !important;
}

@media (max-width: 790px) {
  .appeal__item {
    padding-left: 30px !important;
  }
}

html,
body,
main,
header,
footer {
  overflow-x: hidden !important;
}

main {
  background: #f5f5f5;
}

ul.category-list li a {
  height: 100% !important;
}

.footer_inner .banner-area img {
  max-width: 220px;
}

.v3_lineup_index_box_sp {
  background: #1d324c;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 790px) {
  /*
  .sp_header,
  .sp_short_cut,
  .sp_menu_btn {
    display: none;
  }*/
}

.twpr2504 {
  /* margin-top: 100dvh;*/
  font-family: "Noto Sans JP", system-ui;
}

.twpr2504 .sp-only {
  display: none;
}

@media (max-width: 790px) {
  .twpr2504 .sp-only {
    display: block;
  }
}

.twpr2504 .sps-only {
  display: none;
}

@media (max-width: 480px) {
  .twpr2504 .sps-only {
    display: block;
  }
}

.twpr2504 .pc-only {
  display: block;
}

@media (max-width: 790px) {
  .twpr2504 .pc-only {
    display: none;
  }
}

.twpr2504 ul,
.twpr2504 ol,
.twpr2504 li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.twpr2504 img {
  max-width: 100%;
}

.twpr2504 .break__link--contact {
  background: rgb(240, 128, 1);
  background: linear-gradient(90deg, rgb(240, 128, 1) 0%, rgb(218, 35, 1) 100%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.twpr2504 .break__link--contact:after {
  position: absolute;
  right: 5%;
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url(../img/footer-arrow.png) no-repeat center/contain;
}

.twpr2504 .twpr2504_inner {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
}

@media (max-width: 790px) {
  .twpr2504 .twpr2504_inner {
    padding-left: 5%;
    padding-right: 5%;
  }
}

.twpr2504 .cross {
  font-size: 8px !important;
}

@media (max-width: 790px) {
  .twpr2504 article {
    padding-left: 5%;
    padding-right: 5%;
  }
}

.twpr2504 #twpr2504_kv {
  transition: 1.5s;
  background: rgb(29, 32, 137);
  position: fixed;
  left: 0;
  top: 0;
  width: 100dvw;
  opacity: 1;
  z-index: 5000;
}

.twpr2504 #twpr2504_kv article {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  min-height: 100dvh;
}

.twpr2504 #twpr2504_kv article h1 {
  max-width: 625px;
  margin-bottom: 55px !important;
}

.twpr2504 #twpr2504_kv article .logo_white {
  max-width: 410px;
  margin-bottom: 85px !important;
}

.twpr2504 #twpr2504_kv article .btn_scroll {
  position: absolute;
  bottom: 2%;
  max-width: 80px;
}

.twpr2504 #twpr2504_kv article h1,
.twpr2504 #twpr2504_kv article .logo_white,
.twpr2504 #twpr2504_kv article .btn_scroll {
  opacity: 0;
  transition: opacity 1s ease;
}

.twpr2504 #twpr2504_kv article h1.show {
  opacity: 1;
  transition-duration: 1s;
}

.twpr2504 #twpr2504_kv article .logo_white.show {
  opacity: 1;
  transition-duration: 0.5s;
}

.twpr2504 #twpr2504_kv article .btn_scroll.show {
  opacity: 1;
  transition-duration: 0.5s;
}

.twpr2504 .twpr2504_nav {
  position: absolute;
  width: 100dvw;
  z-index: 3500;
  line-height: 1;
  background: url(../img/nav_bg.png) no-repeat center bottom/contain;
}

@media (max-width: 790px) {
  .twpr2504 .twpr2504_nav {
    display: none;
  }
}

.twpr2504 .twpr2504_nav ul {
  line-height: 1;
  padding-bottom: 40px !important;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (max-width: 1079px) {
  .twpr2504 .twpr2504_nav ul {
    padding-bottom: 30px !important;
  }
}

.twpr2504 .twpr2504_nav ul li a {
  color: rgb(51, 51, 51);
  font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
  font-weight: 400;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 30px !important;
  padding-bottom: 30px !important;
}

.twpr2504 .twpr2504_nav ul li a span {
  border-right: 1px solid rgb(85, 85, 85);
  display: flex;
  justify-content: center;
  padding: 0 50px;
  white-space: nowrap;
  letter-spacing: 0.2em;
}

.twpr2504 .twpr2504_nav ul li:nth-of-type(1) a span {
  border-left: 1px solid rgb(85, 85, 85);
}

.twpr2504 #twpr2504_about {
  position: relative;
  padding-top: 180px !important;
  margin-top: -180px;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about {
    padding-top: 0px !important;
    padding-bottom: 5px !important;
    margin-top: 0;
  }
}

.twpr2504 #twpr2504_about:before,
.twpr2504 #twpr2504_about:after {
  content: "";
  display: block;
  width: 22%;
  height: 100%;
  position: absolute;
  top: 10%;
}

@media (max-width: 1079px) {

  .twpr2504 #twpr2504_about:before,
  .twpr2504 #twpr2504_about:after {
    position: absolute;
    width: 100dvw;
  }
}

.twpr2504 #twpr2504_about:before {
  left: 0;
  background: url(../img/about_bg-l.png) no-repeat left center/contain;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about:before {
    top: 4%;
    height: 15%;
    background: url(../img/about_bg-l_sp.png) no-repeat center 0/contain;
  }
}

.twpr2504 #twpr2504_about:after {
  right: 0;
  background: url(../img/about_bg-r.png) no-repeat right center/contain;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about:after {
    top: auto;
    bottom: 0;
    height: 15%;
    background: url(../img/about_bg-r_sp.png) no-repeat center bottom/contain;
  }
}

.twpr2504 #twpr2504_about article {
  display: flex;
  justify-content: center;
}

.twpr2504 #twpr2504_about article .about_wrapper {
  max-width: 700px;
  position: relative;
  z-index: 10;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about article .about_wrapper {
    padding-top: 35%;
    padding-bottom: 30%;
  }
}

.twpr2504 #twpr2504_about article .about_wrapper h1 {
  margin: auto;
  max-width: 485px;
  margin-bottom: 35px !important;
}

.twpr2504 #twpr2504_about article .about_wrapper p {
  font-size: clamp(1.8rem, 2.1555555556rem - 0.7407407407vw, 1.4rem);
  font-weight: 400;
  margin-bottom: 10px !important;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about article .about_wrapper h1 {
    max-width: 300px;
    margin: auto;
  }

  .twpr2504 #twpr2504_about article .about_wrapper p {
    font-size: clamp(1.4rem, 1.4rem + 0vw, 1.4rem);
  }

  .twpr2504 #twpr2504_about article .about_wrapper h1 {
    scroll-margin-top: 300px;
  }
}

.twpr2504 #twpr2504_about article .about_wrapper sup {
  font-size: clamp(0.8rem, 0.2666666667rem + 1.1111111111vw, 1.4rem);
  position: relative;
  top: -5px;
}

.twpr2504 #twpr2504_about article .about_wrapper span {
  font-size: clamp(1.1rem, 0.8333333333rem + 0.5555555556vw, 1.4rem);
}

.twpr2504 #twpr2504_movie {
  margin-top: 100px !important;
  background: rgb(29, 32, 137);
  position: relative;
  padding-top: 150px !important;
  padding-bottom: 150px !important;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_movie {
    margin-top: 50px !important;
  }
}

.twpr2504 #twpr2504_movie:before,
.twpr2504 #twpr2504_movie:after {
  content: "";
  display: block;
  width: 48%;
  height: 100%;
  max-width: 260px;
  position: absolute;
  top: 0;
}

@media (max-width: 1079px) {

  .twpr2504 #twpr2504_movie:before,
  .twpr2504 #twpr2504_movie:after {
    max-width: 150px;
  }
}

@media (max-width: 570px) {

  .twpr2504 #twpr2504_movie:before,
  .twpr2504 #twpr2504_movie:after {
    max-width: 90px;
  }
}

.twpr2504 #twpr2504_movie:before {
  left: 0;
  background: url(../img/movie_bg-l.png) repeat-y left 0/cover;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_movie:before {
    background: url(../img/movie_bg-l.png) repeat-y left 0/contain;
  }
}

.twpr2504 #twpr2504_movie:after {
  right: 0;
  background: url(../img/movie_bg-r.png) repeat-y right top/cover;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_movie:after {
    background: url(../img/movie_bg-r.png) repeat-y right 0/contain;
  }
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_movie {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_movie {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
}

.twpr2504 #twpr2504_movie article {
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 10;
}

.twpr2504 #twpr2504_movie article h1,
.twpr2504 #twpr2504_movie article h2,
.twpr2504 #twpr2504_movie article p,
.twpr2504 #twpr2504_movie article a {
  color: rgb(255, 255, 255);
}

.twpr2504 #twpr2504_movie article h1,
.twpr2504 #twpr2504_movie article h2 {
  letter-spacing: 0.1em;
}

.twpr2504 #twpr2504_movie article h1 {
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  font-size: clamp(6.6rem, 11.2222222222rem - 9.6296296296vw, 1.4rem);
  margin-bottom: 25px !important;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_movie article h1 {
    font-size: clamp(4.5rem, 7.2555555556rem - 5.7407407407vw, 1.4rem);
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_movie article h1 {
    font-size: clamp(2.8rem, 4.0444444444rem - 2.5925925926vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_movie article h2 {
  font-weight: 300;
  margin-bottom: 50px !important;
  font-size: clamp(2.2rem, 2.9111111111rem - 1.4814814815vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_movie article h2 {
    font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_movie .movie_wrapper {
  max-width: 80%;
  width: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
}

.twpr2504 #twpr2504_movie .movie_wrapper .modal__inner {
  /* flex-direction: column; */
  background: transparent;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data figure {
  display: flex;
  justify-content: center;
  align-items: center;
  /* flex-direction: column; 250526_縦表示の原因*/
  position: relative;
  overflow: hidden;
  max-width: 450px;
  width: 100%;
  margin: auto;
  cursor: pointer;
  background: rgb(0, 0, 0);
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data figure:before {
  content: "";
  position: absolute;
  width: 70px;
  height: 70px;
  z-index: 10;
  background: url(../img/ic-play.png) no-repeat center/contain;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data span {
  transition: 1s all;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data span img {
  transition: 1s all;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data span:hover {
  opacity: 0.75;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_data span:hover img {
  transform: scale(1.2, 1.2);
  transition: 1s all;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_wrap {
  /* 250526修正 */
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 60px;
}

.twpr2504 #twpr2504_movie .movie_wrapper .mov_wrap .mv_caption {
  color: rgb(255, 255, 255);
  margin-top: 10px !important;
  font-size: clamp(1.4rem, 1.4rem + 0vw, 1.4rem);
}

@media (max-width: 570px) {
  .twpr2504 #twpr2504_movie .movie_wrapper .mov_wrap .mv_caption {
    font-size: clamp(1rem, 0.6444444444rem + 0.7407407407vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_history {
  background: url(../img/history_bg.png) no-repeat center top/cover;
}

.twpr2504 #twpr2504_history article {
  position: relative;
  padding-top: 150px !important;
  padding-bottom: 150px !important;
  margin: auto;
  padding: 0 5%;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_history article {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }
}

.twpr2504 #twpr2504_history article h1 {
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  font-size: clamp(6.6rem, 11.2222222222rem - 9.6296296296vw, 1.4rem);
  margin-bottom: 25px !important;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_history article h1 {
    font-size: clamp(4.5rem, 7.2555555556rem - 5.7407407407vw, 1.4rem);
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_history article h1 {
    font-size: clamp(2.8rem, 4.0444444444rem - 2.5925925926vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_history article h2 {
  font-weight: 400;
  margin-bottom: 50px !important;
  font-size: clamp(2.2rem, 2.9111111111rem - 1.4814814815vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_history article h2 {
    font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_history article p {
  font-weight: 400;
  text-align: center;
  margin-bottom: 55px !important;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_history article .hisotory_images figure {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    white-space: nowrap;
  }

  .twpr2504 #twpr2504_history article .hisotory_images img {
    display: block;
    width: auto;
    height: 500px;
    max-width: unset;
  }
}

.twpr2504 #twpr2504_history article .btn_zoom {
  margin-top: 35px !important;
  display: flex;
  justify-content: center;
  align-items: center;
}

.twpr2504 #twpr2504_history article .btn_zoom a {
  text-decoration: none;
}

.twpr2504 #twpr2504_history article .btn_zoom span {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(90deg, #5C85E0 0%, #1D4AB0 100%);
  color: rgb(255, 255, 255);
  padding: 10px 15px 10px 30px;
}

.twpr2504 #twpr2504_history article .btn_zoom span:before {
  position: absolute;
  left: 10px;
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  background: url(../img/ic-zoom.png) no-repeat center/contain;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_history article .btn_zoom span {
    width: 100%;
    max-width: 240px;
    text-align: left;
  }
}

.twpr2504 #twpr2504_history article .btn_zoom br {
  display: none;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_history article .btn_zoom br {
    display: block;
  }
}

.twpr2504 #twpr2504_about-tw {
  background: url(../img/about-tw_bg.png) no-repeat right bottom/100%;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw {
    background: transparent;
  }
}

.twpr2504 #twpr2504_about-tw article {
  position: relative;
  padding-top: 150px !important;
}

@media (min-width: 1600px) {
  .twpr2504 #twpr2504_about-tw article {
    padding-bottom: 13.5% !important;
  }
}

@media (min-width: 1400px) {
  .twpr2504 #twpr2504_about-tw article {
    padding-bottom: 10% !important;
  }
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about-tw article {
    padding-top: 80px !important;
  }
}

.twpr2504 #twpr2504_about-tw article h1 {
  position: absolute;
  left: 6%;
  top: 10%;
  text-align: left;
  writing-mode: vertical-rl;
  font-size: clamp(1.4rem, 1.4rem + 0vw, 1.4rem);
  font-weight: 400;
  padding-left: 10px;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about-tw article h1 {
    top: 80px;
  }
}

.twpr2504 #twpr2504_about-tw article h1:before {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  left: 0;
  top: 0;
  height: 500px;
  background-image: linear-gradient(0deg, rgba(255, 255, 255, 0) 18%, rgba(0, 0, 0, 0.8));
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about-tw article h1 {
    left: 3%;
    height: 80%;
  }

  .twpr2504 #twpr2504_about-tw article h1:before {
    height: 100%;
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper {
  max-width: 70%;
  margin: auto;
  text-align: left;
  padding-bottom: 13.5%;
}

@media (max-width: 1399px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper {
    padding-bottom: 15%;
  }
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper {
    padding-bottom: 10%;
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper {
    max-width: 98%;
    padding-left: 10%;
    padding-bottom: 0;
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper h2 {
  margin-top: -10px;
  line-height: 1.8;
  margin-bottom: 45px !important;
  font-size: clamp(3rem, 4.4222222222rem - 2.962962963vw, 1.4rem);
  letter-spacing: 0.1em;
  font-weight: 500;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper h2 {
    font-size: clamp(2rem, 2.5333333333rem - 1.1111111111vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper h2 sup {
  position: relative;
  top: -10px;
  font-size: clamp(1.2rem, 1.0222222222rem + 0.3703703704vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper h2 sup {
    font-size: clamp(1rem, 0.6444444444rem + 0.7407407407vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit p {
  line-height: 1.8;
  font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
  margin-bottom: 10px !important;
  font-weight: 400;
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit p sup {
  font-size: clamp(1rem, 0.6444444444rem + 0.7407407407vw, 1.4rem);
  position: relative;
  top: -5px;
  margin: 0 5px;
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit .visible_text {
  max-width: 100%;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit .visible_text {
    max-width: 100%;
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit .unvisible_text {
  max-width: 60%;
  transition: 0.5s;
}

@media (max-width: 1099px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit .unvisible_text {
    max-width: 62%;
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit .unvisible_text {
    max-width: 100%;
    opacity: 0;
    visibility: hidden;
    display: none;
  }
}

.twpr2504 #twpr2504_about-tw article .about-tw_wrapper .text_unit ul li {
  font-size: clamp(1.1rem, 0.8333333333rem + 0.5555555556vw, 1.4rem);
  line-height: 2;
  font-weight: 400;
}

.twpr2504 #twpr2504_about-tw .btn_andmore {
  display: none !important;
}

@media (max-width: 790px) and (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw .btn_andmore {
    display: flex !important;
    justify-content: center;
    position: relative;
    z-index: 100;
    margin-top: 15px !important;
    margin-bottom: 45px !important;
  }

  .twpr2504 #twpr2504_about-tw .btn_andmore span {
    border: 1px solid #d9d9da;
    background: rgb(255, 255, 255);
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 300px;
    height: 65px;
    font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
    font-weight: 400;
    color: #2F4DA4;
  }

  .twpr2504 #twpr2504_about-tw .btn_andmore span:after {
    position: absolute;
    right: 5%;
    content: "";
    display: block;
    width: 13px;
    height: 12px;
    transform: rotate(180deg);
    background: url(../img/ic-arrow.svg) no-repeat center/contain;
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_about-tw .close {
    display: none !important;
  }

  .twpr2504 #twpr2504_about-tw .close span:after {
    transform: rotate(0) !important;
  }

  .twpr2504 #twpr2504_about-tw.active {
    position: relative;
    background: url(../img/about-tw_bg_sp.png) no-repeat right 93%/contain;
  }

  .twpr2504 #twpr2504_about-tw.active:after {
    position: absolute;
    bottom: 0;
    content: "";
    display: block;
    width: 100%;
    height: 120px;
    background-image: linear-gradient(180deg, rgba(255, 255, 255, 0), rgb(245, 245, 245) 20%);
  }

  .twpr2504 #twpr2504_about-tw.active .about-tw_wrapper {
    padding-bottom: 110%;
  }

  .twpr2504 #twpr2504_about-tw.active .about-tw_wrapper .text_unit .unvisible_text {
    opacity: 1;
    display: block;
    visibility: visible;
  }

  .twpr2504 #twpr2504_about-tw.active .btn_andmore {
    display: none !important;
  }

  .twpr2504 #twpr2504_about-tw.active .close {
    display: flex !important;
    justify-content: center;
  }
}

.twpr2504 #twpr2504_strengths {
  background: rgb(29, 32, 137);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article {
    padding: 0;
  }
}

.twpr2504 #twpr2504_strengths article h1 {
  position: relative;
  display: flex;
  align-items: center;
  overflow-x: hidden;
}

.twpr2504 #twpr2504_strengths article h1:before {
  white-space: nowrap;
  content: "STRENGTH";
  font-family: "Roboto", sans-serif;
  font-weight: 300;
  text-transform: uppercase;
  color: #35368e;
  font-size: clamp(33rem, 61.0888888889rem - 58.5185185185vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article h1:before {
    font-size: clamp(17rem, 30.8666666667rem - 28.8888888889vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_strengths article h1 span {
  position: absolute;
  left: 8%;
  display: inline-block;
  color: rgb(255, 255, 255);
  background: #0e1075;
  font-weight: 500;
  padding: 10px 20px;
  font-size: clamp(4.2rem, 6.6888888889rem - 5.1851851852vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article h1 span {
    left: 0;
    font-size: clamp(2.6rem, 3.6666666667rem - 2.2222222222vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_strengths article .detail_head {
  background: url(../img/strengths_bg.png) no-repeat center/cover;
}

.twpr2504 #twpr2504_strengths article .detail_head .sp_disp {
  display: none;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_head .sp_disp {
    display: block;
  }
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap {
  width: 35%;
  margin: auto;
  min-height: 500px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 350px;
}

@media (max-width: 1079px) {
  .twpr2504 #twpr2504_strengths article .detail_head .head_wrap {
    width: 45%;
  }
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_head .head_wrap {
    width: auto;
    min-width: 300px;
    min-height: auto;
    padding: 10%;
  }
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 span,
.twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 strong {
  display: block;
  color: #0e1075;
  font-weight: 500;
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 strong {
  font-size: clamp(8.4rem, 14.6222222222rem - 12.962962963vw, 1.4rem);
  margin-bottom: 10px !important;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 strong {
    font-size: clamp(5rem, 8.2rem - 6.6666666667vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 span {
  font-size: clamp(2.6rem, 3.6666666667rem - 2.2222222222vw, 1.4rem);
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_head .head_wrap h2 span {
    font-size: clamp(2rem, 2.5333333333rem - 1.1111111111vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap p {
  color: #0e1075;
  text-align: left;
  font-weight: 400;
}

.twpr2504 #twpr2504_strengths article .detail_head .head_wrap p.mini {
  text-align: right;
  font-size: clamp(1rem, 0.6444444444rem + 0.7407407407vw, 1.4rem);
}

.twpr2504 #twpr2504_strengths article .detail_body {
  padding: 25px 5% 100px;
  display: flex;
  /*justify-content: space-between;*/
  justify-content: center;
  /* gap: 25px;*/
}

.twpr2504 #twpr2504_strengths article .detail_body .detail_unit {
  /* width: 50%;*/
  width: 46%;
  min-width: 550px;
  color: rgb(255, 255, 255);
  background: #060861;

}

.twpr2504 #twpr2504_strengths article .detail_body .detail_unit dl {
  padding: 25px 25px 45px;
  text-align: left;
}

.twpr2504 #twpr2504_strengths article .detail_body .detail_unit dl dt {
  font-size: clamp(2.6rem, 3.6666666667rem - 2.2222222222vw, 1.4rem);
  font-weight: 500;
  margin-bottom: 25px !important;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_body .detail_unit dl dt {
    font-size: clamp(2rem, 2.5333333333rem - 1.1111111111vw, 1.4rem);
  }
}

.twpr2504 #twpr2504_strengths article .detail_body .detail_unit dl dd {
  font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
  font-weight: 400;
  line-height: 1.8;
}

@media (max-width: 790px) {
  .twpr2504 #twpr2504_strengths article .detail_body .detail_unit dl dd {
    font-size: clamp(1.4rem, 1.4rem + 0vw, 1.4rem);
  }
}

@media (max-width: 570px) {
  .twpr2504 #twpr2504_strengths article .detail_body {
    flex-direction: column-reverse;
  }

  .twpr2504 #twpr2504_strengths article .detail_body .detail_unit {
    /*add*/
    min-width: auto;

    width: 100%;
  }
}

.hidden #twpr2504_kv {
  left: 0;
  top: 0;
  width: 100dvw;
  transition: 1.5s;
  opacity: 0;
  z-index: -10;
}

.works__slick {
  width: 100%;
  max-width: 100%;
  display: flex;
  justify-content: center;
}

.works__slick .slick-dots {
  left: auto;
}

.works__slick .slick-dots li {
  width: 20%;
}

.modal__inner {
  display: flex;
  align-items: center;
}

@media (max-width: 790px) {
  .modal__inner {
    overflow: hidden;
    overflow-x: scroll;
  }
}

.pc_disp {
  display: block;
}

@media (max-width: 480px) {
  .pc_disp {
    display: none;
  }
}

.sp_disp {
  display: none;
}

@media (max-width: 480px) {
  .sp_disp {
    display: block;
  }
}

.fixed_item {
  position: fixed;
  right: 0;
  bottom: 1%;
  z-index: 10;
  max-width: 254px;
  opacity: 0;
  display: block;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.fixed_item a:hover {
  opacity: 0.85;
}

@media (max-width: 480px) {
  .fixed_item {
    max-width: 214px;
  }
}

.fixed_item.fixed {
  opacity: 1 !important;
  z-index: 10;
  pointer-events: auto;
  transition: opacity 0.3s ease;
}

.fixed_item.fixed.none {
  opacity: 0 !important;
  cursor: default;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.youtube_frame {
  aspect-ratio: 16/9;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.youtube_frame iframe {
  position: absolute !important;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}

#lp_spnav {
  display: none;
}

@media (max-width: 790px) {
  #lp_spnav {
    display: block;
    position: fixed;
    z-index: 15000;
    width: 100%;
  }

  #lp_spnav .menu-trigger,
  #lp_spnav .menu-trigger span {
    display: inline-block;
    transition: all 0.4s;
    box-sizing: border-box;
  }

  #lp_spnav .menu-trigger {
    background: #0e1075;
    width: 60px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 10;
    cursor: pointer;
  }

  #lp_spnav .menu-trigger span {
    position: absolute;
    display: block;
    width: 26px;
    height: 2px;
    border-radius: 4px;
    background: rgb(255, 255, 255);
    transition: all 0.2s 0s ease;
  }

  #lp_spnav .menu-trigger span:nth-of-type(1) {
    top: 21px;
  }

  #lp_spnav .menu-trigger span:nth-of-type(3) {
    top: 37px;
  }

  #lp_spnav .menu-trigger.active {
    background: transparent;
  }

  #lp_spnav .menu-trigger.active span {
    background: #0e1075;
  }

  #lp_spnav .menu-trigger.active span:nth-of-type(1) {
    transform: translateY(0) rotate(-318deg);
    top: 26px;
  }

  #lp_spnav .menu-trigger.active span:nth-of-type(2) {
    opacity: 0;
  }

  #lp_spnav .menu-trigger.active span:nth-of-type(3) {
    transform: translateY(0) rotate(318deg);
    top: 27px;
  }

  #lp_spnav .lp_spnav_wrap {
    position: fixed;
    z-index: 1;
    background: rgb(255, 255, 255);
    top: -200dvh;
    opacity: 0;
    visibility: hidden;
    width: 100dvw;
    padding: 15px 10% 0;
    transition: 1s;
  }

  #lp_spnav .lp_spnav_wrap.active {
    opacity: 1;
    visibility: visible;
    top: 0;
  }

  #lp_spnav .lp_spnav_wrap h1 {
    position: absolute;
    left: 3%;
    text-align: left;
    font-size: clamp(1.4rem, 1.4rem + 0vw, 1.4rem);
  }

  #lp_spnav .lp_spnav_wrap ul {
    margin: 10dvh auto;
    max-width: 70%;
    border-top: 1px solid #E1DEDE;
  }
}

@media (max-width: 790px) and (max-width: 570px) {
  #lp_spnav .lp_spnav_wrap ul {
    max-width: 270px;
  }
}

@media (max-width: 790px) {
  #lp_spnav .lp_spnav_wrap ul li {
    font-size: clamp(1.6rem, 1.7777777778rem - 0.3703703704vw, 1.4rem);
    font-weight: 300;
    text-align: left;
    color: rgb(51, 51, 51);
    border-bottom: 1px solid #E1DEDE;
  }

  #lp_spnav .lp_spnav_wrap ul li a {
    position: relative;
    display: flex;
    align-items: center;
    padding: 20px;
    color: rgb(51, 51, 51);
    font-weight: 400;
  }

  #lp_spnav .lp_spnav_wrap ul li a:after {
    content: "";
    display: block;
    position: absolute;
    right: 15px;
    width: 15px;
    height: 15px;
    background: url(../img/arrow-bottom.svg) no-repeat center/contain;
  }
}

/*# sourceMappingURL=style.css.map */