@charset "UTF-8";
/*
Theme Name: S.CO-nnection Corporate 2026
Description: 株式会社S.CO-nnection 2026年Ver
Version: 3.0.3
*/
@media (min-width: 600px) {
  .br-sp {
    display: none;
  }
}
html {
  scroll-behavior: smooth;
  height: 100%;
  margin-top: 0 !important;
  font-size: 1.3888888889vw;
}

html::-webkit-scrollbar {
  display: none;
}

img {
  height: auto;
}

a {
  color: #000;
  /* 初期状態でリンクの色を明示的に設定 */
  text-decoration: none;
  transition: color 0.4s ease;
}

a:hover {
  color: #28A7E1 !important;
  /* ホバー時に色を変更 */
}

#wpadminbar {
  position: fixed !important;
}

/* ////////////////////// 基本 ///////////////////////// */
body :root {
  --scrollbar: 0;
}
body {
  height: calc(var(--vh, 1vh) * 100);
  width: calc(100vw - var(--scrollbar));
}

main {
  display: flex;
  flex-flow: column;
  align-items: center;
  text-align: center;
  font-family: "Yu Gothic", sans-serif;
  font-weight: 100;
  background: radial-gradient(50% 50% at 50% 50%, #F8FEFF 50.48%, #EBFCFF 100%);
}

.pc {
  display: flex !important;
}
@media (max-width: 600px) {
  .pc {
    display: none !important;
  }
}

.sp {
  display: none !important;
}
@media (max-width: 600px) {
  .sp {
    display: flex !important;
  }
}

/* ////////////////////// TOPページ ///////////////////////// */
header {
  z-index: 2;
  position: fixed;
  padding-top: 4.8828125vh;
  width: 100vw;
  display: flex;
  justify-content: space-between;
  padding-left: 3.4722222222vw;
  padding-right: 3.4722222222vw;
}
@media (max-width: 600px) {
  header {
    align-items: center;
    padding-top: 5.2083333333vh;
    width: 100vw;
    padding-left: 2.0833333333vh;
    padding-right: 2.0833333333vh;
  }
}
header.fixed-header {
  top: 0;
  z-index: 3;
}
header .company-logo {
  display: flex;
  flex-flow: column;
  justify-content: center;
}
header .company-logo a img {
  width: 13.9583333333vw;
}
@media (max-width: 600px) {
  header .company-logo a img {
    width: 48vw;
  }
}
header nav {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.0972222222vw;
  height: 3.4722222222vw;
}
header nav ul.navigation-menu {
  font-family: "Chillax", sans-serif;
  font-weight: 500;
  display: flex;
  align-items: center;
  transition: opacity 0.6s ease;
}
header nav ul.navigation-menu li {
  position: relative;
}
header nav ul.navigation-menu li a {
  display: flex;
  align-items: anchor-center;
  color: #000;
  padding: 0.6944444444vw 1.953125vh;
}
header nav ul.navigation-menu li a::after {
  position: absolute;
  left: 10%;
  content: "";
  width: 80%;
  height: 0.09765625vh;
  background: #000;
  bottom: -0.78125vh;
  transform: scaleX(0);
  transform-origin: right center;
  transition: transform 0.3s ease;
  will-change: transform;
  backface-visibility: hidden;
  transform-style: preserve-3d;
  /* ↓補完用の奥行きトリックでアンチエイリアスを抑える */
  transform: scaleX(0) translateZ(0);
}
header nav ul.navigation-menu li a:hover::after {
  transform: scaleX(1) translateZ(0);
  transform-origin: left center;
}
header nav ul.navigation-menu li img {
  position: absolute;
  left: 2.7777777778vw;
  bottom: 4.1015625vh;
  max-width: 6.8055555556vw;
}
header nav ul.navigation-menu li .a-gelpoint_bk {
  position: static;
  width: 1.3888888889vw;
  margin-right: 0.2777777778vw;
}
header nav ul.navigation-menu .is-current a {
  color: var(--CPC_c, #004185);
}
header nav a.contact-button {
  margin-left: 1.3888888889vw;
  font-family: "Chillax", sans-serif;
  font-weight: 500;
  display: flex;
  padding: 1.0416666667vw 2.9296875vh;
  justify-content: center;
  align-items: center;
  gap: 0.6944444444vw;
  color: #004185;
  border-radius: 69.4444444444vw;
  border: 0.0694444444vw solid #004185;
  background: #FFF;
  position: relative;
  overflow: hidden;
  transition: all 0.2s ease-in;
}
header nav a.contact-button:hover {
  color: #fff;
  background: #28A7E1;
  transition: all 0.2s ease-out;
  border: 0.0694444444vw solid #28A7E1;
  color: #fff !important;
}
header nav a.contact-button:hover::before {
  animation: light 0.5s 0s linear;
}
header nav a.contact-button::before {
  content: "";
  display: block;
  width: 0px;
  height: 86%;
  position: absolute;
  top: 7%;
  left: 0%;
  opacity: 0;
  background: #fff;
  box-shadow: 0 0 50px 30px #fff;
  transform: skewX(-20deg);
}
@keyframes light {
  from {
    opacity: 0;
    left: 0%;
  }
  50% {
    opacity: 1;
  }
  to {
    opacity: 0;
    left: 100%;
  }
}
header nav {
  /******* ハンバーガーメニュー設定 *******/
}
header nav .hamburger-menu {
  margin-left: 0.6944444444vw;
}
header nav .hamburger-menu .menu-btn {
  border-radius: 69.4444444444vw;
  background: #004185;
  border: 1px solid #004185;
  padding: 1.6666666667vw 2.9296875vh;
  position: relative;
  display: flex;
  width: 5.5555555556vw;
  justify-content: center;
  z-index: 4;
  cursor: pointer;
  background-color: #004185;
  transition: all 0.4s ease;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-btn {
    padding: 5.3333333333vw 4.4613333333vw;
    height: 11.7333333333vw;
    width: 11.7333333333vw;
  }
}
header nav .hamburger-menu .menu-btn span,
header nav .hamburger-menu .menu-btn span::before,
header nav .hamburger-menu .menu-btn span::after {
  content: "";
  display: block;
  height: 0.146484375vh;
  width: 1.5972222222vw;
  background-color: #fff;
  position: absolute;
  transition: all 0.4s ease;
  /* スムーズなアニメーション */
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-btn span,
  header nav .hamburger-menu .menu-btn span::before,
  header nav .hamburger-menu .menu-btn span::after {
    height: 0.1302083333vh;
    width: 2.0833333333vh;
  }
}
header nav .hamburger-menu .menu-btn span::before {
  bottom: 0.68359375vh;
  transition: all 0.4s ease;
  /* 上線のアニメーション */
}
header nav .hamburger-menu .menu-btn span::after {
  top: 0.703125vh;
  transition: all 0.4s ease;
  /* 下線のアニメーション */
}
header nav .hamburger-menu #menu-btn-check:checked ~ .menu-btn {
  background-color: #004185;
  /* メニューが開いたときの背景色 */
}
header nav .hamburger-menu #menu-btn-check:checked ~ .menu-btn span {
  transform: rotate(45deg);
  background-color: #fff;
  /* 線の色を変更してX形にする */
}
header nav .hamburger-menu #menu-btn-check:checked ~ .menu-btn span::before {
  bottom: 0;
  transform: rotate(90deg);
  background-color: #fff;
  /* 上線を回転させてX形を形成 */
}
header nav .hamburger-menu #menu-btn-check:checked ~ .menu-btn span::after {
  top: 0;
  transform: rotate(-90deg);
  background-color: #fff;
  /* 下線を回転させてX形を形成 */
}
header nav .hamburger-menu #menu-btn-check {
  display: none;
}
header nav .hamburger-menu .menu-content {
  height: 100vh;
  position: fixed;
  top: 0;
  left: 100%;
  z-index: 3;
  transition: all 0.5s;
  background: url(../img/logo-container_img_a.webp) lightgray 50%/cover no-repeat;
  backdrop-filter: blur(1.7361111111vw);
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content {
    backdrop-filter: blur(6.6666666667vw);
    background: url(../img/SP_menu.webp) lightgray 50%/cover no-repeat;
    background-position: top center;
    background-size: 100% auto;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame {
  width: 100vw;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  padding-right: 16.5277777778vw;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame {
    height: 100vh;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame {
  /* イメージ画像 */
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-image {
  max-height: 56.0546875vh;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-image__img {
  width: 48.8888888889vw;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design {
  display: flex;
  flex-flow: column;
  align-items: center;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design {
    width: 91.4666666667vw;
    align-items: start;
    padding-left: 13.3333333333vw;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design {
  /* ロゴ(画像) */
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .logo-container__img {
  width: 19.4444444444vw;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .logo-container__img {
    width: 48vw;
    padding-top: 11.2vw;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu-box {
  display: flex;
  flex-flow: column;
  align-items: start;
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu {
  padding-top: 7.8125vh;
  padding-bottom: 3.90625vh;
  display: flex;
  flex-flow: column;
  align-items: start;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu {
    padding-left: 9.0666666667vw;
    padding-top: 16vw;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu__item a {
  color: #fff;
  font-family: "Chillax", sans-serif;
  font-size: 2.9296875vh;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  text-transform: uppercase;
  padding: 0.9765625vh 0;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu__item a {
    font-size: 8vw;
  }
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .navigation-menu__item a::after {
  position: absolute;
  left: 0;
  content: "";
  width: 0;
  height: 0.09765625vh;
  background: #000;
  bottom: -0.09765625vh;
  transform: scale(0, 1);
  transform-origin: right top;
  /*変形（アンダーラインの伸長）の原点がaタグ（各メニュー）の右端*/
  transition: transform 0.3s;
  /*変形の時間*/
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design {
  /* 個人情報保護方針 */
}
header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .privacy-policy-link {
  color: #fff;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.26953125vh;
  font-style: normal;
  font-weight: 400;
  line-height: 2.5390625vh;
  letter-spacing: 0.126953125vh;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  header nav .hamburger-menu .menu-content .menu-container .menu-frame .menu-right-design .privacy-policy-link {
    font-size: 3.4666666667vw;
    padding-top: 13.3333333333vw;
    padding-left: 9.0666666667vw;
  }
}
header nav .hamburger-menu #menu-btn-check:checked ~ .menu-content {
  left: 0;
  /* メニューを画面内へ */
}
header nav {
  /******* ハンバーガーメニュー設定 *******/
}

/******* ▲▲▲ ここまでTOPビュー ▲▲▲ *******/
.bg-logo-wrapper {
  top: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  pointer-events: none;
  overflow: hidden;
}
@media (max-width: 600px) {
  .bg-logo-wrapper {
    position: relative;
    height: 120vh;
  }
}
.bg-logo-wrapper .bg-logo-inner,
.bg-logo-wrapper .bg-logo-inner-a {
  position: absolute;
  top: 30%;
  right: 10%;
}
@media (max-width: 600px) {
  .bg-logo-wrapper .bg-logo-inner,
  .bg-logo-wrapper .bg-logo-inner-a {
    width: 100vw;
    top: 12%;
    overflow: hidden;
    left: 10%;
  }
}
.bg-logo-wrapper .bg-logo-inner svg,
.bg-logo-wrapper .bg-logo-inner-a svg {
  width: 47.2222222222vw;
  display: block;
}
@media (max-width: 600px) {
  .bg-logo-wrapper .bg-logo-inner svg,
  .bg-logo-wrapper .bg-logo-inner-a svg {
    max-width: none;
    width: 141.8666666667vw;
  }
}
.bg-logo-wrapper .bg-logo-inner svg path,
.bg-logo-wrapper .bg-logo-inner-a svg path {
  opacity: 0;
}
.bg-logo-wrapper .bg-logo-inner {
  filter: drop-shadow(0 4px 4px rgba(0, 0, 0, 0.25));
  opacity: 0.4;
}
.bg-logo-wrapper .bg-logo-inner-a {
  filter: blur(11.1111111111vw);
}
.bg-logo-wrapper .bg-logo-inner-sp {
  position: absolute;
  top: 30%;
  right: 30%;
}
@media (max-width: 600px) {
  .bg-logo-wrapper .bg-logo-inner-sp {
    width: 100vw;
    top: 10%;
    overflow: hidden;
    left: 6%;
  }
}
.bg-logo-wrapper .bg-logo-inner-sp img {
  width: 47.2222222222vw;
  display: block;
}
@media (max-width: 600px) {
  .bg-logo-wrapper .bg-logo-inner-sp img {
    max-width: none;
    width: 155.2vw;
    opacity: 0.4;
  }
}
.bg-logo-wrapper .bg-logo-inner-sp img path {
  opacity: 0;
}

@keyframes fadeInUp {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.main-logo-area {
  position: absolute;
  top: 19.7916666667vw;
  left: 13.8888888889vw;
  width: 34.7222222222vw;
  z-index: 1;
}
.main-logo-area svg path {
  opacity: 0;
}
@media (max-width: 600px) {
  .main-logo-area {
    width: 68vw;
    top: 60.5333333333vw;
    left: 9.0277777778vw;
  }
}

@keyframes richFadeInUp {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes richFadeIn {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
.fv-text-container {
  position: absolute;
  top: 27.7777777778vw;
  left: 13.8888888889vw;
  z-index: 1;
  color: #001f49;
  font-feature-settings: "palt";
  text-align: start;
  font-family: "YuGothic", sans-serif;
}
@media (max-width: 600px) {
  .fv-text-container {
    top: 78.6666666667vw;
    left: 9.0277777778vw;
  }
}
.fv-text-container .fv-main-copy {
  font-size: 2.3611111111vw;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: 0.03em;
  margin-bottom: 2.7777777778vw;
}
@media (max-width: 600px) {
  .fv-text-container .fv-main-copy {
    font-size: 5.3333333333vw;
  }
}
.fv-text-container .fv-sub-lead {
  font-size: 1.1111111111vw;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-bottom: 2.7777777778vw;
}
@media (max-width: 600px) {
  .fv-text-container .fv-sub-lead {
    font-size: 4.5333333333vw;
    margin-bottom: 5.3333333333vw;
  }
}
.fv-text-container .fv-description-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.fv-text-container .fv-description-list li {
  font-size: 0.9722222222vw;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.02em;
  color: rgba(0, 31, 73, 0.85);
}
@media (max-width: 600px) {
  .fv-text-container .fv-description-list li {
    font-size: 3.7333333333vw;
  }
}

.scroll-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  padding: 20px;
  cursor: pointer;
  animation: float 3s ease-in-out infinite;
  transition: opacity 0.3s ease;
  position: absolute;
  top: 77vh;
  left: 1.3888888889vw;
  cursor: pointer;
}
@media (max-width: 600px) {
  .scroll-indicator {
    left: 3.7333333333vw;
  }
}
.scroll-indicator:hover {
  opacity: 0.7;
}
.scroll-indicator .scroll-text {
  writing-mode: vertical-rl;
  font-family: "Chillax", sans-serif;
  color: #0a1f5c;
  font-size: 0.9722222222vw;
  font-weight: 300;
  letter-spacing: 0.3em;
  margin-bottom: 20px;
}
@media (max-width: 600px) {
  .scroll-indicator .scroll-text {
    font-size: 3.2vw;
  }
}
.scroll-indicator .scroll-lines {
  display: flex;
  flex-direction: column;
  gap: 0.5555555556vw;
}
@media (max-width: 600px) {
  .scroll-indicator .scroll-lines {
    gap: 2.6666666667vw;
  }
}
.scroll-indicator .scroll-lines .line {
  width: 0.5555555556vw;
  height: 0.1388888889vw;
  border-radius: 1.5px;
  opacity: 0.2;
  animation: cascadeDown 1.5s ease-in-out infinite;
}
@media (max-width: 600px) {
  .scroll-indicator .scroll-lines .line {
    width: 2.1333333333vw;
    height: 0.5333333333vw;
  }
}
.scroll-indicator .scroll-lines .line.line-dark {
  background-color: #0a1f5c;
}
.scroll-indicator .scroll-lines .line.line-light {
  background-color: #5ab1ce;
}
.scroll-indicator .scroll-lines .line:nth-child(1) {
  animation-delay: 0s;
}
.scroll-indicator .scroll-lines .line:nth-child(2) {
  animation-delay: 0.2s;
}
.scroll-indicator .scroll-lines .line:nth-child(3) {
  animation-delay: 0.4s;
}
.scroll-indicator .scroll-lines .line:nth-child(4) {
  animation-delay: 0.6s;
}
.scroll-indicator .scroll-lines .line:nth-child(5) {
  animation-delay: 0.8s;
}

@keyframes float {
  0% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(6px);
  }
  100% {
    transform: translateY(0px);
  }
}
@keyframes cascadeDown {
  0% {
    opacity: 0.2;
    transform: translateY(0);
  }
  30% {
    opacity: 1;
    transform: translateY(2px);
  }
  100% {
    opacity: 0.2;
    transform: translateY(0);
  }
}
.floating-badge {
  position: absolute;
  bottom: 3.4722222222vw;
  right: 3.4722222222vw;
  transition: transform 0.3s ease, filter 0.3s ease;
}
.floating-badge img {
  width: 6.25vw;
  height: auto;
  display: block;
}
@media (max-width: 600px) {
  .floating-badge img {
    width: 21.3333333333vw;
  }
}

.about-section {
  width: 100%;
  padding: 20.8333333333vw 0 0;
  box-sizing: border-box;
}
@media (max-width: 600px) {
  .about-section {
    padding: 0;
  }
}
.about-section .about-inner {
  text-align: start;
  display: flex;
  align-items: center;
  justify-content: start;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}
@media (max-width: 600px) {
  .about-section .about-inner {
    flex-flow: column;
    align-items: start;
  }
}
.about-section .about-image-area {
  width: 42.8472222222vw;
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .about-section .about-image-area {
    width: 96vw;
  }
}
.about-section .about-image-area img {
  width: 100%;
  height: auto;
  display: block;
}
.about-section .about-content-area {
  width: 36.1111111111vw;
  flex-shrink: 0;
  margin-left: 8.125vw;
}
@media (max-width: 600px) {
  .about-section .about-content-area {
    padding-top: 16vw;
    width: 90.6666666667vw;
    margin-left: 0;
    padding-left: 8vw;
  }
}
.about-section .about-label {
  display: block;
  font-family: "Chillax", sans-serif;
  font-size: 1.1111111111vw;
  letter-spacing: 0.1388888889vw;
  color: var(--CPC_a, #21B9D7);
  line-height: 1;
  margin-bottom: 1.6666666667vw;
}
@media (max-width: 600px) {
  .about-section .about-label {
    font-size: 3.2vw;
    margin-bottom: 5.3333333333vw;
  }
}
.about-section .about-title {
  font-family: "YuGothic", sans-serif;
  font-size: 1.8055555556vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  letter-spacing: 0.1388888889vw;
  margin-bottom: 2.2222222222vw;
}
@media (max-width: 600px) {
  .about-section .about-title {
    font-size: 5.3333333333vw;
    margin-bottom: 8vw;
  }
}
.about-section .about-text {
  font-family: "Yu Gothic", "YuGothic", sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 500;
  color: var(--text, #011E55);
  line-height: 1.7361111111vw;
  letter-spacing: 0.02em;
  text-align: justify;
}
@media (max-width: 600px) {
  .about-section .about-text {
    font-size: 3.7333333333vw;
    line-height: 6.6666666667vw;
    padding-bottom: 10.6666666667vw;
  }
}

.features-section {
  overflow: hidden;
  padding: 13.8888888889vw 0 17.3611111111vw;
  width: 100vw;
}
@media (max-width: 600px) {
  .features-section {
    padding-top: 34.6666666667vw;
    padding-bottom: 40vw;
  }
}
.features-section .features-content {
  display: flex;
  flex-direction: column;
  gap: 2.7777777778vw;
  padding: 0 1.3888888889vw;
}
@media (min-width: 1024px) {
  .features-section .features-content {
    flex-direction: row;
    padding-left: 13.8888888889vw;
    padding-right: 0;
    gap: 0;
  }
}
@media (max-width: 600px) {
  .features-section .features-content {
    padding: 8vw;
  }
}
.features-section .text-area {
  text-align: start;
  flex: 1;
}
@media (min-width: 1024px) {
  .features-section .text-area {
    flex: 0 0 35.1388888889vw;
    margin-right: 60px;
  }
}
.features-section .text-area .label {
  font-family: "Chillax", sans-serif;
  font-size: 1.1111111111vw;
  letter-spacing: 0.1388888889vw;
  color: var(--CPC_a, #21B9D7);
  display: block;
  margin-bottom: 16px;
}
@media (max-width: 600px) {
  .features-section .text-area .label {
    font-size: 3.2vw;
  }
}
.features-section .text-area h2 {
  font-family: "YuGothic", sans-serif;
  font-size: 1.8055555556vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  letter-spacing: 0.1388888889vw;
  margin-bottom: 24px;
}
@media (max-width: 600px) {
  .features-section .text-area h2 {
    font-size: 5.3333333333vw;
  }
}
.features-section .text-area .description {
  color: var(--text, #011E55);
  font-weight: 500;
  font-size: 0.9722222222vw;
  line-height: 1.8;
  margin-bottom: 2.7777777778vw;
  width: 28.9583333333vw;
}
@media (max-width: 600px) {
  .features-section .text-area .description {
    font-size: 3.7333333333vw;
    line-height: 6.6666666667vw;
    width: 85.3333333333vw;
  }
}
.features-section .text-area .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(90deg, #0a5b99, #29b6d8);
  color: #fff;
  text-decoration: none;
  padding: 18px 40px;
  font-size: 15px;
  font-weight: bold;
  transition: opacity 0.3s ease;
  width: 28.9583333333vw;
}
.features-section .text-area .btn:hover {
  opacity: 0.8;
}
.features-section .cards-area {
  flex: 1;
  min-width: 0;
  position: relative;
  width: 49.0277777778vw;
  margin-right: -20px;
}
@media (max-width: 600px) {
  .features-section .cards-area {
    width: 85.3333333333vw;
  }
}
.features-section .cards-area .cards-background {
  position: absolute;
  top: 80%;
  transform: translateY(-50%);
  left: 0;
  right: -100vw;
  height: 70%;
  background-color: #eaf3f8;
  z-index: 1;
}
.features-section .cards-area .cards-scroll {
  display: flex;
  gap: 2.0833333333vw;
  padding: 5.5555555556vw 0 0;
  overflow-x: auto;
  position: relative;
  z-index: 2;
  padding-left: 6.25vw;
}
@media (max-width: 600px) {
  .features-section .cards-area .cards-scroll {
    gap: 5.3333333333vw;
  }
}
.features-section .cards-area .cards-scroll::after {
  content: "";
  flex: 0 0 40px;
}
.features-section .cards-area .cards-scroll {
  scrollbar-width: none;
}
.features-section .cards-area .cards-scroll::-webkit-scrollbar {
  display: none;
}
.features-section .cards-area .cards-scroll .card {
  flex: 0 0 300px;
  background-color: #fff;
  padding: 5.5555555556vw 4.8611111111vw;
  box-shadow: 0 0.6944444444vw 2.0833333333vw rgba(0, 0, 0, 0.05);
  scroll-snap-align: start;
}
@media (max-width: 600px) {
  .features-section .cards-area .cards-scroll .card {
    flex: auto;
    padding: 10.6666666667vw 13.3333333333vw;
  }
}
.features-section .cards-area .cards-scroll .card .card-number {
  font-family: "Chillax", sans-serif;
  font-weight: 300;
  color: #5ab1ce;
  font-size: 1.1111111111vw;
  margin-bottom: 1.3888888889vw;
  position: absolute;
  bottom: 25vw;
}
@media (max-width: 600px) {
  .features-section .cards-area .cards-scroll .card .card-number {
    position: unset;
    font-size: 4.2666666667vw;
    text-align: start;
  }
}
.features-section .cards-area .cards-scroll .card .card-icon {
  width: 14.5833333333vw;
  height: 14.5833333333vw;
  background-color: #e0eff5;
  border-radius: 50%;
  margin: 0 auto 1.3888888889vw;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 600px) {
  .features-section .cards-area .cards-scroll .card .card-icon {
    width: 42.6666666667vw;
    height: 42.6666666667vw;
  }
}
.features-section .cards-area .cards-scroll .card .card-icon img {
  max-width: 60%;
  height: auto;
}
.features-section .cards-area .cards-scroll .card .card-text {
  font-family: "YuGothic", sans-serif;
  color: #0a1f5c;
  font-size: 1.1111111111vw;
  font-weight: 500;
  line-height: 1.6;
  text-align: center;
  margin: 0;
}
@media (max-width: 600px) {
  .features-section .cards-area .cards-scroll .card .card-text {
    font-size: 3.7333333333vw;
  }
}

.p-work {
  position: relative;
  width: 100%;
  padding-top: 5.5555555556vw;
  padding-bottom: 6.9444444444vw;
  overflow: hidden;
}
@media (max-width: 600px) {
  .p-work {
    padding-bottom: 0;
  }
}
.p-work::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 52vw;
  height: 36vw;
  background-color: #e6f3f7;
  z-index: 0;
}
@media (max-width: 600px) {
  .p-work::before {
    height: 55vh;
  }
}
.p-work__inner {
  position: relative;
  z-index: 1;
  width: 72.2222222222vw;
  margin-right: auto;
  margin-left: auto;
}
@media (max-width: 600px) {
  .p-work__inner {
    width: 85.3333333333vw;
  }
}
.p-work__header {
  text-align: start;
  margin-bottom: 3.6111111111vw;
}
@media (max-width: 600px) {
  .p-work__header {
    margin-bottom: 8vw;
    padding-top: 8vw;
  }
}
.p-work__sub-title {
  display: block;
  font-family: "Chillax", sans-serif;
  font-size: 1.1111111111vw;
  letter-spacing: 0.1388888889vw;
  color: var(--CPC_a, #21B9D7);
  margin-bottom: 2.7777777778vw;
}
@media (max-width: 600px) {
  .p-work__sub-title {
    font-size: 3.2vw;
    margin-bottom: 8vw;
  }
}
.p-work__title {
  font-family: "YuGothic", sans-serif;
  font-size: 1.8055555556vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  letter-spacing: 0.1388888889vw;
}
@media (max-width: 600px) {
  .p-work__title {
    font-size: 5.3333333333vw;
  }
}
.p-work__list {
  display: flex;
  flex-direction: column;
  gap: 0.6944444444vw;
}
@media (max-width: 600px) {
  .p-work__list {
    gap: 2.6666666667vw;
  }
}
.p-work__item {
  font-family: "YuGothic", sans-serif;
  display: flex;
  background-color: #ffffff;
  padding: 4.1666666667vw 5.5555555556vw;
  border-radius: 4px;
  box-shadow: 0.6944444444vw 2.0833333333vw 4.8611111111vw 0 rgba(194, 215, 219, 0.25);
}
@media (max-width: 600px) {
  .p-work__item {
    padding: 10.6666666667vw;
    flex-flow: column;
  }
}
.p-work__item-num {
  position: relative;
  right: 2.7777777778vw;
  bottom: 1.3888888889vw;
  font-family: "Chillax", sans-serif;
  flex-shrink: 0;
  width: 1.3888888889vw;
  font-size: 1.1111111111vw;
  font-weight: 500;
  color: #49b2cb;
  line-height: 1.5;
}
@media (max-width: 600px) {
  .p-work__item-num {
    font-size: 4.2666666667vw;
    padding: 0;
    position: unset;
  }
}
.p-work__item-body {
  text-align: start;
  flex-grow: 1;
  padding-left: 1.3888888889vw;
}
@media (max-width: 600px) {
  .p-work__item-body {
    padding-top: 2.6666666667vw;
    padding-left: 0;
  }
}
.p-work__item-title {
  font-size: 1.3888888889vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  margin-bottom: 1.1111111111vw;
}
@media (max-width: 600px) {
  .p-work__item-title {
    font-size: 4.2666666667vw;
  }
}
.p-work__item-text {
  font-size: 1.1111111111vw;
  color: var(--text, #011E55);
  line-height: 1.75;
}
@media (max-width: 600px) {
  .p-work__item-text {
    font-size: 3.7333333333vw;
  }
}

.p-services {
  position: relative;
  width: 100%;
  padding-top: 8.3333333333vw;
  padding-bottom: 8.3333333333vw;
  overflow: hidden;
}
@media (max-width: 600px) {
  .p-services {
    padding-top: 34.6666666667vw;
  }
}
.p-services::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: 6.9444444444vw;
  width: 73.75vw;
  height: 34.7222222222vw;
  bottom: 8.3333333333vw;
  background-color: #eaf3f6;
  z-index: 0;
}
@media (max-width: 600px) {
  .p-services::before {
    display: none;
  }
}
.p-services__inner {
  position: relative;
  z-index: 1;
  width: 72.2222222222vw;
  margin-right: auto;
  margin-left: auto;
}
@media (max-width: 600px) {
  .p-services__inner {
    width: 100vw;
  }
}
.p-services__body {
  position: relative;
  z-index: 2;
  display: flex;
  justify-content: flex-start;
}
.p-services__card {
  text-align: start;
  background-color: #ffffff;
  width: 35.0694444444vw;
  padding: 4.4444444444vw 3.3333333333vw;
  margin-top: 11.1111111111vw;
  box-shadow: 0 10px 30px rgba(12, 35, 64, 0.02);
}
@media (max-width: 600px) {
  .p-services__card {
    width: 93.3333333333vw;
    padding: 10.6666666667vw 8vw;
  }
}
.p-services__sub-title {
  font-family: "Chillax", sans-serif;
  display: block;
  font-family: "Chillax", sans-serif;
  font-size: 1.1111111111vw;
  letter-spacing: 0.1388888889vw;
  color: var(--CPC_a, #21B9D7);
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 600px) {
  .p-services__sub-title {
    font-size: 3.2vw;
    margin-bottom: 5.3333333333vw;
  }
}
.p-services__title {
  font-family: "YuGothic", sans-serif;
  font-size: 1.8055555556vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  letter-spacing: 0.1388888889vw;
  margin-bottom: 2.2222222222vw;
}
@media (max-width: 600px) {
  .p-services__title {
    font-size: 5.3333333333vw;
    margin-bottom: 5.3333333333vw;
  }
}
.p-services__text {
  font-family: "YuGothic", sans-serif;
  font-size: 0.9722222222vw;
  color: var(--text, #011E55);
  line-height: 2;
  letter-spacing: 0.02em;
}
@media (max-width: 600px) {
  .p-services__text {
    font-size: 3.7333333333vw;
    line-height: 6.6666666667vw;
  }
}
.p-services__graphic {
  position: absolute;
  top: 0;
  right: 0;
  width: 47.2222222222vw;
  height: 26.3888888889vw;
  z-index: 1;
}
@media (max-width: 600px) {
  .p-services__graphic {
    width: 93.3333333333vw;
    height: 61.3333333333vw;
  }
}
.p-services__graphic img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-services__action {
  display: flex;
  justify-content: flex-end;
  margin-top: 2.7777777778vw;
  position: relative;
  z-index: 2;
  bottom: 4.8611111111vw;
}
@media (max-width: 600px) {
  .p-services__action {
    margin-top: 13.3333333333vw;
    margin-right: 8vw;
  }
}
.p-services__btn {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: #0c2340;
  transition: opacity 0.3s;
}
.p-services__btn:hover {
  opacity: 0.7;
}
.p-services__btn-text {
  font-size: 0.9722222222vw;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.p-services__btn-graph {
  position: relative;
  width: 4.7222222222vw;
  height: 2.2222222222vw;
  margin-left: 1.6666666667vw;
}
.p-services__btn-graph img {
  width: 47.5vw;
}
.p-services__btn-line {
  position: absolute;
  top: 50%;
  left: 0;
  width: 3.6111111111vw;
  height: 1px;
  background-color: #0c2340;
  transform: translateY(-50%);
  z-index: 1;
}
.p-services__btn-circle {
  position: absolute;
  top: 0;
  right: 0;
  width: 2.2222222222vw;
  height: 2.2222222222vw;
  border: 1px solid #0c2340;
  border-radius: 50%;
  background-color: transparent;
  z-index: 2;
}
.p-services__btn-circle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.4166666667vw;
  height: 0.4166666667vw;
  background-color: #0c2340;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

#latest-news {
  padding-top: 6.9444444444vw;
  padding-bottom: 13.8888888889vw;
  text-align: start;
  display: flex;
  flex-flow: column;
  align-items: center;
  gap: 13.8888888889vw;
}
@media (max-width: 600px) {
  #latest-news {
    padding-top: 37.3333333333vw;
    padding-bottom: 40vw;
    gap: 37.3333333333vw;
  }
}
#latest-news .news-section,
#latest-news .blog-section {
  display: flex;
  gap: 10.625vw;
}
@media (max-width: 600px) {
  #latest-news .news-section,
  #latest-news .blog-section {
    flex-flow: column;
    gap: 10.6666666667vw;
  }
}
#latest-news .news-section .design-frame-left,
#latest-news .blog-section .design-frame-left {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
}
#latest-news .news-section .design-frame-left h2.section-title,
#latest-news .blog-section .design-frame-left h2.section-title {
  color: var(--text, #011E55);
  font-family: "Chillax", sans-serif;
  font-size: 1.7361111111vw;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.3472222222vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  #latest-news .news-section .design-frame-left h2.section-title,
  #latest-news .blog-section .design-frame-left h2.section-title {
    font-size: 6.6666666667vw;
    letter-spacing: 1.3333333333vw;
  }
}
#latest-news .news-section .design-frame-left a.detail-page-link,
#latest-news .blog-section .design-frame-left a.detail-page-link {
  display: inline-flex;
  padding: 0px 3.6805555556vw 1.1805555556vw 0px;
  align-items: center;
  color: var(--text, #011E55);
  font-family: "Chillax", sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.0972222222vw;
  text-transform: uppercase;
}
#latest-news .news-section .design-frame-left .detail-page-link,
#latest-news .blog-section .design-frame-left .detail-page-link {
  position: relative;
  display: inline-block;
  color: #0E0E0E;
  text-decoration: none;
  overflow: hidden;
}
#latest-news .news-section .design-frame-right,
#latest-news .blog-section .design-frame-right {
  display: flex;
  flex-flow: column;
  gap: 1.6666666667vw;
  width: 45.6944444444vw;
}
@media (max-width: 600px) {
  #latest-news .news-section .design-frame-right,
  #latest-news .blog-section .design-frame-right {
    width: 73.3333333333vw;
    gap: 5.3333333333vw;
  }
}
#latest-news .news-section .design-frame-right article.news-article a,
#latest-news .blog-section .design-frame-right article.news-article a {
  display: flex;
  gap: 1.3888888889vw;
  align-items: baseline;
}
@media (max-width: 600px) {
  #latest-news .news-section .design-frame-right article.news-article a,
  #latest-news .blog-section .design-frame-right article.news-article a {
    flex-flow: column;
    gap: 1.3333333333vw;
  }
}
#latest-news .news-section .design-frame-right article.news-article a time.date,
#latest-news .blog-section .design-frame-right article.news-article a time.date {
  color: var(--CPC_a, #21B9D7);
  font-family: "Chillax", sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.0486111111vw;
  text-transform: uppercase;
  transition: color 0.4s ease;
}
@media (max-width: 600px) {
  #latest-news .news-section .design-frame-right article.news-article a time.date,
  #latest-news .blog-section .design-frame-right article.news-article a time.date {
    font-size: 3.7333333333vw;
    letter-spacing: 0.1866666667vw;
  }
}
#latest-news .news-section .design-frame-right article.news-article a h3.news-title,
#latest-news .blog-section .design-frame-right article.news-article a h3.news-title {
  overflow: hidden;
  color: var(--text, #011E55);
  text-overflow: ellipsis;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.0486111111vw;
  text-transform: uppercase;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  white-space: normal;
  overflow: hidden;
  transition: color 0.4s ease;
}
@media (max-width: 600px) {
  #latest-news .news-section .design-frame-right article.news-article a h3.news-title,
  #latest-news .blog-section .design-frame-right article.news-article a h3.news-title {
    font-size: 3.7333333333vw;
    line-height: 5.3333333333vw;
    letter-spacing: 0.1866666667vw;
    width: 76.2666666667vw;
    -webkit-line-clamp: 2;
  }
}
#latest-news .news-section .design-frame-right article.news-article a:hover .date, #latest-news .news-section .design-frame-right article.news-article a:hover .news-title,
#latest-news .blog-section .design-frame-right article.news-article a:hover .date,
#latest-news .blog-section .design-frame-right article.news-article a:hover .news-title {
  transition: color 0.4s ease;
  color: #28A7E1;
}
#latest-news .blog-section .design-frame-right {
  display: flex;
  flex-flow: nowrap;
  flex-wrap: wrap;
  gap: 1.9444444444vw;
}
@media (max-width: 600px) {
  #latest-news .blog-section .design-frame-right {
    width: 76.2666666667vw;
    gap: 10.1333333333vw;
  }
}
#latest-news .blog-section .design-frame-right a.thumbnail-link {
  width: 21.8319444444vw;
  -o-object-fit: contain;
     object-fit: contain;
}
@media (max-width: 600px) {
  #latest-news .blog-section .design-frame-right a.thumbnail-link {
    height: auto;
    width: 76.2666666667vw;
  }
}
#latest-news .blog-section .design-frame-right a.thumbnail-link .thumb-wrapper {
  width: 21.8319444444vw;
  height: 12.2805555556vw;
  border-radius: 0.6944444444vw;
  overflow: hidden;
  position: relative;
}
@media (max-width: 600px) {
  #latest-news .blog-section .design-frame-right a.thumbnail-link .thumb-wrapper {
    width: 76.2666666667vw;
    height: 42.8986666667vw;
    border-radius: 2.6666666667vw;
  }
}
#latest-news .blog-section .design-frame-right a.thumbnail-link .thumb-wrapper img.thumb {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}
#latest-news .blog-section .design-frame-right a.thumbnail-link img:hover {
  transform: scale(1.05);
}
#latest-news .blog-section .design-frame-right a.thumbnail-link .blog_date {
  font-size: 0.9722222222vw;
  padding-top: 1.1111111111vw;
  font-family: "Chillax", sans-serif;
  color: var(--CPC_a, #21B9D7);
}
@media (max-width: 600px) {
  #latest-news .blog-section .design-frame-right a.thumbnail-link .blog_date {
    font-size: 3.3333333333vw;
    padding-top: 4.2666666667vw;
  }
}
#latest-news .blog-section .design-frame-right a.thumbnail-link .blog-title {
  font-size: 0.9722222222vw;
  font-weight: 500;
  padding-top: 1.1111111111vw;
  color: var(--text, #011E55);
  word-break: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  /* 必要に応じて幅を明示（親要素に依存） */
}
@media (max-width: 600px) {
  #latest-news .blog-section .design-frame-right a.thumbnail-link .blog-title {
    font-size: 3.7333333333vw;
    padding-top: 4.2666666667vw;
    line-height: 5.3333333333vw;
  }
}
@media (max-width: 600px) {
  #latest-news a.detail-page-link {
    display: inline-flex;
    padding: 0 0 4.5333333333vw 0px;
    align-items: center;
    color: var(--text, #011E55);
    font-family: "Chillax", sans-serif;
    font-size: 3.7333333333vw;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 0.3733333333vw;
    text-transform: uppercase;
  }
  #latest-news .detail-page-link {
    position: relative;
    display: inline-block;
    color: var(--text, #011E55);
    text-decoration: none;
    overflow: hidden;
    /* アニメーション中のはみ出しを隠す */
  }
}

.p-faq {
  width: 100%;
  padding-bottom: 13.8888888889vw;
}
@media (max-width: 600px) {
  .p-faq {
    padding-bottom: 40vw;
  }
}
.p-faq__inner {
  width: 72.2222222222vw;
  margin: 0 auto;
}
@media (max-width: 600px) {
  .p-faq__inner {
    width: 85.3333333333vw;
  }
}
.p-faq__header {
  text-align: start;
  margin-bottom: 3.3333333333vw;
}
@media (max-width: 600px) {
  .p-faq__header {
    margin-bottom: 5.3333333333vw;
  }
}
.p-faq__sub-title {
  font-family: "Chillax", sans-serif;
  display: block;
  font-family: "Chillax", sans-serif;
  font-size: 1.1111111111vw;
  letter-spacing: 0.1388888889vw;
  color: var(--CPC_a, #21B9D7);
  margin-bottom: 1.1111111111vw;
}
@media (max-width: 600px) {
  .p-faq__sub-title {
    font-size: 3.2vw;
    margin-bottom: 5.3333333333vw;
  }
}
.p-faq__title {
  font-family: "YuGothic", sans-serif;
  font-size: 1.8055555556vw;
  font-weight: 700;
  color: var(--text, #011E55);
  line-height: 1.5;
  letter-spacing: 0.1388888889vw;
}
@media (max-width: 600px) {
  .p-faq__title {
    font-size: 5.3333333333vw;
  }
}
.p-faq__list {
  display: flex;
  flex-direction: column;
  gap: 0.6944444444vw;
}
.p-faq__item {
  background-color: #ffffff;
  box-shadow: 0.6944444444vw 2.0833333333vw 4.8611111111vw 0 rgba(194, 215, 219, 0.25);
  border-radius: 4px;
  overflow: hidden;
}
.p-faq__item.is-open .p-faq__q-text {
  color: #003366;
}
.p-faq__q {
  width: 100%;
  display: flex;
  align-items: center;
  padding: 2.7777777778vw 4.1666666667vw 2.0833333333vw;
  border: none;
  background: none;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.3s;
}
.p-faq__q:hover {
  background-color: #fcfdfe;
}
@media (max-width: 600px) {
  .p-faq__q {
    align-items: start;
    padding: 8vw 8vw 4vw;
  }
}
.p-faq__q-icon {
  font-family: "Chillax", sans-serif;
  font-size: 1.8055555556vw;
  color: var(--CPC_a, #21B9D7);
  margin-right: 1.6666666667vw;
  font-weight: 400;
  line-height: 1;
}
@media (max-width: 600px) {
  .p-faq__q-icon {
    font-size: 6.4vw;
    margin-right: 4.2666666667vw;
  }
}
.p-faq__q-text {
  font-size: 1.25vw;
  font-weight: 700;
  color: var(--text, #011E55);
  transition: color 0.3s;
}
@media (max-width: 600px) {
  .p-faq__q-text {
    font-size: 3.7333333333vw;
    line-height: 6.4vw;
  }
}
.p-faq__a {
  height: 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: height 0.4s ease, opacity 0.4s ease, visibility 0.4s ease;
}
.p-faq__a.is-active {
  opacity: 1;
  visibility: visible;
}
.p-faq__a-inner {
  display: flex;
  align-items: flex-start;
  padding: 0 4.1666666667vw 2.7777777778vw;
}
@media (max-width: 600px) {
  .p-faq__a-inner {
    padding: 0 8vw 8vw;
  }
}
.p-faq__a-icon {
  font-size: 1.9444444444vw;
  color: #a5c317;
  margin-right: 1.6666666667vw;
  font-weight: 400;
  line-height: 1;
}
@media (max-width: 600px) {
  .p-faq__a-icon {
    font-size: 6.4vw;
    margin-right: 4.2666666667vw;
  }
}
.p-faq__a-content {
  text-align: start;
}
.p-faq__a-text {
  font-family: "YuGothic", sans-serif;
  font-size: 1.0416666667vw;
  color: var(--text, #011E55);
  line-height: 1.8;
}
@media (max-width: 600px) {
  .p-faq__a-text {
    font-size: 3.7333333333vw;
  }
}
.p-faq__a-text + .p-faq__a-text {
  margin-top: 1.1111111111vw;
}

footer .footer-design {
  position: relative;
  display: flex;
  flex-flow: column;
  align-items: start;
  text-align: start;
  width: 100vw;
  height: 45.1388888889vw;
  flex-shrink: 0;
  background: url(../img/logo-container_img_a.webp) lightgray 50%/cover no-repeat;
}
@media (max-width: 600px) {
  footer .footer-design {
    height: 105.3333333333vw;
  }
}
footer .footer-design .catch_img {
  position: absolute;
  right: 0;
  width: 62.2222222222vw;
}
@media (max-width: 600px) {
  footer .footer-design .catch_img {
    width: 49.8666666667vw;
    height: 53.8666666667vw;
    display: block;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
footer .footer-design p.catchphrase {
  padding-top: 13.0555555556vw;
  padding-left: 11.1111111111vw;
  color: #fff;
  font-family: "YuGothic", sans-serif;
  font-size: 2.6388888889vw;
  font-style: normal;
  font-weight: 700;
  line-height: 4.4444444444vw;
  /* 168.421% */
  letter-spacing: 0.4486111111vw;
  text-transform: uppercase;
  z-index: 1;
}
@media (max-width: 600px) {
  footer .footer-design p.catchphrase {
    padding-top: 18.6666666667vw;
    padding-left: 13.3333333333vw;
    font-size: 4.8vw;
    line-height: 10.6666666667vw;
    font-weight: 600;
    letter-spacing: 0.96vw;
  }
}
footer .footer-design .contact-button {
  margin-top: 6.5277777778vw;
  margin-left: 10.4166666667vw;
  padding: 0.6944444444vw;
  color: #fff;
  text-align: right;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 0%;
  letter-spacing: 0.0972222222vw;
}
@media (max-width: 600px) {
  footer .footer-design .contact-button {
    font-size: 3.7333333333vw;
    letter-spacing: 0.3733333333vw;
    margin-top: 13.3333333333vw;
    margin-left: 13.3333333333vw;
  }
}
@media (max-width: 600px) {
  footer .footer-design .contact-button .button-container {
    width: 100%;
  }
}
footer .footer-design .contact-button span {
  color: #fff;
}
footer .footer-design .contact-button .line {
  background-color: #fff;
}
footer .footer-design .contact-button .outer-circle {
  border: 0.0694444444vw solid #fff;
}
footer .footer-design .contact-button .inner-circle {
  background-color: #fff !important;
}
footer .footer-main {
  display: flex;
  flex-flow: column;
  align-items: center;
}
footer .footer-main .details-frame {
  padding-top: 6.25vw;
  padding-bottom: 8.3333333333vw;
  width: 77.7777777778vw;
  display: flex;
  justify-content: space-between;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame {
    flex-flow: column;
    padding-top: 21.3333333333vw;
    padding-bottom: 13.3333333333vw;
    width: 73.3333333333vw;
  }
}
footer .footer-main .details-frame .design-frame-left {
  display: flex;
  flex-flow: column;
  align-items: start;
}
footer .footer-main .details-frame .design-frame-left .company-logo a img {
  width: 20vw;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-left .company-logo a img {
    width: 61.8666666667vw;
  }
}
footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item,
footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item-a {
  text-align: start;
  color: #000;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 1.8055555556vw;
  /* 185.714% */
  letter-spacing: 0.0972222222vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item,
  footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item-a {
    font-size: 3.4666666667vw;
    line-height: 7.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item-a {
  color: #00A29A;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-left ul.company-info-list li.info-item-a {
    padding: 2.6666666667vw 0;
    font-size: 3.2vw;
    line-height: 5.6vw;
  }
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-left ul.company-info-list {
    display: flex;
    flex-flow: column;
    padding-top: 8vw;
  }
}
footer .footer-main .details-frame .design-frame-right {
  display: flex;
  flex-flow: column;
  align-items: end;
  gap: 3.8194444444vw;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-right {
    padding-top: 10.6666666667vw;
    align-items: start;
  }
}
footer .footer-main .details-frame .design-frame-right ul.footer-menu-list {
  display: flex;
  gap: 2.7777777778vw;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-right ul.footer-menu-list {
    flex-flow: column;
    align-items: start;
    gap: 5.3333333333vw;
  }
}
footer .footer-main .details-frame .design-frame-right ul.footer-menu-list li {
  padding-top: 0.7916666667vw;
}
footer .footer-main .details-frame .design-frame-right ul.footer-menu-list li a {
  color: #000;
  font-family: "Chillax", sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.1041666667vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-right ul.footer-menu-list li a {
    font-size: 4vw;
    letter-spacing: 0.4vw;
  }
}
footer .footer-main .details-frame .design-frame-right a.privacy-policy {
  color: #999999;
  text-align: right;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9027777778vw;
  font-style: normal;
  font-weight: 400;
  line-height: 1.8055555556vw;
  /* 200% */
  letter-spacing: 0.0902777778vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-right a.privacy-policy {
    padding-top: 8vw;
    font-size: 3.4666666667vw;
    line-height: 6.9333333333vw;
    letter-spacing: 0.3466666667vw;
  }
}
footer .footer-main .details-frame .design-frame-right p.copyright {
  color: #000;
  text-align: right;
  font-family: Montserrat;
  font-size: 0.6944444444vw;
  font-style: normal;
  font-weight: 400;
  line-height: normal;
  letter-spacing: 0.0694444444vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  footer .footer-main .details-frame .design-frame-right p.copyright {
    padding-top: 8vw;
    font-size: 2.6666666667vw;
    letter-spacing: 0.2666666667vw;
  }
}

/******* 共通ボタン設定 *******/
.button-container {
  display: flex;
  align-items: center;
  gap: 1.3888888889vw;
  justify-content: space-between;
  width: 100%;
}
@media (max-width: 600px) {
  .button-container {
    gap: 5.3333333333vw;
  }
}
.button-container span {
  display: flex;
  flex-flow: column;
  width: 100%;
  height: 3.125vw;
  justify-content: center;
  color: var(--text, #011E55);
  text-align: right;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 121.017%;
}
@media (max-width: 600px) {
  .button-container span {
    font-size: 3.7333333333vw;
  }
}
.button-container .circle-line-container {
  display: flex;
  align-items: center;
  position: relative;
}
.button-container .circle-line-container .line {
  width: 3.4722222222vw;
  height: 0.0694444444vw;
  background-color: #011E55;
  position: relative;
  z-index: 1;
  transform-origin: right;
  transform: scaleX(1);
}
@media (max-width: 600px) {
  .button-container .circle-line-container .line {
    width: 13.3333333333vw;
    height: 0.2666666667vw;
  }
}
.button-container .circle-line-container .outer-circle {
  position: relative;
  width: 3.125vw;
  height: 3.125vw;
  border: 1px solid #011E55;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: -1.5972222222vw;
}
@media (max-width: 600px) {
  .button-container .circle-line-container .outer-circle {
    width: 12vw;
    height: 12vw;
    margin-left: -6.1333333333vw;
  }
}
.button-container .circle-line-container .outer-circle .inner-circle {
  width: 0.625vw;
  height: 0.625vw;
  background-color: #011E55;
  border-radius: 50%;
}
@media (max-width: 600px) {
  .button-container .circle-line-container .outer-circle .inner-circle {
    width: 2.4vw;
    height: 2.4vw;
  }
}
.button-container:hover .line {
  animation: lineShrinkGrow 0.4s ease-in-out forwards;
}

/* ////////////////////// アニメーション ///////////////////////// */
@keyframes lineShrinkGrow {
  0% {
    transform-origin: right;
    transform: scaleX(1);
  }
  50% {
    transform-origin: right;
    transform: scaleX(0);
  }
  50.01% {
    transform-origin: left;
    transform: scaleX(0);
  }
  100% {
    transform-origin: left;
    transform: scaleX(1);
  }
}
.scroll-indicator .wrapper svg path {
  transform-origin: 50% 50%;
  /* 中央を基点に変形 */
  animation: expand-contract 1.8s ease-in-out infinite;
  animation-fill-mode: backwards;
  /* 遅延時間中も初期状態を適用 */
}

@keyframes expand-contract {
  0% {
    transform: scaleX(0);
  }
  50% {
    transform: scaleX(1);
  }
  100% {
    transform: scaleX(0);
  }
}
.scroll-indicator .wrapper svg:nth-child(1) path {
  animation-delay: 0s;
}

.scroll-indicator .wrapper svg:nth-child(2) path {
  animation-delay: 0.2s;
}

.scroll-indicator .wrapper svg:nth-child(3) path {
  animation-delay: 0.3s;
}

.scroll-indicator .wrapper svg:nth-child(4) path {
  animation-delay: 0.5s;
}

.scroll-indicator .wrapper svg:nth-child(5) path {
  animation-delay: 0.7s;
}

.detail-page-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  /* 下線の太さを調整 */
  background-color: #011E55;
  /* 下線の色 */
  transform-origin: right;
  /* 右端を基点に */
  transform: scaleX(1);
  transition: transform 0.4s ease-in-out;
}
@media (max-width: 600px) {
  .detail-page-link::after {
    width: 50%;
  }
}

.detail-page-link:hover::after {
  animation: lineShrinkGrow 0.4s ease-in-out forwards;
}

/* アニメーションの定義 */
@keyframes lineShrinkGrow {
  0% {
    transform-origin: right;
    transform: scaleX(1);
  }
  50% {
    transform-origin: right;
    transform: scaleX(0);
  }
  50.01% {
    transform-origin: left;
    transform: scaleX(0);
  }
  100% {
    transform-origin: left;
    transform: scaleX(1);
  }
}
/* ●が拡大するセクションのスタイル */
.circle_wrap {
  pointer-events: none;
  position: fixed;
  z-index: 2;
}
.circle_wrap .circle-animation-section {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}
.circle_wrap .circle-animation-section .circle {
  position: absolute;
  top: 110%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 0px;
  height: 0px;
  background-color: #004185;
  border-radius: 50%;
}

#particleCanvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 5;
  /* 背景に配置 */
  pointer-events: none;
}

#web-design-animation {
  gap: 5.859375vh;
  width: 100vw;
  white-space: nowrap;
  overflow: hidden;
  width: 100%;
  height: 350vh;
  overflow: hidden;
  z-index: 4;
}
#web-design-animation .catchphrase {
  color: #fff;
  font-family: Inter, sans-serif;
  font-size: 6.6666666667vw;
  font-weight: 700;
  line-height: 1.2;
  font-style: normal;
  letter-spacing: 0.2083333333vw;
  filter: drop-shadow(0.6944444444vw 0.6944444444vw 0.1388888889vw rgba(0, 0, 0, 0.25));
  will-change: transform;
  backface-visibility: hidden;
  position: fixed;
  top: 50%;
  opacity: 0;
  /* 初期は透明 */
  transform: translateX(0);
  /* 初期位置は中央 */
  transition: none;
  /* JavaScriptで制御 */
  height: 45.703125vh;
  z-index: 6;
}
@media (max-width: 600px) {
  #web-design-animation .catchphrase {
    font-size: 16vw;
  }
}
#web-design-animation .catchphrase span {
  color: #E74291;
}
#web-design-animation {
  /* 画面中央から上に25%の位置に配置 */
}
#web-design-animation .catchphrase.from-right:nth-child(1) {
  top: 25%;
  /* 画面中央から上に25% */
}
@media (max-width: 600px) {
  #web-design-animation .catchphrase.from-right:nth-child(1) {
    top: 30%;
  }
}
#web-design-animation {
  /* 画面中央に配置 */
}
#web-design-animation .catchphrase.from-left:nth-child(2) {
  top: 45%;
  /* 画面中央 */
}
#web-design-animation {
  /* 画面中央から下に25%の位置に配置 */
}
#web-design-animation .catchphrase.from-right:nth-child(3) {
  top: 65%;
  /* 画面中央から下に25% */
}
@media (max-width: 600px) {
  #web-design-animation .catchphrase.from-right:nth-child(3) {
    top: 60%;
  }
}

.hidden {
  opacity: 0;
  transition: opacity 0.6s ease;
  /* 0.6秒でフェードアウト */
  pointer-events: none;
}

.x-txt {
  opacity: 0;
}
.is-active .x-txt, .x-txt.is-active {
  opacity: 1;
}

._txt {
  will-change: transform, opacity;
  display: inline-block;
  font-weight: inherit;
  opacity: 0;
  transform: translateY(80%);
  clip-path: inset(0% 0% 0% 100%);
  transition: opacity 1s cubic-bezier(0.19, 1, 0.22, 1), clip-path 1s cubic-bezier(0.19, 1, 0.22, 1), transform 1s cubic-bezier(0.19, 1, 0.22, 1);
}
._txt:nth-child(1) {
  transition-delay: 0.03s;
}
._txt:nth-child(2) {
  transition-delay: 0.06s;
}
._txt:nth-child(3) {
  transition-delay: 0.09s;
}
._txt:nth-child(4) {
  transition-delay: 0.12s;
}
._txt:nth-child(5) {
  transition-delay: 0.15s;
}
._txt:nth-child(6) {
  transition-delay: 0.18s;
}
._txt:nth-child(7) {
  transition-delay: 0.21s;
}
._txt:nth-child(8) {
  transition-delay: 0.24s;
}
._txt:nth-child(9) {
  transition-delay: 0.27s;
}
._txt:nth-child(10) {
  transition-delay: 0.3s;
}
._txt:nth-child(11) {
  transition-delay: 0.33s;
}
._txt:nth-child(12) {
  transition-delay: 0.36s;
}
._txt:nth-child(13) {
  transition-delay: 0.39s;
}
._txt:nth-child(14) {
  transition-delay: 0.42s;
}
._txt:nth-child(15) {
  transition-delay: 0.45s;
}
._txt:nth-child(16) {
  transition-delay: 0.48s;
}
._txt:nth-child(17) {
  transition-delay: 0.51s;
}
._txt:nth-child(18) {
  transition-delay: 0.54s;
}
._txt:nth-child(19) {
  transition-delay: 0.57s;
}
._txt:nth-child(20) {
  transition-delay: 0.6s;
}
._txt:nth-child(21) {
  transition-delay: 0.63s;
}
._txt:nth-child(22) {
  transition-delay: 0.66s;
}
._txt:nth-child(23) {
  transition-delay: 0.69s;
}
._txt:nth-child(24) {
  transition-delay: 0.72s;
}
._txt:nth-child(25) {
  transition-delay: 0.75s;
}
._txt:nth-child(26) {
  transition-delay: 0.78s;
}
._txt:nth-child(27) {
  transition-delay: 0.81s;
}
._txt:nth-child(28) {
  transition-delay: 0.84s;
}
._txt:nth-child(29) {
  transition-delay: 0.87s;
}
._txt:nth-child(30) {
  transition-delay: 0.9s;
}
._txt:nth-child(31) {
  transition-delay: 0.93s;
}
._txt:nth-child(32) {
  transition-delay: 0.96s;
}
._txt:nth-child(33) {
  transition-delay: 0.99s;
}
._txt:nth-child(34) {
  transition-delay: 1.02s;
}
._txt:nth-child(35) {
  transition-delay: 1.05s;
}
._txt:nth-child(36) {
  transition-delay: 1.08s;
}
._txt:nth-child(37) {
  transition-delay: 1.11s;
}
._txt:nth-child(38) {
  transition-delay: 1.14s;
}
._txt:nth-child(39) {
  transition-delay: 1.17s;
}
._txt:nth-child(40) {
  transition-delay: 1.2s;
}
._txt:nth-child(41) {
  transition-delay: 1.23s;
}
._txt:nth-child(42) {
  transition-delay: 1.26s;
}
._txt:nth-child(43) {
  transition-delay: 1.29s;
}
._txt:nth-child(44) {
  transition-delay: 1.32s;
}
._txt:nth-child(45) {
  transition-delay: 1.35s;
}
._txt:nth-child(46) {
  transition-delay: 1.38s;
}
._txt:nth-child(47) {
  transition-delay: 1.41s;
}
._txt:nth-child(48) {
  transition-delay: 1.44s;
}
._txt:nth-child(49) {
  transition-delay: 1.47s;
}
._txt:nth-child(50) {
  transition-delay: 1.5s;
}
.is-active ._txt {
  opacity: 1;
  transform: translateY(0);
  clip-path: inset(0 0 0 0);
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(40px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
/* 初期状態 */
.fade_in {
  opacity: 0;
  transform: translateY(3.90625vh);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

/* 表示領域の下から30%の位置でアニメーションを開始 */
.fade_in.is-visible {
  animation: fadeInUp 0.6s ease forwards;
}

.background-element {
  background-color: #011E55;
  width: 20.3125vw;
  height: 15.1826388889vw;
  border-radius: 0.6944444444vw;
  position: relative;
  overflow: hidden;
  transition: width 0.3s ease-in-out;
  transform-origin: left;
  transform: scaleX(0);
  transition: transform 0.3s ease-in-out;
}

/* アニメーションが完了した後の背景要素 */
.background-element.is-visible {
  width: 20.3125vw;
  transform: scaleX(1);
}
@media (max-width: 600px) {
  .background-element.is-visible {
    width: 82.4vw;
    height: 41.0666666667vw;
    border-radius: 2.6666666667vw;
  }
}

/* 画像要素 */
.image-element {
  position: absolute;
  left: -100%;
  top: 0;
  height: 100%;
  transition: left 0.3s ease-in-out 0.5s;
  /* 背景要素のアニメーションが完了した後に実行 */
}
@media (max-width: 600px) {
  .image-element {
    transition: left 0.2s ease-in 0.4s;
  }
}

/* アニメーションが完了した後の画像要素 */
.background-element.is-visible .image-element {
  left: 0;
}

.common-problems .problem-detail {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

.common-problems .problem-detail.is-visible {
  opacity: 1;
  transform: translateX(0);
}

.top_fadeIn_head {
  animation: top_fadeIn_head 0.6s ease forwards;
}

@keyframes top_fadeIn_head {
  0% {
    opacity: 0;
    transform: translateY(-2.9296875vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.top_fadeIn_late {
  animation: top_fadeIn_late 0.6s ease forwards;
}

@keyframes top_fadeIn_late {
  0% {
    opacity: 0;
    transform: translateY(2.9296875vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.top_fadeIn_main {
  opacity: 0;
  animation: top_fadeIn_main 0.6s ease forwards;
  animation-delay: 0.3s;
}

@keyframes top_fadeIn_main {
  0% {
    opacity: 0;
    transform: scale(1.1);
    filter: blur(20px);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0);
  }
}
.top_fadeIn_sub {
  opacity: 0;
  animation: top_fadeIn_sub 0.9s ease forwards;
  animation-delay: 0.3s;
}

@keyframes top_fadeIn_sub {
  0% {
    opacity: 0;
    filter: blur(20px);
  }
  100% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0);
  }
}
.top_fadeIn_third {
  opacity: 0;
  animation: top_fadeIn_third 0.6s ease forwards;
  animation-delay: 0.7s;
}

@keyframes top_fadeIn_third {
  0% {
    opacity: 0;
    transform: translateY(-0.9765625vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0vh);
  }
}
.top_fadeIn_four {
  opacity: 0;
  animation: top_fadeIn_four 0.8s ease forwards;
  animation-delay: 0.6s;
}

@keyframes top_fadeIn_four {
  0% {
    opacity: 0;
    transform: translateY(2.9296875vh);
  }
  100% {
    opacity: 1;
    transform: translateY(0vh);
  }
}
/* ////////////////////// ABOUTページ ///////////////////////// */
#company-intro {
  padding: 17.2916666667vw 0 0;
}
@media (max-width: 600px) {
  #company-intro {
    padding: 40vw 0;
  }
}
#company-intro .company-intro__inner {
  display: flex;
  justify-content: space-between;
  align-items: start;
  width: 100vw;
  margin: 0 auto;
}
@media (max-width: 600px) {
  #company-intro .company-intro__inner {
    align-items: center;
    flex-flow: column;
    gap: 16vw;
  }
}
#company-intro .company-intro__text-box {
  width: 41.3888888889vw;
  margin-left: 20.0694444444vw;
}
@media (max-width: 600px) {
  #company-intro .company-intro__text-box {
    width: 85.3333333333vw;
    margin-left: 0;
    width: 100vw;
    padding-left: 8vw;
  }
}
#company-intro .company-intro__header {
  margin-bottom: 6.9444444444vw;
  text-align: start;
}
@media (max-width: 600px) {
  #company-intro .company-intro__header {
    margin-bottom: 13.3333333333vw;
  }
}
#company-intro .company-intro__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin: 0 0 0.6944444444vw;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  #company-intro .company-intro__title {
    width: 53.3333333333vw;
    font-size: 8.5333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
#company-intro .company-intro__subtitle {
  color: #011E55;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
}
#company-intro .company-intro__subtitle span {
  margin-right: 0.5555555556vw;
  color: #1a2b4c;
}
@media (max-width: 600px) {
  #company-intro .company-intro__subtitle span {
    margin-right: 2.1333333333vw;
  }
}
@media (max-width: 600px) {
  #company-intro .company-intro__subtitle {
    font-size: 3.2vw;
  }
}
#company-intro .company-intro__copy {
  color: var(--text, #011E55);
  text-align: justify;
  font-family: "YuGothic", sans-serif;
  font-weight: 700;
  font-size: 1.9444444444vw;
  line-height: 3.1944444444vw;
  padding-bottom: 4.1666666667vw;
}
@media (max-width: 600px) {
  #company-intro .company-intro__copy {
    font-size: 4.8vw;
    line-height: 2;
    padding-bottom: 10.6666666667vw;
    width: 85.3333333333vw;
  }
}
#company-intro .company-intro__description {
  color: var(--text, #011E55);
  text-align: justify;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  line-height: 2.2;
}
@media (max-width: 600px) {
  #company-intro .company-intro__description {
    font-size: 3.7333333333vw;
    line-height: 2;
    width: 85.3333333333vw;
  }
}
#company-intro .company-intro__image-box {
  width: 24.3055555556vw;
  justify-content: end;
}
@media (max-width: 600px) {
  #company-intro .company-intro__image-box {
    width: 73.0666666667vw;
    padding-bottom: 10.6666666667vw;
    margin-left: auto;
  }
}
#company-intro .company-intro__image-box img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 600px) {
  #company-intro .company-intro__image-box img {
    display: block;
    width: 73.0666666667vw;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
}

.message {
  padding: 13.8888888889vw 0;
  width: 100vw;
  overflow: hidden;
}
@media (max-width: 600px) {
  .message {
    padding: 0 0 40vw;
  }
}
.message__inner {
  position: relative;
  width: 100vw;
  margin: 0 auto;
}
@media (max-width: 600px) {
  .message__inner {
    width: 85.3333333333vw;
  }
}
.message__image-left {
  position: absolute;
  left: 0;
  width: 24.3055555556vw;
}
.message__image-left img {
  display: block;
  width: 100%;
  height: auto;
}
.message__content {
  margin-left: 38.6111111111vw;
  width: 35.1388888889vw;
}
@media (max-width: 600px) {
  .message__content {
    margin-left: 0;
    width: 100%;
  }
}
.message__header {
  margin-bottom: 4.1666666667vw;
  text-align: start;
}
@media (max-width: 600px) {
  .message__header {
    margin-bottom: 10.6666666667vw;
  }
}
.message__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin: 0 0 0.6944444444vw;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  .message__title {
    font-size: 8.5333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.message__subtitle {
  color: #011E55;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0;
}
.message__subtitle span {
  margin-right: 0.5555555556vw;
  color: #1a2b4c;
}
@media (max-width: 600px) {
  .message__subtitle span {
    margin-right: 2.1333333333vw;
  }
}
@media (max-width: 600px) {
  .message__subtitle {
    font-size: 3.2vw;
  }
}
.message__text {
  color: #011E55;
  text-align: justify;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  line-height: 2.2;
  margin: 0 0 4.1666666667vw;
}
@media (max-width: 600px) {
  .message__text {
    font-size: 3.7333333333vw;
    line-height: 2;
    margin-bottom: 10.6666666667vw;
  }
}
.message__profile {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.message__profile img {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 600px) {
  .message__profile img {
    margin-bottom: 4.2666666667vw;
  }
}
.message__signature {
  color: var(--text, #011E55);
  font-family: "YuGothic", sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 500;
  letter-spacing: 0.05em;
}
@media (max-width: 600px) {
  .message__signature {
    font-size: 3.2vw;
  }
}

.business-cta {
  background-color: #f3f9fb;
  padding: 8.3333333333vw 0;
  position: relative;
  width: 100vw;
  overflow: hidden;
}
@media (max-width: 600px) {
  .business-cta {
    padding: 16vw 0;
  }
}
.business-cta::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 36%;
  width: 100vw;
  background-color: #e6eff4;
  z-index: 0;
}
@media (max-width: 600px) {
  .business-cta::before {
    left: 20%;
  }
}
.business-cta__inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.business-cta__box {
  background-color: #ffffff;
  width: 59.8611111111vw;
  padding: 5.5555555556vw 6.9444444444vw;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 600px) {
  .business-cta__box {
    width: 85.3333333333vw;
    padding: 10.6666666667vw;
  }
}
.business-cta__lead {
  color: #011E55;
  font-family: "YuGothic", sans-serif;
  font-size: 1.25vw;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin: 0 0 3.4722222222vw;
  text-align: center;
}
@media (max-width: 600px) {
  .business-cta__lead {
    font-size: 3.7333333333vw;
    margin-bottom: 8vw;
  }
}
.business-cta__btn-group {
  display: flex;
  justify-content: center;
  width: 100%;
  gap: 2.0833333333vw;
}
@media (max-width: 600px) {
  .business-cta__btn-group {
    flex-direction: column;
    gap: 5.3333333333vw;
  }
}
.business-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1;
  padding: 1.7361111111vw 0.6944444444vw;
  background-color: #011E55;
  color: #ffffff;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
  box-sizing: border-box;
  transition: opacity 0.3s ease, transform 0.3s ease;
}
@media (max-width: 600px) {
  .business-cta__btn {
    font-size: 3.7333333333vw;
    padding: 5.3333333333vw 2.6666666667vw;
  }
}
.business-cta__btn:hover {
  opacity: 0.8;
  transform: translateY(-2px);
}

.overview {
  padding: 13.8888888889vw 0;
  background-color: #f3f9fb;
  width: 100vw;
  overflow: hidden;
}
@media (max-width: 600px) {
  .overview {
    padding: 40vw 0;
  }
}
.overview__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin: 0 auto;
}
@media (max-width: 600px) {
  .overview__inner {
    flex-flow: column;
    width: 85.3333333333vw;
    gap: 16vw;
  }
}
.overview__content {
  padding-left: 20vw;
}
@media (max-width: 600px) {
  .overview__content {
    padding-left: 0;
  }
}
.overview__header {
  margin-bottom: 4.1666666667vw;
  text-align: start;
}
@media (max-width: 600px) {
  .overview__header {
    margin-bottom: 10.6666666667vw;
  }
}
.overview__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin: 0 0 0.6944444444vw;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  .overview__title {
    font-size: 8.5333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
.overview__subtitle {
  color: #011E55;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0;
}
.overview__subtitle span {
  margin-right: 0.5555555556vw;
  color: #1a2b4c;
}
@media (max-width: 600px) {
  .overview__subtitle span {
    margin-right: 2.1333333333vw;
  }
}
@media (max-width: 600px) {
  .overview__subtitle {
    font-size: 3.2vw;
  }
}
.overview__list {
  display: flex;
  flex-direction: column;
  width: 100%;
}
.overview__row {
  text-align: start;
  display: flex;
  align-items: center;
  padding: 1.6666666667vw 0;
  border-bottom: 1px solid #DDEDF9;
}
.overview__row:last-child {
  border-bottom: none;
}
@media (max-width: 600px) {
  .overview__row {
    flex-direction: column;
    padding: 5.3333333333vw 0 4.2666666667vw;
    gap: 3.2vw;
    align-items: start;
  }
}
.overview__term {
  width: 12.5vw;
  color: #011E55;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media (max-width: 600px) {
  .overview__term {
    width: 100%;
    font-size: 3.7333333333vw;
    font-weight: 500;
  }
}
.overview__desc {
  flex: 1;
  color: #011E55;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  margin: 0;
}
@media (max-width: 600px) {
  .overview__desc {
    font-size: 3.7333333333vw;
    line-height: 1.8;
  }
}
.overview__desc a {
  color: #229bba;
  text-decoration: underline;
  text-underline-offset: 4px;
  transition: opacity 0.3s ease;
}
.overview__desc a:hover {
  opacity: 0.7;
}
.overview__image {
  width: 24.3055555556vw;
  flex-shrink: 0;
}
@media (max-width: 600px) {
  .overview__image {
    width: calc(50vw + 50%);
    max-width: none;
    align-self: flex-end;
  }
}
.overview__image img {
  display: block;
  width: 100%;
  height: auto;
}

/* ////////////////////// SERVICESページ ///////////////////////// */
#services-intro {
  padding: 17.2916666667vw 0 13.8888888889vw;
}
@media (max-width: 600px) {
  #services-intro {
    padding: 40vw 0;
  }
}
#services-intro .services-intro__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100vw;
  margin: 0 auto;
  padding-bottom: 13.8888888889vw;
}
@media (max-width: 600px) {
  #services-intro .services-intro__inner {
    flex-flow: column;
    gap: 16vw;
  }
}
#services-intro .services-intro__text-box {
  width: 41.3888888889vw;
  margin-left: 20.0694444444vw;
}
@media (max-width: 600px) {
  #services-intro .services-intro__text-box {
    width: 85.3333333333vw;
    margin-left: 0;
  }
}
#services-intro .services-intro__header {
  margin-bottom: 6.9444444444vw;
  text-align: start;
}
@media (max-width: 600px) {
  #services-intro .services-intro__header {
    margin-bottom: 13.3333333333vw;
  }
}
#services-intro .services-intro__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin: 0 0 0.6944444444vw;
  width: 18.0555555556vw;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  #services-intro .services-intro__title {
    width: 53.3333333333vw;
    font-size: 8.5333333333vw;
    margin-bottom: 2.1333333333vw;
  }
}
#services-intro .services-intro__subtitle {
  color: #011E55;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
}
#services-intro .services-intro__subtitle span {
  margin-right: 0.5555555556vw;
  color: #1a2b4c;
}
@media (max-width: 600px) {
  #services-intro .services-intro__subtitle span {
    margin-right: 2.1333333333vw;
  }
}
@media (max-width: 600px) {
  #services-intro .services-intro__subtitle {
    font-size: 3.2vw;
  }
}
#services-intro .services-intro__description {
  color: var(--text, #011E55);
  text-align: justify;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  line-height: 2.2;
}
@media (max-width: 600px) {
  #services-intro .services-intro__description {
    font-size: 3.7333333333vw;
    line-height: 2;
  }
}
#services-intro .services-intro__image-box {
  width: 24.3055555556vw;
  justify-content: end;
}
@media (max-width: 600px) {
  #services-intro .services-intro__image-box {
    width: calc(50vw + 50%);
    max-width: none;
    padding-bottom: 16vw;
  }
}
#services-intro .services-intro__image-box img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 600px) {
  #services-intro .services-intro__image-box img {
    display: block;
    width: 73.0666666667vw;
    height: auto;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
#services-intro .service-list {
  display: flex;
  flex-direction: column;
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  flex-flow: column;
  align-items: center;
  display: flex;
  flex-flow: column;
}
#services-intro .service-list__item {
  box-shadow: 10px 30px 50px 0 rgba(194, 215, 219, 0.4);
}
#services-intro .service-card {
  display: flex;
  align-items: flex-start;
  gap: 5.5555555556vw;
  width: 60.4166666667vw;
  background: #fff;
  padding: 5.5555555556vw;
  align-items: center;
  border: solid 0.0694444444vw #DDEDF9;
}
@media (max-width: 600px) {
  #services-intro .service-card {
    flex-direction: column;
    gap: 10.6666666667vw;
    width: 85.3333333333vw;
    align-items: start;
    padding: 10.6666666667vw;
  }
}
#services-intro .service-card__image {
  width: 12.5vw;
  flex-shrink: 0;
}
@media (max-width: 600px) {
  #services-intro .service-card__image {
    width: 32vw;
  }
}
#services-intro .service-card__image img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 600px) {
  #services-intro .service-card__image img {
    width: 18.6666666667vw;
  }
}
#services-intro .service-card__content {
  display: flex;
  flex-direction: column;
  gap: 1.3888888889vw;
  text-align: start;
}
@media (max-width: 600px) {
  #services-intro .service-card__content {
    gap: 4.2666666667vw;
  }
}
#services-intro .service-card__title {
  color: var(--text, #011E55);
  font-size: 1.6666666667vw;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.1em;
  margin: 0;
}
@media (max-width: 600px) {
  #services-intro .service-card__title {
    font-size: 4.8vw;
  }
}
#services-intro .service-card__subtitle {
  color: var(--text, #011E55);
  font-size: 1.1111111111vw;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.08em;
  margin: 0;
}
@media (max-width: 600px) {
  #services-intro .service-card__subtitle {
    font-size: 4.2666666667vw;
  }
}
#services-intro .service-card__description {
  color: var(--text, #011E55);
  font-size: 0.9722222222vw;
  font-weight: 500;
  line-height: 2.2;
  text-align: justify;
  margin: 0;
}
@media (max-width: 600px) {
  #services-intro .service-card__description {
    font-size: 3.7333333333vw;
    line-height: 2;
  }
}

.step-cta {
  background-color: #f3f9fb;
  padding: 8.3333333333vw 0;
  position: relative;
  width: 100vw;
  overflow: hidden;
  margin-bottom: 13.8888888889vw;
}
@media (max-width: 600px) {
  .step-cta {
    padding: 21.3333333333vw 0;
    margin-bottom: 42.6666666667vw;
  }
}
.step-cta::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 40%;
  width: 100vw;
  background-color: #e8f2f6;
  z-index: 0;
}
@media (max-width: 600px) {
  .step-cta::before {
    left: 20%;
  }
}
.step-cta__inner {
  max-width: 1440px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.step-cta__box {
  background-color: #fff;
  width: 59.8611111111vw;
  padding: 5.5555555556vw;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-shadow: 10px 30px 50px 0 rgba(194, 215, 219, 0.4);
}
@media (max-width: 600px) {
  .step-cta__box {
    width: 85.3333333333vw;
    padding: 13.3333333333vw 6.4vw;
  }
}
.step-cta__header {
  text-align: center;
  margin-bottom: 3.4722222222vw;
}
@media (max-width: 600px) {
  .step-cta__header {
    margin-bottom: 10.6666666667vw;
  }
}
.step-cta__heading-sub {
  color: #011E55;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin: 0 0 0.5555555556vw;
}
@media (max-width: 600px) {
  .step-cta__heading-sub {
    font-size: 3.4666666667vw;
    margin-bottom: 2.1333333333vw;
  }
}
.step-cta__heading-main {
  color: #011E55;
  font-family: "YuGothic", sans-serif;
  font-size: 1.25vw;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.1em;
  margin: 0;
}
@media (max-width: 600px) {
  .step-cta__heading-main {
    font-size: 4.2666666667vw;
  }
}
.step-cta__btn-group {
  display: flex;
  justify-content: space-between;
  width: 100%;
  gap: 2.0833333333vw;
  margin-bottom: 4.1666666667vw;
}
@media (max-width: 600px) {
  .step-cta__btn-group {
    flex-direction: column;
    gap: 8vw;
    margin-bottom: 13.3333333333vw;
  }
}
.step-cta__btn-wrapper {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.step-cta__btn-label {
  color: #00A29A;
  font-family: "YuGothic", sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin: 0 0 0.8333333333vw;
}
@media (max-width: 600px) {
  .step-cta__btn-label {
    font-size: 3.2vw;
    margin-bottom: 2.6666666667vw;
  }
}
.step-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 1.3888888889vw 0.6944444444vw;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
  box-sizing: border-box;
  transition: opacity 0.3s ease, transform 0.3s ease;
}
@media (max-width: 600px) {
  .step-cta__btn {
    font-size: 3.7333333333vw;
    padding: 4.8vw 2.6666666667vw;
  }
}
.step-cta__btn:hover {
  opacity: 0.8;
  transform: translateY(-2px);
}
.step-cta__btn--dark {
  background-color: #011E55;
  color: #fff;
}
.step-cta__btn--primary {
  background: var(--CPC_b, #00A29A);
  color: #fff;
}
.step-cta__bottom {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.step-cta__lead {
  color: #011E55;
  text-align: center;
  font-family: "YuGothic", sans-serif;
  font-size: 1.25vw;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
  margin: 0 0 2.0833333333vw;
}
@media (max-width: 600px) {
  .step-cta__lead {
    font-size: 3.7333333333vw;
    margin-bottom: 6.4vw;
  }
}

/* ////////////////////// NEWS&BLOGページ ///////////////////////// */
.news-blog {
  padding: 17.3611111111vw 0 0vw;
  overflow: hidden;
  width: 100vw;
}
@media (max-width: 600px) {
  .news-blog {
    padding: 42.1333333333vw 0 13.3333333333vw;
  }
}
.news-blog__inner {
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
  display: flex;
  flex-flow: column;
  align-items: center;
}
.news-blog__header {
  width: 59.8611111111vw;
  display: flex;
  flex-flow: column;
  align-items: start;
  margin-bottom: 4.1666666667vw;
}
@media (max-width: 600px) {
  .news-blog__header {
    width: 85.3333333333vw;
    margin-bottom: 0;
  }
}
.news-blog__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.0680555556vw;
  line-height: 1.2;
  margin: 0 0 8px;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  .news-blog__title {
    font-size: 8vw;
  }
}
.news-blog__subtitle {
  color: #011E55;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0;
}
.news-blog__subtitle span {
  margin-right: 8px;
}
@media (max-width: 600px) {
  .news-blog__subtitle {
    font-size: 3.2vw;
  }
}

.news-blog-container {
  margin: 0 auto;
  margin-top: 2.7777777778vw;
  width: 64.4444444444vw;
}
@media (max-width: 600px) {
  .news-blog-container {
    margin-top: 2.1333333333vw;
    width: 91.4666666667vw;
  }
}
.news-blog-container {
  /* タブのデザイン一覧 */
}
.news-blog-container .tab-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  overflow-x: hidden;
}
.news-blog-container .tab-container .tab-separator {
  order: -2;
  max-width: 70px;
  width: 2.9861111111vw;
  border-bottom: solid 0.0694444444vw #004185;
  position: relative;
}
@media (max-width: 600px) {
  .news-blog-container .tab-container .tab-separator {
    width: 4.3546666667vw;
    border-bottom: solid 0.2666666667vw #004185;
  }
}
.news-blog-container .tab-container .tab-separator.news-border {
  border-color: #004185;
}
.news-blog-container .tab-container .tab-separator.blog-border {
  border-color: #004185;
}
.news-blog-container .tab-container .tab-title {
  color: var(--logo-color-3, #004185);
  text-align: center;
  font-feature-settings: "palt" on;
  padding: 1.3888888889vw 0;
  color: #004185;
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Chillax", sans-serif;
  font-size: 1.3888888889vw;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.1388888889vw;
  width: 29.1666666667vw;
  order: -2;
  position: relative;
  z-index: 1;
  cursor: pointer;
  flex: 1;
  background: #e8f4ff;
  border-bottom: solid 0.0694444444vw #004185;
  border-top-left-radius: 0.5555555556vw;
  border-top-right-radius: 0.5555555556vw;
}
@media (max-width: 600px) {
  .news-blog-container .tab-container .tab-title {
    padding: 3.125vw 0;
    font-size: 3.4666666667vw;
    letter-spacing: 0.3466666667vw;
    width: 41.2325333333vw;
    border-bottom: solid 0.2666666667vw #004185;
    border-top-left-radius: 2.1333333333vw;
    border-top-right-radius: 2.1333333333vw;
  }
}
.news-blog-container .tab-container .tab-panel {
  height: 0;
  overflow: hidden;
  opacity: 0;
}
.news-blog-container .tab-container {
  /* アクティブなタブ */
}
.news-blog-container .tab-container .tab-input:checked + .tab-title {
  background: #f5feff;
  border-bottom: none;
  border-top: solid 0.0694444444vw #004185;
  border-left: solid 0.0694444444vw #004185;
  border-right: solid 0.0694444444vw #004185;
}
@media (max-width: 600px) {
  .news-blog-container .tab-container .tab-input:checked + .tab-title {
    background: #effdfe;
    border-top: solid 0.2666666667vw #004185;
    border-left: solid 0.2666666667vw #004185;
    border-right: solid 0.2666666667vw #004185;
  }
}
.news-blog-container .tab-container .tab-input:checked + .tab-title + .tab-panel {
  padding-bottom: 20.8333333333vw;
  height: auto;
  overflow: auto;
  opacity: 1;
  transition: 0.5s opacity;
}
@media (max-width: 600px) {
  .news-blog-container .tab-container .tab-input:checked + .tab-title + .tab-panel {
    padding-bottom: 26.6666666667vw;
  }
}
.news-blog-container .tab-container {
  /* ラジオボタン非表示 */
}
.news-blog-container .tab-container .tab-input {
  display: none;
}
.news-blog-container {
  /* ニュースタブ */
}
.news-blog-container .post-news-section {
  padding-top: 6.9444444444vw;
  display: flex;
  flex-flow: column;
  align-items: center;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section {
    padding-top: 11.4666666667vw;
  }
}
.news-blog-container .post-news-section .news-list {
  display: flex;
  flex-flow: column;
  align-items: center;
  gap: 1.3888888889vw;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list {
    gap: 4.2666666667vw;
  }
}
.news-blog-container .post-news-section .news-list p {
  width: 64.4444444444vw;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list p {
    width: 100vw;
  }
}
.news-blog-container .post-news-section .news-list .news-item {
  display: flex;
  align-items: start;
  gap: 2.2784722222vw;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list .news-item {
    gap: 4.2666666667vw;
  }
}
.news-blog-container .post-news-section .news-list .news-item a {
  display: flex;
  align-items: start;
  gap: 2.7777777778vw;
  width: 64.4444444444vw;
  padding-top: 1.1111111111vw;
  padding-bottom: 2.7777777778vw;
  padding-left: 1.19375vw;
  border-bottom: 1px solid #DADEDF;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list .news-item a {
    flex-flow: column;
    gap: 3.2vw;
    width: 84vw;
    padding-top: 4.2666666667vw;
    padding-bottom: 4.2666666667vw;
    padding-left: 0;
  }
}
.news-blog-container .post-news-section .news-list .news-item .news-date {
  color: var(--CPC_a, #21B9D7);
  font-feature-settings: "palt" on;
  font-family: "Chillax", sans-serif;
  letter-spacing: 0.0486111111vw;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  text-transform: uppercase;
  width: 4.375vw;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list .news-item .news-date {
    font-size: 3.2vw;
    letter-spacing: 0.1866666667vw;
  }
}
.news-blog-container .post-news-section .news-list .news-item :hover .news-date {
  color: #28A7E1;
  transition: color 0.6s;
}
.news-blog-container .post-news-section .news-list .news-item .news-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--text, #011E55);
  font-feature-settings: "palt" on;
  font-family: "YuGothic", sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.0972222222vw;
  text-align: start;
  width: 54.1666666667vw;
}
@media (max-width: 600px) {
  .news-blog-container .post-news-section .news-list .news-item .news-title {
    font-size: 3.4666666667vw;
    letter-spacing: 0.3466666667vw;
    width: 84vw;
    white-space: initial;
    line-height: 20px;
  }
}
.news-blog-container .post-news-section .news-list .news-item :hover .news-title {
  color: #28A7E1;
  transition: color 0.6s;
}
.news-blog-container {
  /* BLOGタブ */
}
.news-blog-container .tab-wrapper {
  padding-top: 5.5902777778vw;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6944444444vw;
}
@media (max-width: 600px) {
  .news-blog-container .tab-wrapper {
    padding-top: 10.8vw;
    gap: 1.3333333333vw;
  }
}
.news-blog-container .tab-wrapper .tab:not(:last-of-type) {
  margin-right: 2px;
}
.news-blog-container input[name=tab-radio] {
  display: none;
}
.news-blog-container .tab-label {
  display: block;
  cursor: pointer;
  transition: 0.3s;
  border-bottom: 2px solid #F2F2F2;
  display: flex;
  width: 13.8888888889vw;
  padding: 1.0416666667vw 2.0833333333vw;
  justify-content: center;
  align-items: center;
  gap: 0.6944444444vw;
  border-radius: 69.4444444444vw;
  border: 0.0694444444vw solid #004185;
  background: #fff;
  color: #004185;
  text-align: center;
  font-family: "YuGothic", sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .news-blog-container .tab-label {
    width: auto;
    padding: 1.6vw 5.3333333333vw;
    gap: 0vw;
    border-radius: 266.6666666667vw;
    border: 0.2666666667vw solid #004185;
    font-size: 4vw;
    letter-spacing: 0.4vw;
  }
}
.news-blog-container .tab-label:hover {
  opacity: 0.7;
}
.news-blog-container .selected > .tab-label {
  transition: 0.3s;
  color: #fff;
  background-color: #004185;
}
.news-blog-container .tab-panel > div {
  display: flex;
}
.news-blog-container .panel-1,
.news-blog-container .panel-2,
.news-blog-container .panel-3,
.news-blog-container .panel-4,
.news-blog-container .panel-5 {
  display: none;
}
.news-blog-container .category-tab {
  padding-top: 5.5555555556vw;
  width: 58.3333333333vw;
  display: flex;
  align-content: start;
  flex-wrap: wrap;
  justify-content: start;
  gap: 1.3888888889vw;
}
@media (max-width: 600px) {
  .news-blog-container .category-tab {
    padding-top: 16vw;
    width: 91.4666666667vw;
    gap: 8vw;
    justify-content: center;
  }
}
.news-blog-container .category-tab p {
  width: 64.4444444444vw;
}
.news-blog-container .works_contents {
  width: 27.7777777778vw;
  display: flex;
  flex-direction: column;
  align-items: start;
}
@media (max-width: 600px) {
  .news-blog-container .works_contents {
    width: 76.2666666667vw;
  }
}
.news-blog-container .works_contents a.thumbnail-link {
  display: block;
  text-decoration: none;
  width: 100%;
  text-align: start;
}
.news-blog-container .works_contents a.thumbnail-link .thumb-wrapper {
  width: 100%;
  height: 15.625vw;
  overflow: hidden;
  position: relative;
}
@media (max-width: 600px) {
  .news-blog-container .works_contents a.thumbnail-link .thumb-wrapper {
    height: 42.8986666667vw;
  }
}
.news-blog-container .works_contents a.thumbnail-link .thumb-wrapper img.thumb {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.4s ease;
  display: block;
}
.news-blog-container .works_contents a.thumbnail-link .thumb-wrapper:hover img.thumb {
  transform: scale(1.05);
}
.news-blog-container .works_contents a.thumbnail-link .blog_date {
  font-family: "Chillax", sans-serif;
  letter-spacing: 0.0486111111vw;
  font-size: 0.9722222222vw;
  padding-top: 1.1111111111vw;
  color: var(--CPC_a, #21B9D7);
}
@media (max-width: 600px) {
  .news-blog-container .works_contents a.thumbnail-link .blog_date {
    letter-spacing: 0.1866666667vw;
    font-size: 3.3333333333vw;
    padding-top: 4.2666666667vw;
  }
}
.news-blog-container .works_contents a.thumbnail-link .blog-title {
  font-family: "YuGothic", sans-serif;
  padding-top: 1.1111111111vw;
  font-size: 0.9722222222vw;
  font-weight: 500;
  line-height: 1.25vw;
  word-break: break-word;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
@media (max-width: 600px) {
  .news-blog-container .works_contents a.thumbnail-link .blog-title {
    font-size: 3.7333333333vw;
    padding-top: 4.2666666667vw;
    line-height: 5.3333333333vw;
  }
}
.news-blog-container .pagination,
.news-blog-container .page-numbers {
  display: flex;
  justify-content: center;
  width: 66.9444444444vw;
  max-width: 66.9444444444vw;
  padding-top: 2.7777777778vw;
  padding-bottom: 2.0833333333vw;
  color: #000;
  text-align: center;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.0972222222vw;
}
@media (max-width: 600px) {
  .news-blog-container .pagination,
  .news-blog-container .page-numbers {
    width: 91.4666666667vw;
    padding-top: 10.6666666667vw;
    padding-bottom: 0vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.3733333333vw;
  }
}
.news-blog-container .pagination a,
.news-blog-container .pagination span,
.news-blog-container .page-numbers a,
.news-blog-container .page-numbers span {
  display: flex;
  flex-flow: column;
  align-items: center;
  justify-content: center;
  width: 4.7916666667vw;
  height: 5.1388888889vw;
  transition: 0.3s;
  border-bottom: 0.2777777778vw solid #fff;
}
@media (max-width: 600px) {
  .news-blog-container .pagination a,
  .news-blog-container .pagination span,
  .news-blog-container .page-numbers a,
  .news-blog-container .page-numbers span {
    width: 18.4vw;
    height: 19.7333333333vw;
    border-bottom: 1.0666666667vw solid #fff;
    padding-bottom: 8vw;
  }
}
.news-blog-container .pagination .current,
.news-blog-container .page-numbers .current {
  transition: 0.3s;
  border-bottom: 0.2777777778vw solid #28A7E1;
}
@media (max-width: 600px) {
  .news-blog-container .pagination .current,
  .news-blog-container .page-numbers .current {
    border-bottom: 1.0666666667vw solid #28A7E1;
  }
}

/* ////////////////////// POSTページ ///////////////////////// */
.post-navigation {
  padding-top: 17.2916666667vw;
}
@media (max-width: 600px) {
  .post-navigation {
    padding-top: 25.0666666667vw;
  }
}
.post-navigation .back-to-list {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 2.0833333333vw;
  width: 77.7777777778vw;
}
@media (max-width: 600px) {
  .post-navigation .back-to-list {
    gap: 2.6666666667vw;
    width: 84.5333333333vw;
  }
}
.post-navigation .back-to-list .back-arrow {
  width: 2.7083333333vw;
}
@media (max-width: 600px) {
  .post-navigation .back-to-list .back-arrow {
    width: 10.6666666667vw;
  }
}
.post-navigation .back-to-list .back-link {
  color: #000;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  /* calculate-vw(16px) */
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .post-navigation .back-to-list .back-link {
    font-size: 3.7333333333vw;
    padding-top: 1.0666666667vw;
  }
}

.post-content {
  margin-top: 6.25vw;
  width: 77.7777777778vw;
}
@media (max-width: 600px) {
  .post-content {
    margin-top: 8vw;
    width: 100vw;
    border-top: 0.2666666667vw solid #DADEDF;
    border-bottom: 0.2666666667vw solid #DADEDF;
  }
}
.post-content .post-item {
  display: flex;
  flex-flow: column;
  align-items: center;
  background: #fff;
}
.post-content .post-item .post-meta {
  display: flex;
  flex-flow: column;
  align-items: center;
  text-align: start;
}
.post-content .post-item .post-meta .post-date {
  width: 64.4444444444vw;
  margin-top: 6.9444444444vw;
  color: var(--CPC_a, #21B9D7);
  font-feature-settings: "palt" on;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.0972222222vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .post-content .post-item .post-meta .post-date {
    width: 84vw;
    margin-top: 8vw;
    font-size: 3.2vw;
    letter-spacing: 0.32vw;
  }
}
.post-content .post-item .post-meta .post-title {
  width: 64.4444444444vw;
  padding-top: 1.3888888889vw;
  text-align: start;
  color: #004185;
  font-feature-settings: "palt" on;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.9444444444vw;
  font-style: normal;
  font-weight: 600;
  line-height: 100%;
  letter-spacing: 0.1944444444vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .post-content .post-item .post-meta .post-title {
    width: 84vw;
    padding-top: 2.6666666667vw;
    font-size: 4.2666666667vw;
    letter-spacing: 0.4266666667vw;
  }
}
.post-content .post-item .post-meta .des-line-flame {
  width: 64.4444444444vw;
  padding-top: 2.7777777778vw;
  display: flex;
}
@media (max-width: 600px) {
  .post-content .post-item .post-meta .des-line-flame {
    display: none;
  }
}
.post-content .post-item .post-meta .des-line-flame .des-line-1 {
  width: 13.6111111111vw;
  border: 0.0694444444vw solid #28A7E1;
}
.post-content .post-item .post-meta .des-line-flame .des-line-2 {
  width: 100%;
  border: 0.0694444444vw solid #DADEDF;
}
.post-content .post-item .post-meta .thumb {
  padding-top: 2.7777777778vw;
  width: 64.4444444444vw;
}
@media (max-width: 600px) {
  .post-content .post-item .post-meta .thumb {
    padding-top: 5.3333333333vw;
    width: 84vw;
  }
}
.post-content .post-item .post-body {
  padding-top: 2.7777777778vw;
  padding-bottom: 6.9444444444vw;
  width: 64.4444444444vw;
  display: flex;
  flex-flow: column;
  align-items: start;
  gap: 2.7777777778vw;
  color: #000;
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 400;
  line-height: 2.7777777778vw;
  letter-spacing: 0.1111111111vw;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body {
    padding-top: 5.3333333333vw;
    padding-bottom: 13.3333333333vw;
    width: 84vw;
    gap: 5.3333333333vw;
    font-size: 3.7333333333vw;
    line-height: 7.4666666667vw;
    letter-spacing: normal;
  }
}
.post-content .post-item .post-body img {
  width: 64.4444444444vw;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body img {
    width: 84vw;
  }
}
.post-content .post-item .post-body h2 {
  font-size: 1.6666666667vw;
  color: #fff;
  background: #004185;
  font-weight: 700;
  padding: 0vw 0.6944444444vw;
  margin-top: 0.6944444444vw;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body h2 {
    font-size: 4.2666666667vw;
    padding: 0vw 2.6666666667vw;
    margin-top: 2.6666666667vw;
  }
}
.post-content .post-item .post-body h3 {
  font-size: 1.5277777778vw;
  font-weight: 700;
  color: #1679a8;
  border-bottom: 0.1388888889vw solid #21617e;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body h3 {
    font-size: 4.2666666667vw;
    border-bottom: 0.5333333333vw solid #21617e;
  }
}
.post-content .post-item .post-body h4 {
  font-size: 1.3888888889vw;
  font-weight: 700;
  color: #1679a8;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body h4 {
    font-size: 4.2666666667vw;
  }
}
.post-content .post-item .post-body ol {
  list-style-type: decimal;
  list-style-position: inside;
}
.post-content .post-item .post-body ul {
  list-style-type: disc;
  list-style-position: outside;
  margin-left: 1.3888888889vw;
}
@media (max-width: 600px) {
  .post-content .post-item .post-body ul {
    margin-left: 4.2666666667vw;
  }
}

.pagination {
  padding-top: 4.8611111111vw;
  padding-bottom: 20.8333333333vw;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.6666666667vw;
  max-width: 31.8055555556vw;
  flex-wrap: wrap;
}
@media (max-width: 600px) {
  .pagination {
    padding-top: 10.6666666667vw;
    padding-bottom: 26.6666666667vw;
    gap: 2.3466666667vw;
    max-width: 84.0533333333vw;
  }
}
.pagination .pagination-prev a,
.pagination .pagination-prev button {
  display: flex;
  align-items: center;
  display: inline-flex;
  padding: 1.0416666667vw 3.4722222222vw 1.0416666667vw 1.1111111111vw;
  align-items: center;
  background: #000;
  border-radius: 0.6944444444vw;
}
@media (max-width: 600px) {
  .pagination .pagination-prev a,
  .pagination .pagination-prev button {
    padding: 4vw 6.4vw 4vw 4.2666666667vw;
    border-radius: 2.6666666667vw;
  }
}
.pagination .pagination-prev a img,
.pagination .pagination-prev button img {
  width: 1.6666666667vw;
}
@media (max-width: 600px) {
  .pagination .pagination-prev a img,
  .pagination .pagination-prev button img {
    width: 5.12vw;
  }
}
.pagination .pagination-prev a span,
.pagination .pagination-prev button span {
  padding-left: 2.0833333333vw;
  color: #fff;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  /* calculate-vw(16px) */
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .pagination .pagination-prev a span,
  .pagination .pagination-prev button span {
    padding-left: 1.0666666667vw;
    font-size: 3.7333333333vw;
    line-height: 4.2666666667vw;
  }
}
.pagination .pagination-prev button {
  color: #fff;
  padding: 1.0416666667vw;
  cursor: pointer;
}
@media (max-width: 600px) {
  .pagination .pagination-prev button {
    padding: 4vw;
    font-size: 3.7333333333vw;
    line-height: 3.7333333333vw;
    font-weight: 400;
  }
}
.pagination .pagination-next a {
  display: flex;
  align-items: center;
  display: inline-flex;
  padding: 1.0416666667vw 1.1111111111vw 1.0416666667vw 3.4722222222vw;
  align-items: center;
  background: #000;
  border-radius: 0.6944444444vw;
}
@media (max-width: 600px) {
  .pagination .pagination-next a {
    padding: 4vw 4.2666666667vw 4vw 6.4vw;
    border-radius: 2.6666666667vw;
  }
}
.pagination .pagination-next a img {
  width: 1.6666666667vw;
  transform: rotate(180deg);
}
@media (max-width: 600px) {
  .pagination .pagination-next a img {
    width: 5.12vw;
  }
}
.pagination .pagination-next a span {
  padding-right: 2.0833333333vw;
  color: #fff;
  font-family: "YuGothic", sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  /* calculate-vw(16px) */
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .pagination .pagination-next a span {
    padding-left: 1.0666666667vw;
    font-size: 3.7333333333vw;
    line-height: 4.2666666667vw;
  }
}
.pagination .pagination-top {
  max-width: 31.8055555556vw;
  padding-top: 0.6944444444vw;
  font-weight: 500;
}
@media (max-width: 600px) {
  .pagination .pagination-top {
    max-width: 84.0533333333vw;
    font-size: 4.2666666667vw;
    padding-top: 5.3333333333vw;
  }
}
.pagination .none-p {
  width: 15vw;
  height: 0.6944444444vw;
}
@media (max-width: 600px) {
  .pagination .none-p {
    width: 40.8vw;
    height: 5.12vw;
  }
}

/* ////////////////////// CONTACTページ ///////////////////////// */
.contact-section {
  padding-top: 0vw;
  padding-bottom: 13.8888888889vw;
}
@media (max-width: 600px) {
  .contact-section {
    padding-bottom: 40vw;
  }
}
.contact-section .contact-intro {
  text-align: center;
  color: #000;
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  letter-spacing: 0.1111111111vw;
}
@media (max-width: 600px) {
  .contact-section .contact-intro {
    font-size: 3.7333333333vw;
    letter-spacing: 0.3733333333vw;
    line-height: 5.3333333333vw;
  }
}
.contact-section .required {
  padding-left: 0.3472222222vw;
  color: var(--CPC_a, #21B9D7);
  font-family: Inter, Arial, sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .contact-section .required {
    padding-left: 1.3333333333vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.3733333333vw;
  }
}
.contact-section p {
  display: flex;
  flex-flow: column;
  align-items: start;
  width: 51.1111111111vw;
  color: var(--text, #011E55);
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .contact-section p {
    padding-left: 0vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.3733333333vw;
    width: 91.4666666667vw;
  }
}
.contact-section p a {
  color: #28A7E1;
}
.contact-section .wpcf7-textarea {
  width: 51.1111111111vw;
  height: 17.3611111111vw;
  padding: 0.6944444444vw 1.0416666667vw;
  border: none;
  font-weight: 500;
  line-height: 2.0833333333vw;
  background: #fff;
  border: 1px solid #DDEDF9;
}
@media (max-width: 600px) {
  .contact-section .wpcf7-textarea {
    width: 91.4666666667vw;
    height: 66.6666666667vw;
    padding: 2.6666666667vw 4vw;
    line-height: 8vw;
  }
}
.contact-section .wpcf7-list-item {
  margin: 0;
}
.contact-section .wpcf7-validates-as-required {
  display: flex;
  gap: 2.7777777778vw;
  flex-wrap: wrap;
}
@media (max-width: 600px) {
  .contact-section .wpcf7-validates-as-required {
    gap: 10.6666666667vw;
  }
}
.contact-section .form-group {
  display: flex;
  flex-flow: column;
  align-items: center;
}
.contact-section .form-group input {
  background: #fff;
  border: none;
  border: 1px solid #DDEDF9;
}
.contact-section .form-group .v-line p {
  display: flex;
  flex-flow: column;
  align-items: start;
  gap: 0.6944444444vw;
  width: 25vw;
  color: #999999;
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.8333333333vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
  /* calculate-vw(12px) */
}
@media (max-width: 600px) {
  .contact-section .form-group .v-line p {
    gap: 2.6666666667vw;
    font-size: 3.2vw;
    width: 44.4vw;
  }
}
.contact-section .form-group.name-group {
  padding-top: 6.9444444444vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.name-group {
    padding-top: 16vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.name-group .name-inputs {
  padding-top: 1.3888888889vw;
  display: flex;
  gap: 1.1111111111vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.name-group .name-inputs {
    padding-top: 2.6666666667vw;
    gap: 2.6666666667vw;
  }
}
.contact-section .form-group.name-group .name-inputs p {
  display: flex;
}
.contact-section .form-group.name-group .name-inputs input {
  width: 25vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  color: #000;
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.name-group .name-inputs input {
    width: 44.4vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.furigana-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.furigana-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.furigana-group .furigana-inputs {
  padding-top: 1.3888888889vw;
  display: flex;
  gap: 1.1111111111vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.furigana-group .furigana-inputs {
    padding-top: 2.6666666667vw;
    gap: 2.6666666667vw;
  }
}
.contact-section .form-group.furigana-group .furigana-inputs p {
  display: flex;
}
.contact-section .form-group.furigana-group .furigana-inputs input {
  width: 25vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  color: #000;
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 500;
  line-height: 100%;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.furigana-group .furigana-inputs input {
    width: 44.4vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.company-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.company-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.company-group p {
  display: flex;
  flex-flow: column;
}
.contact-section .form-group.company-group input {
  width: 51.1111111111vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  font-weight: 500;
}
@media (max-width: 600px) {
  .contact-section .form-group.company-group input {
    width: 91.4666666667vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.phone-group {
  padding-top: 4.1666666667vw;
  display: flex;
  align-items: start;
  gap: 1.3888888889vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.phone-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
    gap: 2.6666666667vw;
  }
}
.contact-section .form-group.phone-group p {
  display: flex;
  flex-flow: column;
}
.contact-section .form-group.phone-group input {
  width: 51.1111111111vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  color: #999999;
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 500;
  line-height: 100%;
}
@media (max-width: 600px) {
  .contact-section .form-group.phone-group input {
    gap: 2.6666666667vw;
    font-size: 3.2vw;
    font-weight: 700;
    width: 91.4666666667vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.7333333333vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.email-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.email-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.email-group p {
  display: flex;
  flex-flow: column;
}
.contact-section .form-group.email-group input {
  width: 51.1111111111vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  font-weight: 500;
}
@media (max-width: 600px) {
  .contact-section .form-group.email-group input {
    width: 91.4666666667vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.email-confirm-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.email-confirm-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.email-confirm-group p {
  display: flex;
  flex-flow: column;
}
.contact-section .form-group.email-confirm-group input {
  width: 51.1111111111vw;
  height: 4.1666666667vw;
  padding: 0.6944444444vw 1.0416666667vw;
  font-weight: 500;
}
@media (max-width: 600px) {
  .contact-section .form-group.email-confirm-group input {
    width: 91.4666666667vw;
    height: 13.3333333333vw;
    padding: 2.6666666667vw 4vw;
    font-size: 3.2vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .form-group.inquiry-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.inquiry-group .checkbox-group {
  padding-top: 1.3888888889vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group .checkbox-group {
    padding-top: 5.6vw;
  }
}
.contact-section .form-group.inquiry-group .checkbox-group .wpcf7-validates-as-required {
  gap: 0.9722222222vw 2.7777777778vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group .checkbox-group .wpcf7-validates-as-required {
    gap: 5.3333333333vw 5.3333333333vw;
    display: flex;
    flex-wrap: wrap;
  }
}
.contact-section .form-group.inquiry-group .checkbox-group .checkbox {
  border: none;
}
.contact-section .form-group.inquiry-group .checkbox-group label {
  display: flex;
  align-items: center;
  gap: 0.6944444444vw;
  color: var(--text, #011E55);
  text-align: justify;
  font-family: Inter, Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-style: normal;
  font-weight: 400;
  line-height: 100%;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group .checkbox-group label {
    gap: 2.6666666667vw;
    font-size: 3.4666666667vw;
  }
}
.contact-section .form-group.inquiry-group .checkbox-group label {
  cursor: pointer;
}
.contact-section .form-group.inquiry-group .checkbox-group label input[type=checkbox][name="inquiry_type[]"] {
  margin: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 1.3888888889vw;
  height: 1.3888888889vw;
  background-color: #DCDCDC;
  border-radius: 0.2777777778vw;
  cursor: pointer;
  position: relative;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group .checkbox-group label input[type=checkbox][name="inquiry_type[]"] {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    border-radius: 1.0666666667vw;
  }
}
.contact-section .form-group.inquiry-group .checkbox-group label input[type=checkbox][name="inquiry_type[]"]:checked {
  background-color: var(--corporate-color-a, #28A7E1);
}
.contact-section .form-group.inquiry-group .checkbox-group label input[type=checkbox][name="inquiry_type[]"]:checked::after {
  content: "";
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 0.8333333333vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.inquiry-group .checkbox-group label input[type=checkbox][name="inquiry_type[]"]:checked::after {
    font-size: 3.2vw;
  }
}
.contact-section .form-group.privacy-group {
  padding-top: 4.1666666667vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.privacy-group {
    padding-top: 10.6666666667vw;
    display: flex;
    align-items: start;
    width: 91.4666666667vw;
  }
}
.contact-section .form-group.privacy-group p {
  display: flex;
  flex-flow: unset;
}
@media (max-width: 600px) {
  .contact-section .form-group.privacy-group p {
    flex-flow: initial;
    display: block;
    line-height: 5.3333333333vw;
  }
}
.contact-section .form-group.privacy-group input[type=checkbox][name="privacy_agree[]"] {
  margin: 0;
  margin-right: 0.6944444444vw;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 1.3888888889vw;
  height: 1.3888888889vw;
  background-color: #DCDCDC;
  border-radius: 0.2777777778vw;
  cursor: pointer;
  position: relative;
}
@media (max-width: 600px) {
  .contact-section .form-group.privacy-group input[type=checkbox][name="privacy_agree[]"] {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    border-radius: 1.0666666667vw;
  }
}
.contact-section .form-group.privacy-group input[type=checkbox][name="privacy_agree[]"]:checked {
  background-color: var(--corporate-color-a, #28A7E1);
}
.contact-section .form-group.privacy-group input[type=checkbox][name="privacy_agree[]"]:checked::after {
  content: "";
  color: #fff;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 0.8333333333vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.privacy-group input[type=checkbox][name="privacy_agree[]"]:checked::after {
    font-size: 3.2vw;
  }
}
.contact-section .form-group.privacy-group label {
  padding-top: 2.7777777778vw;
  display: flex;
  align-items: center;
}
@media (max-width: 600px) {
  .contact-section .form-group.privacy-group label {
    padding-top: 10.6666666667vw;
    gap: 2.6666666667vw;
  }
}
.contact-section .form-group.privacy-group label {
  cursor: pointer;
}
.contact-section .form-group.submit-group {
  padding-top: 6.9444444444vw;
}
@media (max-width: 600px) {
  .contact-section .form-group.submit-group {
    padding-top: 10.6666666667vw;
  }
}
.contact-section .form-group.submit-group p {
  display: flex;
  flex-flow: column;
  align-items: center;
}
.contact-section .form-group.submit-group p input {
  display: flex;
  width: 24.4444444444vw;
  height: 4.1666666667vw;
  padding: 1.1111111111vw 1.6666666667vw;
  justify-content: center;
  align-items: center;
  gap: 0.6944444444vw;
  flex-shrink: 0;
  background: #004185;
  color: #fff;
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  /* calculate-vw(16px) */
  letter-spacing: 0.2222222222vw;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .contact-section .form-group.submit-group p input {
    width: 91.4666666667vw;
    height: 16vw;
    padding: 4.2666666667vw 6.4vw;
    gap: 2.6666666667vw;
    font-size: 4.2666666667vw;
    letter-spacing: 0.8533333333vw;
  }
}
.contact-section .form-group.submit-group input[type=submit] {
  cursor: pointer;
}
.contact-section .wpcf7-list-item-label {
  font-weight: 500;
}
.contact-section .screen-reader-response {
  display: none;
}
.contact-section .wpcf7-response-output {
  display: none;
}
.contact-section .wpcf7-not-valid-tip {
  margin-top: 0.6944444444vw;
  color: #E74291;
  font-size: 1.1111111111vw;
  font-weight: 500;
}
@media (max-width: 600px) {
  .contact-section .wpcf7-not-valid-tip {
    margin-top: 1.6vw;
    font-size: 3.2vw;
  }
}
.contact-section .wpcf7-form-control-wrap {
  display: flex;
  flex-flow: column;
}
.contact-section .thanks {
  padding-top: 6.9444444444vw;
}
@media (max-width: 600px) {
  .contact-section .thanks {
    padding-top: 10.6666666667vw;
  }
}
.contact-section .thanks p {
  display: flex;
  flex-flow: column;
  align-items: center;
  color: #333;
  text-align: center;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.0416666667vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3888888889vw;
  letter-spacing: 0.1041666667vw;
}
@media (max-width: 600px) {
  .contact-section .thanks p {
    font-size: 3.4666666667vw;
    line-height: 6.4vw;
    letter-spacing: 0.4266666667vw;
  }
}
.contact-section .thanks span {
  color: #28A7E1;
  text-align: center;
  font-family: Inter, Arial, sans-serif;
  font-size: 1.3888888889vw;
  font-style: normal;
  font-weight: 700;
  line-height: 1.6666666667vw;
  /* 120% */
  letter-spacing: 0.1388888889vw;
}
@media (max-width: 600px) {
  .contact-section .thanks span {
    font-size: 4.2666666667vw;
    line-height: 5.3333333333vw;
    letter-spacing: 0.3466666667vw;
  }
}
.contact-section .init {
  display: flex;
  flex-flow: column;
  align-items: center;
}

.grecaptcha-badge {
  visibility: hidden;
}

.contact {
  padding: 17.3611111111vw 0 0;
  overflow: hidden;
  width: 59.8611111111vw;
}
@media (max-width: 600px) {
  .contact {
    padding: 41.6vw 0 0;
    width: 92.2666666667vw;
  }
}
.contact__inner {
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
  display: flex;
  flex-flow: column;
  align-items: center;
}
.contact__header {
  width: 59.8611111111vw;
  display: flex;
  flex-flow: column;
  align-items: start;
  margin-bottom: 5.5555555556vw;
}
@media (max-width: 600px) {
  .contact__header {
    width: 93.3333333333vw;
    margin-bottom: 13.3333333333vw;
  }
}
.contact__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.0680555556vw;
  line-height: 1.2;
  margin: 0 0 8px;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  .contact__title {
    font-size: 8vw;
  }
}
.contact__subtitle {
  color: #011E55;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0;
}
.contact__subtitle span {
  margin-right: 8px;
  color: #999999;
}
@media (max-width: 600px) {
  .contact__subtitle {
    font-size: 3.2vw;
  }
}
.contact__content {
  position: relative;
  padding: 5.5555555556vw 0;
}
@media (max-width: 600px) {
  .contact__content {
    padding: 16vw 0;
  }
}
.contact__content::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 32%;
  width: 100vw;
  z-index: 0;
}
.contact__message-box {
  position: relative;
  z-index: 1;
  background-color: #ffffff;
  width: 59.8611111111vw;
  padding: 5.5555555556vw 6.1805555556vw;
  box-sizing: border-box;
  box-shadow: 10px 30px 50px 0 rgba(194, 215, 219, 0.4);
}
@media (max-width: 600px) {
  .contact__message-box {
    padding: 10.6666666667vw;
    width: 85.3333333333vw;
  }
}
.contact .business-cta-simple {
  width: 100%;
  display: flex;
  justify-content: center;
}
.contact .business-cta-simple__inner {
  width: 100%;
  display: flex;
  justify-content: center;
}
.contact .business-cta-simple__box {
  width: 59.8611111111vw;
  text-align: start;
  display: flex;
  flex-direction: column;
}
@media (max-width: 600px) {
  .contact .business-cta-simple__box {
    width: 91.4666666667vw;
  }
}
.contact .business-cta-simple__heading {
  color: var(--text, #011E55);
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin: 0 0 2.0833333333vw;
}
@media (max-width: 600px) {
  .contact .business-cta-simple__heading {
    font-size: 4.2666666667vw;
    margin-bottom: 8vw;
  }
}
.contact .business-cta-simple__note {
  color: var(--BK, #000);
  font-family: "DIN 2014", Arial, sans-serif;
  font-size: 0.9722222222vw;
  font-weight: 700;
  line-height: 1.6;
  margin: 0;
}
@media (max-width: 600px) {
  .contact .business-cta-simple__note {
    font-size: 3.7333333333vw;
  }
}
.contact .business-cta-simple__link {
  color: var(--CPC_a, #21B9D7);
  text-decoration: underline;
  text-underline-offset: 4px;
  transition: opacity 0.3s;
}
.contact .business-cta-simple__link:hover {
  opacity: 0.7;
}

/* ////////////////////// 投稿ページ ///////////////////////// */
.wp-block-image {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.aligncenter {
  display: block;
  /* ブロック要素化 */
  margin-left: auto;
  margin-right: auto;
}

.alignright {
  display: block;
  /* ブロック要素化 */
  margin-left: auto;
}

.post-body a {
  color: #090;
}

/* ////////////////////// 採用ページ ///////////////////////// */
.recruit {
  padding: 17.3611111111vw 0 13.8888888889vw;
  overflow: hidden;
  width: 100vw;
}
@media (max-width: 600px) {
  .recruit {
    padding: 41.6vw 0 42.6666666667vw;
  }
}
.recruit__inner {
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
  display: flex;
  flex-flow: column;
  align-items: center;
}
.recruit__header {
  width: 59.8611111111vw;
  display: flex;
  flex-flow: column;
  align-items: start;
  margin-bottom: 4.1666666667vw;
}
@media (max-width: 600px) {
  .recruit__header {
    width: 85.3333333333vw;
  }
}
.recruit__title {
  font-family: "Chillax", sans-serif;
  font-size: 3.1944444444vw;
  font-weight: 500;
  letter-spacing: 0.0680555556vw;
  line-height: 1.2;
  margin: 0 0 8px;
  background: linear-gradient(to right, #204e8a 0%, #56aed0 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@media (max-width: 600px) {
  .recruit__title {
    font-size: 8vw;
  }
}
.recruit__subtitle {
  color: #011E55;
  font-size: 1.1111111111vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  margin: 0;
}
.recruit__subtitle span {
  margin-right: 8px;
  color: #1a2b4c;
}
@media (max-width: 600px) {
  .recruit__subtitle {
    font-size: 3.2vw;
  }
}
.recruit__content {
  position: relative;
  padding: 5.5555555556vw 0;
}
@media (max-width: 600px) {
  .recruit__content {
    padding: 16vw 0;
  }
}
.recruit__content::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 32%;
  width: 100vw;
  background-color: #e6eff4;
  z-index: 0;
}
.recruit__message-box {
  position: relative;
  z-index: 1;
  background-color: #ffffff;
  width: 59.8611111111vw;
  padding: 5.5555555556vw 6.1805555556vw;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 10px 30px 50px 0 rgba(194, 215, 219, 0.4);
}
@media (max-width: 600px) {
  .recruit__message-box {
    padding: 10.6666666667vw;
    width: 85.3333333333vw;
  }
}
.recruit__message {
  color: #011E55;
  font-size: 1.25vw;
  font-weight: 600;
  letter-spacing: 0.1em;
  margin: 0;
}
@media (max-width: 600px) {
  .recruit__message {
    font-size: 3.7333333333vw;
  }
}
@media screen and (max-width: 768px) {
  .recruit {
    padding: 42.6666666667vw 0;
  }
  .recruit__header {
    margin-bottom: 13.3333333333vw;
  }
  .recruit__content::before {
    left: 26%;
  }
}/*# sourceMappingURL=style.css.map */