a {
  text-decoration: none;
  color: #0d1a38;
}

/* 基本設定 */
.sp_only {
  display: none;
}

@media (max-width: 768px) {
  .sp_only {
    display: block;
  }
}

@media (max-width: 768px){
  .pconly{
    display: none !important;
  }
}

@media (min-width: 769px){
  .sponly{
    display: none !important;
  }
}


.one_button_search {
  display: inline-block;
  padding: 7px 15px;
  border: 1px solid #0e9deb;
  border-radius: 5px;
  box-shadow: 0 0 7px #e1e1e1;
  transition: all .3s;
  font-weight: 600;
  margin-right: 10px;
}

.one_button_search:hover {
  background-color: #0e9deb;
  color: #fff;
}

#modal-footer-wrapper_id_01,
#modal-footer-wrapper_id {
  display: none;
}

.inner_container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* MV */

.main_banner {
  background-image: url("../image/mv_bg.webp");
  background-size: cover;
  background-repeat: no-repeat;
  height: 400px;
}

.mv_area {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}

.mv_area_left {
  flex: 1;
  color: white;
}

.mv_catch {
  font-size: 42px;
  font-weight: bold;
  margin-bottom: 8px;
}

.mv_catch span.color{
  color: #1b2f5b;
}

.mv_catch span.mv_title{
  font-size: 28px;
  font-weight: bold;
  background: white;
  display: block;
  padding: 4px 0 2px;
  margin: 15px 0 20px;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Roboto, "Droid Sans", "Yu Gothic", Meiryo, "Meiryo UI", sans-serif !important;
  width: 210px;
  text-align: center;
}
.mv_catch span.mv_title > span{
  font-weight: bold;
  background: linear-gradient(90deg, #3875bf, #81c6f5, #3270bd);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}


.mv_consult_box {
  background: white;
  border-radius: 12px;
  padding: 16px 24px;
  max-width: 500px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.mv_consult_text {
  font-size: 18px;
  text-align: center;
  color: #222;
  margin-bottom: 12px;
  font-weight: 600;
}

.mv_consult_text span {
  background: linear-gradient(transparent 70%, #fff176 70%);
}

.mv_buttons {
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.mv_buttons .btn {
  display: inline-block;
  width: 220px;
  padding: 7px 7px 7px 15px;
  border-radius: 25px;
  font-size: 17px;
  font-weight: bold;
  text-decoration: none;
  white-space: nowrap;
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: center;
  transition: .3s;
}

.mv_buttons .btn:hover {
  transform: scale(1.1);
}

.mv_buttons .btn.dark {
  background: #1e254c;
  color: #fff;
  padding-left: 50px;
}

.mv_buttons .btn.light {
  background: #eef5ff;
  color: #1e254c;
  border: 2px solid #1e254c;
}

.mv_buttons .btn.light span {
  width: 35px;
  height: 35px;
  background: #1e254c;
  color: #fff;
  border-radius: 50%;
  line-height: 35px;
}

.mv_buttons .btn.dark span {
  width: 35px;
  height: 35px;
  background: #eef5ff;
  color: #1e254c;
  border-radius: 50%;
  line-height: 35px;
}

.mv_area_right {
  flex: 1;
  background: #ccc;
  display: flex;
  justify-content: center;
  height: 400px;
  min-width: 300px;
  font-size: 40px;
  font-weight: bold;
  border-radius: 30px;
}

.mv_area_right .video_area video {
  width: 100%;
  height: 400px;
  object-fit: cover;
  border-radius: 30px;
}

@media (max-width: 1024px) {
  .mv_area {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
  }

  .main_banner {
    height: auto;
  }

  .mv_consult_box {
    margin: 0 auto;
  }

  .mv_area_right .video_area video {
    display: block;
  }
}

@media (max-width: 820px) {
  .main_banner {
    background-image: url("../image/mv_bg_sp.webp");
    background-size: contain;
  }

  .mv_area_right .video_area video {
    height: 250px;
  }

  .mv_catch span.mv_title {
    font-size: 24px;
    width: 180px;
  }

  .mv_catch {
    font-size: 28px;
    margin-top: 30px;
  }


  .mv_buttons {
    flex-direction: column;
    align-items: center;
  }

  .mv_consult_box {
    margin: 130px auto 10px;
  }
}

@media (max-width: 440px) {
  .mv_area {
    gap: 10px;
  }

  .mv_consult_box {
    margin: 0 auto;
  }
}

/* END｜MV */

/*就職に役立つ情報を発信*/

.column-section {
  background: #edf5fb;
  padding: 50px 20px;
  text-align: center;
}

.column-label {
  font-size: 18px;
  letter-spacing: 1px;
  color: #333;
  font-weight: 600;
}

.column-title {
  font-size: 44px;
  font-weight: bold;
  color: #0f2344;
  margin: 10px 0;
}

.column-sub {
  font-size: 18px;
  color: #222;
  font-weight: 500;
}

.column-sub span {
  color: #189CEA;
  font-weight: 600;
}

.column-highlight {
  font-size: 22px;
  color: #189CEA;
  font-weight: 500;
  margin: 50px 0;
}


.search-box {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 400px;
  background: #fff;
  border-radius: 25px;
  overflow: hidden;
  box-shadow: 0 0 6px rgba(0, 0, 0, 0.1);
  margin-bottom: 40px;
}

.search-box input {
  border: none;
  padding: 12px 16px;
  flex-grow: 1;
  font-size: 14px;
}

.search-box input[type="text"]:focus {
  outline: none;
}

.search-box button {
  background: none;
  border: none;
  padding: 0 16px;
  font-size: 16px;
  cursor: pointer;
}

.column-section .search-box {
  margin: 20px auto 50px;
}

.column-slider {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 0 10px;
}

.column-slider::-webkit-scrollbar {
  height: 6px;
}

.column-slider::-webkit-scrollbar-thumb {
  background-color: #ccc;
  border-radius: 3px;
}

.column-card {
  min-width: 200px;
  background: #fff;
  border-radius: 10px;
  scroll-snap-align: start;
  flex-shrink: 0;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.05);
}

.column-card img {
  width: 100%;
  height: auto;
  border-radius: 10px 10px 0 0;
}

.card-title {
  font-size: 14px;
  font-weight: bold;
  margin: 10px;
  color: #222;
}

.card-tags {
  font-size: 12px;
  color: #666;
  margin: 0 10px 10px;
}


/* トップページ｜企業ロゴスライド */
.slider-container {
  overflow: hidden;
  margin: 20px 0;
}

.slider-container .slider {
  width: 100%;
  position: relative;
}

.slider-container .slides {
  display: flex;
  width: 200%;
}

.slider-container .slide {
  flex-basis: 50%;
  display: flex;
  align-items: center;
}

.slider-container .slide img {
  flex-basis: var(--logo-width, 10.84%);
  width: 10.84%;
  padding: 5px 20px;
  height: 80px;
  object-fit: contain;
}

.slider-container .slides {
  animation: slide var(--duration, 10s) linear infinite;
}

@keyframes slide {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

@keyframes slide_alternate {
  0% {
    transform: translateX(-50%);
  }

  100% {
    transform: translateX(0%);
  }
}

@media screen and (max-width: 1440px) {
  .slider-container .slide img {
    flex-basis: var(--logo-width, 8.84%);
    width: 8.84%;
  }

  .slider-container {
    margin: 20px 0;
  }
}

@media screen and (max-width: 767px) {
  .column-title {
    font-size: 36px;
  }

  .column-card {
    min-width: 150px;
  }

  .slider-container .slider {
    width: 200%;
  }

  .slider-container .slides {
    width: 400%;
  }
}

/* END トップページ｜企業ロゴスライド */

/* トップページ｜新着求人 */
.job-section {
  background: #eaf3f9;
  padding: 60px 0;
  overflow-x: hidden;
}

.job_inner_container {
  width: 100%;
  box-sizing: border-box;
  padding-left: calc((100vw - 1200px) / 2);
  padding-right: 0;
}

.job-inner {
  display: flex;
  gap: 120px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.job-info {
  flex: 0 0 500px;
}

.job-label {
  font-size: 18px;
  color: #234;
  margin-bottom: 6px;
  font-weight: 600;
}

.job-title {
  font-size: 44px;
  font-weight: bold;
  color: #10234a;
}

.job-desc {
  font-size: 16px;
  line-height: 1.8;
  margin: 16px 0;
  color: #222;
}

.job-btn {
  display: inline-flex;
  background-color: #1a2b5b;
  align-items: center;
  justify-content: center;
  padding: 10px 10px 10px 35px;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  color: #fff;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
  box-shadow: 0 3px 3px #a0a0a0;
}

.job-btn span {
  width: 35px;
  height: 35px;
  display: inline-block;
  background: #fff;
  color: #1a2b5b;
  border-radius: 50%;
  transition: background 0.3s ease;
  margin-left: 15px;
  line-height: 35px;
  text-align: center;
}

.job-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
  color: #fff;
}

.job-slider {
  position: relative;
  flex: 1;
  height: 300px;
  overflow: hidden;
}

.job-slider_abso {
  position: absolute;
  display: flex;
  gap: 16px;
  will-change: transform;
}

.job-card {
  flex: 0 0 240px;
  background: #fff;
  border-radius: 12px;
  padding: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.badge {
  display: inline-block;
  background: #e0eeff;
  color: #2b66b4;
  font-size: 12px;
  padding: 4px 10px;
  border-radius: 10px;
  margin-bottom: 8px;
  font-weight: bold;
}

.job-card-title {
  font-size: 16px;
  font-weight: bold;
  margin-bottom: 10px;
  line-height: 1.4;
}

.job-features {
  font-size: 14px;
  list-style: none;
  padding-left: 0;
  color: #444;
  margin-bottom: 10px;
}

.job-features li {
  margin-bottom: 4px;
}

.job-card img {
  width: 100%;
  border-radius: 8px;
}

@media (max-width: 1220px) {
  .inner_container {
    padding-left: 20px;
  }
}

@media (max-width: 1280px) {
  .inner_container {
    padding-left: 20px;
    padding-right: 20px;
  }

  .job-info {
    flex: 1 1 auto;
    width: 100%;
    padding: 0 20px;
  }

  .job-slider_abso {
    position: relative;
    width: 100%;
  }

  .job-inner {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 768px) {
  .job-title {
    font-size: 36px;
    font-weight: bold;
    color: #10234a;
  }
}

/* END｜トップページ｜新着求人 */

/* REASON */
.reason-section {
  background: #f1f8fc;
  padding: 130px 20px;
}

.reason-label {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 1px;
  color: #333;
  margin-bottom: 8px;
}

.reason-title {
  font-size: 44px;
  font-weight: bold;
  margin-bottom: 40px;
  color: #10234a;
}

.reason-list {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.reason-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 100px;
  margin-bottom: 70px;
}

.reason-item.reverse {
  flex-direction: row-reverse;
}

.reason-text {
  flex: 1;
  min-width: 300px;
}

.reason-heading {
  font-size: 44px;
  font-weight: bold;
  color: #4889EC;
  margin-bottom: 12px;
}

.reason-text p {
  font-size: 16px;
  color: #333;
  line-height: 1.6;
}

.reason-text .highlight {
  color: #4889EC;
  font-weight: bold;
  /* text-decoration: underline; */
}

.reason-text a {
  color: #4889EC;
  text-decoration: underline;
  font-weight: bold;
}

.reason-img {
  flex: 1;
  min-width: 300px;
  text-align: center;
  position: relative;
}

.reason-img img {
  max-width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: 0 10px 22px rgba(72, 137, 236, 0.3);
}

.reason-img01,
.reason-img03 {
  position: absolute;
  top: -50px;
  left: -20%;
}

.reason-img02 {
  position: absolute;
  top: -85px;
  right: -10%;
}

.reason-img01 img,
.reason-img02 img,
.reason-img03 img {
  width: 300px;
}

@media (max-width: 768px) {
  .reason-title {
    font-size: 36px;
  }

  .reason-heading {
    font-size: 24px;
  }

  .reason-img01,
  .reason-img03 {
    left: 0;
    right: 0;
  }

  .reason-img02 {
    left: 0;
    right: 0;
  }
}

/* END｜REASON */

/* ヘッダー */
#header_area {
  width: 100%;
  max-width: 1200px !important;
  background-color: #fff;
}

#header_area .header {
  height: 100px;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Roboto, "Droid Sans", "Yu Gothic", Meiryo, "Meiryo UI", sans-serif !important;
}

.header-right nav ul {
  display: flex;
  gap: 50px;
  margin: 0 100px 0 0;
}

.header-right nav ul li {
  position: relative;
  list-style: none;
}

.header-right nav ul li a {
  font-weight: 600;
  padding-bottom: 5px;
  position: relative;
}

.header-right nav ul li ul li {
  padding: 10px 20px 15px;
  background-color: #edf5fb;
}

.header-right nav ul li ul li a {
  line-height: 2.5;
}

.header-right nav ul li a::before {
  background: #1f2c5c;
  content: '';
  width: 100%;
  height: 1.5px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: transform .3s;
}

.header-right nav ul li a:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}

.header-left .header-left__logo {
  flex-direction: column;
  align-items: start;
  margin-top: 10px;
  margin-bottom: -3px;
}

.header-left .header-left__logo p {
  font-size: 12px;
}

.header-left .header-left__logo img {
  margin-top: -5px;
}

.company_btn a {
  display: inline-block;
  background-color: #1f2c5c;
  color: #fff;
  font-weight: 600;
  padding: 5px 20px;
  border-radius: 7px;
  box-shadow: 2px 2px 3px #ADADAD;
  transition: .3s;
}

.company_btn a:hover {
  box-shadow: 5px 5px 10px #ADADAD;
}

.company_btn a img {
  width: 25px;
  height: auto;
  object-fit: cover;
  margin-left: 20px;
}

/* サブメニューのスタイル */
.header-right nav ul.sub-menu {
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.3s ease;
  position: absolute;
  top: 100%;
  left: 0;
  background: white;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  min-width: 200px;
  padding: 10px 0;
  pointer-events: none;
}

.sub-menu li {
  display: block;
}

.sub-menu li a {
  padding: 10px 20px;
  white-space: nowrap;
}

.has-submenu:hover .sub-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

@media (max-width: 1280px) {
  .header-left .header-left__logo {
    margin-left: 20px;
  }
}

@media (max-width: 768px) {
  #header_area .header {
    height: 70px;
  }

  .header-left .header-left__logo img {
    max-width: 160px;
    max-height: 40px;
  }

  .header-left .header-left__logo {
    margin-top: 20px;
  }
}

/* 共通スタイル */
.menu-toggle {
  display: none;
  position: absolute;
  top: 25px;
  right: 20px;
  width: 30px;
  height: 22px;
  flex-direction: column;
  justify-content: space-between;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 1001;
}

.menu-toggle span {
  display: block;
  height: 3px;
  background-color: #1f2c5c;
  border-radius: 2px;
  transition: all 0.3s ease;
}

.menu-toggle.open span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.menu-toggle.open span:nth-child(2) {
  opacity: 0;
}

.menu-toggle.open span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

/* ドロワーメニュー */
.drawer-menu {
  background: #fff;
  width: 100%;
  max-width: 100%;
  padding: 20px;
  position: fixed;
  top: 0;
  right: -100%;
  height: 100vh;
  overflow-y: auto;
  z-index: 9999;
  box-shadow: -4px 0 8px rgba(0, 0, 0, 0.1);
  transition: right 0.3s ease;
}

.drawer-menu.open {
  right: 0;
}

.drawer-header {
  position: relative;
}

.drawer-header img {
  vertical-align: inherit;
}

.drawer-header .logo {
  height: 26px;
}

.drawer-caption {
  display: inline-block;
  font-size: 12px;
  color: #444;
  margin: 6px 0;
}

.drawer-close {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 32px;
  background: none;
  border: none;
  cursor: pointer;
}

.drawer-body {
  display: flex;
  flex-direction: column;
  gap: 30px;
  margin-top: 30px;
}

.drawer-section {
  border-bottom: 1px solid #ddd;
  padding-bottom: 12px;
}

.drawer-label {
  font-size: 18px;
  font-weight: bold;
  color: #1f2c5c;
  display: flex;
  align-items: center;
  gap: 8px;
}

.drawer-label span {
  font-size: 12px;
  color: #444;
  font-weight: 600;
}

.icon-external {
  width: 14px;
  height: 14px;
}

.drawer-search {
  display: flex;
  border: 2px solid #1f2c5c;
  border-radius: 25px;
  overflow: hidden;
}

.drawer-search input {
  flex: 1;
  border: none;
  padding: 10px 14px;
  font-size: 14px;
}

.drawer-search .search-icon {
  background: none;
  border: none;
  padding: 10px 14px;
  font-size: 16px;
  cursor: pointer;
}

.drawer-links {
  list-style: none;
  padding-left: 0;
  margin-left: 30px;
}

.drawer-links li {
  margin-top: 12px;
}

.drawer-links a {
  font-size: 16px;
  font-weight: bold;
  color: #1f2c5c;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
}

.circle-arrow {
  display: inline-block;
  width: 28px;
  height: 28px;
  background: #7da3e6;
  color: white;
  border-radius: 50%;
  font-size: 16px;
  text-align: center;
  line-height: 28px;
}

/* PCとSP切り替え */
@media (max-width: 1024px) {

  .header-right nav,
  .company_btn {
    display: none;
  }

  .menu-toggle {
    display: flex;
  }

  .menu-toggle {
    top: 15px;
  }

  #header_area.fixed .header-left .header-left__logo {
    justify-content: center;
  }
}

/* PC表示時の固定スタイル */
#header_area.fixed {
  /* 画面上部に固定 */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 100% !important;
  z-index: 999;
  /* 他の要素より手前に表示 */

  /* 固定時に元のヘッダーの背景色と影を適用 */
  background-color: #fff;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);

  /* アニメーションで滑らかに表示 */
  transform: translateY(-100%);
  animation: slideDown 0.4s ease-out forwards;
}

/* ヘッダーが表示される際のアニメーション */
@keyframes slideDown {
  from {
    transform: translateY(-100%);
  }

  to {
    transform: translateY(0);
  }
}

/* 固定時のヘッダー内部のスタイル */
#header_area.fixed .header {
  /* 元の高さ100pxから20%減らして80pxに設定 */
  height: 80px;
  /* 横幅と中央寄せを維持 */
  max-width: 1200px;
  margin: 0 auto;
  /* 高さの変更を滑らかにする */
  transition: height 0.3s ease-in-out;
}

/* 固定時にロゴの上部マージンを調整 */
#header_area.fixed .header-left .header-left__logo {
  margin-top: 0;
}


/* スマートフォン表示時の固定スタイル */
@media (max-width: 768px) {
  #header_area.fixed .header {
    /* SP版の元の高さ70pxから20%減らして56pxに設定 */
    height: 56px;
  }

  /* 固定時にロゴが中央に来るように調整 */
  #header_area.fixed .header-left .header-left__logo {
    margin-top: 0;
  }
}

/* END｜ヘッダー */

/* フッター */
.site-footer {
  position: relative;
  width: 100%;
  background: linear-gradient(to bottom, #008DFB, #69AAE9);
  color: #ffffff;
  padding: 50px 0 5px;
  overflow: hidden;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Roboto, "Droid Sans", "Yu Gothic", Meiryo, "Meiryo UI", sans-serif;
}

.site-footer::before {
  content: '';
  position: absolute;
  top: 0;
  right: -100%;
  width: 100%;
  height: 100%;
  background-color: #E3F2FA;
  opacity: 0.1;
  transform: skewX(-65deg);
  transform-origin: top right;
  z-index: 1;
}

.site-footer .footer-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 2;
}

.site-footer .footer_top {
  text-align: center;
  margin-bottom: 50px;
}

.site-footer .catchphrase {
  margin-bottom: 25px;
  font-size: 17px;
}

.site-footer .main-logo {
  display: block;
  margin: 0 auto 25px auto;
  height: auto;
  width: 300px;
}

.site-footer .phone-number {
  margin: 0;
  font-size: 24px;
  font-weight: bold;
}

.site-footer .phone-number img {
  width: 20px;
  margin-right: 5px;
}

.site-footer .footer-main {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.site-footer .footer-column {
  margin: 0 10px 30px 10px;
}

.site-footer .footer-column ul li img {
  width: 20px;
}

.site-footer .footer-heading {
  font-size: 16px;
  font-weight: 500;
  background-color: rgba(255, 255, 255, 0.8);
  padding: 4px 12px;
  display: inline-block;
  margin-top: 0;
  margin-bottom: 20px;
  width: 100%;
  color: #5E98DE;
  text-align: center;
  box-sizing: border-box;
}

.site-footer .footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-footer .footer-links li {
  margin-bottom: 12px;
}

.site-footer .footer-links a {
  color: #ffffff;
  text-decoration: none;
  font-size: 16px;
}

.site-footer .footer-links a:hover {
  text-decoration: underline;
}

.site-footer .menu-column {
  width: 170px;
}

.site-footer .sns-column {
  width: 250px;
}

.site-footer .sns-column .sns-logo {
  display: block;
  margin-bottom: 20px;
  height: 80px;
  width: 100%;
  object-fit: contain;
  padding: 0 20px;
  box-sizing: border-box;
}

.site-footer .sns-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.site-footer .sns-links li {
  margin-bottom: 15px;
}

.site-footer .sns-links a {
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
}

[class^="icon-"] {
  display: inline-block;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  margin-right: 10px;
  position: relative;
  font-style: normal;
  text-align: center;
  line-height: 24px;
  color: white;
  font-weight: bold;
}

.site-footer .icon-tiktok {
  background-color: #25F4EE;
}

.site-footer .icon-instagram {
  background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
}

.site-footer .icon-x {
  background-color: #000000;
}

.site-footer .footer_bottom {
  text-align: center;
  margin-top: 30px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.8);
}

.site-footer .sns-button {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #ffffff;
  color: #000000;
  border: none;
  border-radius: 50px;
  padding: 8px 20px;
  font-size: 16px;
  font-weight: 500;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  width: 100%;
  transition: all .3s;
}

.site-footer .sns-button .account-name {
  margin-left: 35px;
  margin-right: 30px;
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Roboto, "Droid Sans", "Yu Gothic", Meiryo, "Meiryo UI", sans-serif;
}

/* 左側のアイコン */
.site-footer .sns-button.tiktok::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 21px;
  height: 23px;
  background-image: url('../image/tiktok_logo.svg');
  background-size: cover;
  background-repeat: no-repeat;
}

.site-footer .sns-button.insta::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 23px;
  height: 23px;
  background-image: url('../image/insta_logo.svg');
  background-size: cover;
  background-repeat: no-repeat;
}

.site-footer .sns-button.x_twitter::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 21px;
  background-image: url('../image/x_logo.svg');
  background-size: cover;
  background-repeat: no-repeat;
}

.site-footer .sns-button::after {
  content: '→';
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: #1D2A51;
  color: #ffffff;
  font-size: 16px;
  text-align: center;
  line-height: 28px;
}

.site-footer .sns-links .sns-button:hover {
  transform: scale(0.9, 0.9);
}

.site-footer .connection_site ul li a {
  position: relative;
}

.site-footer .connection_site ul li a::after {
  content: '';
  position: absolute;
  right: -25px;
  top: 50%;
  transform: translateY(-50%);
  width: 15px;
  height: 15px;
  background-image: url('../image/union_icon.webp');
  background-size: cover;
  background-repeat: no-repeat;
}

@media screen and (max-width: 1023px) {

  .site-footer .menu-column,
  .site-footer .sns-column {
    width: 40%;
    padding: 0 20px;
  }
}

@media screen and (max-width: 767px) {

  .site-footer .menu-column,
  .site-footer .sns-column {
    width: 90%;
    padding: 0 20px;
  }
}

/* END｜フッター */

/* 会社概要 */
.about-section {
  display: flex;
  min-height: 400px;
}

.about-left {
  flex: 1;
  background-image: url('../image/about_image.jpg');
  background-size: cover;
  background-position: center;
}

.about-right {
  flex: 1;
  background: #fff;
  padding: 60px 40px 10px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #1D2A51;
}

.about-label {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 1px;
  margin-bottom: 8px;
}

.about-title {
  font-size: 44px;
  font-weight: bold;
  margin-bottom: 35px;
}

.about-list {
  font-size: 16px;
  line-height: 1.8;
  font-weight: 600;
}

.about-list .about-row {
  display: flex;
  align-items: flex-start;
  margin-bottom: 20px;
}

.about-list dt {
  width: 120px;
  font-weight: bold;
  color: #1D2A51;
  flex-shrink: 0;
}

.about-list dd {
  margin: 0;
  color: #1D2A51;
  line-height: 1.6;
}

@media (max-width: 1024px) {
  .about-list {
    font-size: 15px;
  }
  .about-list .about-row{
    margin-bottom: 16px;
  }
  .footer-top .footer-top-phone {
    font-size: 36px;
  }

  .about-section {
    flex-direction: column;
    min-height: 400px;
  }

  .about-left {
    flex: unset;
    height: 300px;
  }
}

@media (max-width: 1024px) {
  .about-title {
    font-size: 36px;
  }
}

/* END｜会社概要 */

/*JOB-SEARCH*/
/* 基本設定 */
.job_main-content {
  position: relative;
  width: 100%;
  padding: 130px 0;
  background: linear-gradient(90deg, #008DFB, #69AAE9, #2CB6D0);
  overflow: hidden;
  color: #fff;
}

/* インナー幅とカラム設定 */
.job_main-content .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
}

.left-column,
.right-column {
  display: flex;
  gap: 120px;
}

.left-column {
  margin-bottom: 80px;
}

/* 共通タイトル */
.job_main-content .section-title .en-title {
  font-size: 18px;
  font-weight: bold;
  margin: 0 0 10px;
  opacity: 0.8;
  color: #fff;
}

.job_main-content .section-title .main-title {
  font-size: 44px;
  font-weight: 600;
  margin: 0;
  color: #fff;
}

/* 左カラム：求人検索 */
.job_main-content .job-search-section {
  width: 50%;
}

.job_main-content .feature-section {
  width: 50%;
}

.job_main-content .job-search-section .sub-heading {
  margin: 30px 0 20px;
  font-size: 20px;
  font-weight: 600;
}

.job_main-content .job-search-section .sub-heading::before {
  margin-right: 20px;
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url('../image/search_icon_white.svg');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.job_main-content .search-box {
  background-color: #fff;
  border-radius: 5px;
  padding: 30px;
  width: 400px;
}

.job_main-content .search-tabs {
  display: flex;
  gap: 10px;
  justify-content: space-between;
}

.job_main-content .tab-button {
  width: 160px;
  padding: 12px;
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
  box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1);
}

.job_main-content .tab-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
  color: #fff;
}

.job_main-content .tab-button.mijimu {
  background: linear-gradient(90deg, #F598AB, #F38590, #F6758C);
  color: #fff;
  border-color: transparent;
}

.job_main-content .tab-button.miengi {
  background: linear-gradient(90deg, #008DFB, #69AAE9);
  color: #fff;
  border-color: transparent;
}

/* 左カラム：スマホモックアップ */
.job_main-content .smartphone-section {
  position: relative;
  height: 400px;
  /* 高さを確保 */
  margin-top: 40px;
  width: 50%;
}

.job_main-content .media-section {
  width: 50%;
}

.job_main-content .smartphone-mockup {
  position: relative;
}

.job_main-content .smartphone-mockup img {
  position: absolute;
  width: 450px;
  z-index: 1;
}

.job_main-content .smartphone-mockup video {
  position: absolute;
  width: 196px;
  height: 385px;
  top: 7px;
  left: 9px;
  border-radius: 28px 28px 0 0;
  object-fit: cover;
  z-index: 2;
}

/* 右カラム：特徴セクション */
.job_main-content .right-column .feature-block {
  margin-bottom: 60px;
}

.job_main-content .right-column h3 {
  font-size: 24px;
  margin: 0 0 15px;
}

.job_main-content .right-column .stat-circle p {
  font-size: 14px;
  line-height: 1.2;
  margin: 0;
  font-weight: 500;
}

.job_main-content .stats-container {
  display: flex;
  gap: 10px;
  margin-top: 40px;
}

.job_main-content .stat-item {
  text-align: center;
  width: 25%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}



.job_main-content .stat-circle {
  width: 120px;
  height: 120px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
}

.job_main-content .inner-circle {
  background-color: #4e8fb8;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  position: absolute;
}

.job_main-content .inner-circle img {
  width: 120px;
  height: 120px;
}

.stat-label {
  font-size: 12px;
  z-index: 1;
  line-height: 1.3;
  color: #189CEA;
  font-weight: 600;
  margin-bottom: 0;
}

.stat-percent {
  font-size: 36px;
  font-weight: bold;
  z-index: 1;
  color: #189CEA;
  line-height: 1.2;
}

.stat-percent span {
  font-size: 16px;
}

.stat-label_bigtext {
  display: block;
  font-size: 22px;
}

/* 右カラム：メディアセクション */
.tiktok-link {
  display: inline-flex;
  align-items: center;
  gap: 15px;
  background-color: #fff;
  color: #111;
  border-radius: 99px;
  text-decoration: none;
  font-weight: bold;
  margin-top: 30px;
  transition: transform 0.2s;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}

.tiktok-link span {
  padding: 12px 40px 12px 10px;
  font-weight: 500;
}

.tiktok-link:hover {
  transform: scale(1.05);
}

.tiktok-link::before {
  content: "";
  display: inline-block;
  width: 30px;
  height: 30px;
  background-image: url('../image/tiktok.svg');
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 15px;
}

.dot {
  position: absolute;
  border-radius: 60%;
}

.pink {
  background: #f36;
  z-index: 1;
  animation: pulsePink 3s infinite ease-in-out;
}

.cyan {
  background: #0ff;
  z-index: 2;
  animation: pulseCyan 3s infinite ease-in-out;
  animation-delay: 1.5s;
}

#pinkContainer {
  position: absolute;
  left: -10%;
  top: -65%;
  z-index: 0;
}

#cyanContainer {
  position: absolute;
  left: -55%;
  top: -25%;
  z-index: 0;
}

@keyframes pulsePink {

  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.6;
  }

  50% {
    transform: scale(1.2);
    opacity: 0.8;
  }
}

@keyframes pulseCyan {

  0%,
  100% {
    transform: scale(0.8);
    opacity: 0.6;
  }

  50% {
    transform: scale(1.2);
    opacity: 0.8;
  }
}


/* --------------------------------
  レスポンシブ対応
-------------------------------- */
@media (max-width: 1024px) {
  .inner {
    flex-direction: column;
  }

  .left-column,
  .right-column {
    width: 100%;
    gap: 60px;
  }

  .job_main-content .smartphone-mockup img {
    position: relative;
    width: 100%;
    height: 35vh;
    object-fit: contain;
  }

  #pinkContainer,
  #cyanContainer {
    display: none;
  }

  .smartphone-section {
    margin-bottom: 60px;
  }

  .job_main-content .search-box {
    width: 95%;
  }

  .job_main-content .search-tabs {
    justify-content: space-around;
  }

  .job_main-content .tab-button {
    width: 130px;
  }

  .job_main-content .smartphone-mockup video {
    width: 189px;
    height: 370px;
    top: 37px;
    left: 9px;
    border-radius: 28px 28px 0 0;
  }
}

@media (max-width: 820px) {

  .left-column,
  .right-column {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .job_main-content .job-search-section {
    width: 95%;
  }

  .job_main-content {
    padding: 60px 0;
  }

  .job_main-content .inner {
    padding: 0 20px;
  }

  .section-title .main-title {
    font-size: 36px;
  }

  .job_main-content .stats-container {
    justify-content: center;
  }

  .job_main-content .section-title .main-title {
    font-size: 36px;
  }

  .stat-item {
    width: 100%;
    max-width: 250px;
  }

  .job_main-content .feature-section {
    width: 95%;
  }

  .job_main-content .media-section {
    width: 95%;
  }

  .job_main-content .smartphone-mockup video {
    width: 166px;
    height: 325px;
    top: 28px;
    left: 8px;
    border-radius: 25px 25px 0 0;
  }
}

@media (max-width: 460px) {
  .job_main-content .search-box {
    box-sizing: border-box;
  }

  .job_main-content .stat-item {
    width: 30%;
  }

  .job_main-content .smartphone-section {
    width: 100%;
    height: auto;
    margin-top: 0;
    margin-bottom: 0;
  }

  .feature-block {
    padding: 0 20px;
  }

  .tiktok-area {
    text-align: center;
  }

  .job_main-content .smartphone-mockup img {
    height: auto;
  }

  .job_main-content .smartphone-mockup {
    width: 340px;
    margin: 0 auto;
  }

  .job_main-content .smartphone-mockup video {
    width: 149px;
    height: 291px;
    top: 5px;
    left: 7px;
    border-radius: 20px 20px 0 0;
  }

}

/*END｜JOB-SEARCH*/

/*SERVICE-ABOUT*/
.service-section {
  width: 100%;
  background-color: #fdfdfd;
  /* 画像の背景色に近い色 */
  padding: 75px 0;
  overflow: hidden;
  /* 背景画像がはみ出ないように */

  /* 背景画像（ダミー）の設定 */
  /* background-image: url('../image/about_bg.webp');
  background-repeat: no-repeat;
  background-size: cover;
  /* または 700px など具体的なサイズ */
  /* background-position: 70% center; */
  /* 右寄せで中央に配置 */
}

.service-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  position: relative;
}
.service-inner > img{
  position: absolute;
  height: calc(100% + 150px);
  bottom: -75px;
  right: 0;
}

/*  左側：テキストとボタン */
.service-content {
  width: 50%;
  padding-right: 40px;
}

.service-subtitle {
  font-size: 18px;
  font-weight: bold;
  color: #555;
  margin: 0 0 10px 0;
  letter-spacing: 1px;
}

.service-title {
  font-size: 44px;
  font-weight: bold;
  margin: 0 0 30px 0;
  line-height: 1.4;
  color: #2c3e50;
  /* タイトルの色 */
}

.service-description {
  color: #333;
  margin-bottom: 40px;
  line-height: 1.8;
  max-width: 450px;
}

.service-description span {
  display: block;
  font-weight: 600;
  font-size: 18px;
}

/*  ボタン */
.button-container {
  display: flex;
  gap: 20px;
  /* ボタン間のスペース */
  position: relative;
  z-index: 100;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 10px 10px 35px;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  color: #fff;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
  color: #fff;
}

/* 1つ目のボタン（グラデーション） */
.btn-pink {
  background: linear-gradient(90deg, #F598AB, #F38590, #F76B89);
}

/* 2つ目のボタン（グラデーション） */
.btn-blue {
  background: linear-gradient(90deg, #008DFB, #69AAE9, #2CB6D0);
}

.btn-pink span,
.btn-blue span {
  display: inline-block;
  width: 35px;
  height: 35px;
  background-color: #fff;
  border-radius: 50%;
  margin-left: 15px;
  position: relative;
  line-height: 35px;
}

.btn-pink span {
  color: #F76B89;
}

.btn-blue span {
  color: #008DFB;
}

/*  レスポンシブ対応 */
@media (max-width: 1024px) {
  .service-content {
    width: 60%;
  }
}

@media (max-width: 992px) {
  .service-title {
    font-size: 36px;
  }

  .service-section {
    padding: 100px 0 50px;
    overflow: hidden;

    /* 背景画像（ダミー）の設定 */
    /* background-image: url('../image/about_bg_sp.webp');
    background-repeat: no-repeat;
    background-size: contain;
    /* または 700px など具体的なサイズ */
    /* background-position: 90% center; */
    position: relative;
  }
  .service-section > img{
    position: absolute;
    top: 0;
    right: -5%;
    height: 250px;
    width: auto;
  }


  .service-content {
    width: 100%;
    padding-right: 0;
  }

  .service-content_box {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 20px;
  }

  .service-description {
    margin-left: auto;
    margin-right: auto;
  }

  .button-container {
    justify-content: center;
    flex-direction: column;
    align-items: center;
  }

  .btn {
    width: 85%;
    max-width: 300px;
  }
}

/*END｜SERVICE-ABOUT*/

/**** 就業までの流れ ****/

/* セクション全体 */
.flow-section {
  padding: 130px 0;
  width: 100%;
  background-color: #fff;
  box-sizing: border-box;
}

/* インナー幅の制御 */
.flow-section .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  box-sizing: border-box;
}

/* タイトルブロック */
.flow-section .title-block {
  text-align: left;
  margin-bottom: 80px;
}

.flow-section .en-title {
  font-size: 18px;
  color: #1D2A51;
  ;
  margin: 0 0 10px;
  font-weight: bold;
}

.flow-section .main-title {
  font-size: 44px;
  color: #1D2A51;
  ;
  margin: 0;
  font-weight: bold;
}

/* フローリスト */
.flow-list {
  list-style: none;
  padding: 0;
  margin: 0;
}


/* =============================================================
  フローアイテムのレイアウト設定 (CSS Grid)
============================================================= */

/* PC表示のスタイル (デフォルト) */
.flow-item {
  display: grid;
  /* "アイコン" "タイトル" "説明文" の3カラム構成に変更 */
  grid-template-columns: 100px auto 1fr;
  /* 各要素を配置するエリアに名前をつける */
  grid-template-areas:
    "icon label       label"
    "icon title       description"
    "icon .           description";
  /* カラム間の隙間 */
  column-gap: 30px;
  align-items: flex-end;
  position: relative;
}

.flow-item:not(:last-child) {
  padding-bottom: 60px;
}

.flow-item_step {
  width: 250px;
}

/* 各要素を名前をつけたエリアに配置 */
.flow-icon-wrapper {
  grid-area: icon;
  position: relative;
  display: flex;
  justify-content: center;
}

.step-label {
  grid-area: label;
  padding-top: 0;
}

.step-title {
  grid-area: title;
  align-self: start;
  /* 上揃えにする */
}

.step-description {
  grid-area: auto;
  align-self: start;
}
.step-description>p{
  padding-top: 24px;
}
@media screen and (max-width: 767px){
  .step-description>p{
    font-size: 14px;
  }
}
/* アイコンの円 */
.flow-icon {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background-image: linear-gradient(135deg, #189CEA, #94ACD7, #9DD6D2);
  display: flex;
  justify-content: center;
  align-items: center;
}

.flow-icon img {
  width: 60%;
  height: 60%;
  object-fit: contain;
}

/* 縦の点線 */
.flow-icon-wrapper::after {
  content: '';
  position: absolute;
  top: 100px;
  left: 50%;
  transform: translateX(-50%);
  border-left: 2px dashed #ccc;
  height: calc(100% - 100px + 60px);
}

.flow-item:last-child .flow-icon-wrapper::after {
  display: none;
}


/* テキスト関連のスタイル */
.step-label {
  font-size: 18px;
  color: #488AED;
  margin: 0 0 5px;
  font-weight: bold;
}

.step-title {
  font-size: 26px;
  color: #488AED;
  margin: 0;
  font-weight: bold;
  white-space: nowrap;
  /* タイトルが改行しないように */
}

.step-description {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
  margin: 0;
}


/* --------------------------------
  レスポンシブ対応 (992px以下)
-------------------------------- */
@media (max-width: 992px) {
  .main-title {
    font-size: 36px;
  }

  /* カラム構成を元の2カラムに戻す */
  .flow-item {
    grid-template-columns: 100px 1fr;
    grid-template-areas:
      "icon label"
      "icon title"
      "icon description";
    column-gap: 40px;
    align-items: flex-start;
  }
}


/* --------------------------------
  レスポンシブ対応 (768px以下)
-------------------------------- */
@media (max-width: 767px) {
  .flow-section .main-title {
    font-size: 36px;
  }

  .flow-item_step {
    width: auto;
  }

  .flow-section {
    padding: 60px 0;
  }

  .flow-section .inner {
    padding: 0 20px;
  }

  .main-title {
    font-size: 32px;
  }

  .title-block {
    margin-bottom: 60px;
  }

  /* --- ここからスマホ用のGridレイアウトに上書き --- */
  .flow-item {
    /* "左カラム(110px)"と"右カラム"の2列構成に変更 */
    grid-template-columns: 110px 1fr;
    /* スマホ用のエリア配置に変更 */
    grid-template-areas:
      "label       description"
      "title       description"
      "icon        description"
      ".           description";
    column-gap: 20px;
  }

  .flow-item:not(:last-child) {
    padding-bottom: 0;
  }

  /* テキストやアイコンの位置を微調整 */
  .step-label,
  .step-title {
    text-align: center;
    padding-top: 0;
  }

  .step-title {
    font-size: 18px;
    margin-bottom: 10px;
  }

  .step-description {
    padding-top: 5px;
  }

  .flow-icon-wrapper {
    position: absolute;
    bottom: 0;
  }

  .flow-list .flow_icon_step1 {
    padding-bottom: 100px;
  }

  .flow-list .flow_icon_step2 {
    padding-bottom: 70px;
  }

  .flow-list .flow_icon_step3 {
    padding-bottom: 50px;
  }

  .flow-list .flow_icon_step4 {
    padding-bottom: 50px;
  }


  .flow_icon_step1 .flow-icon-wrapper {
    bottom: -50px;
  }

  .flow_icon_step2 .flow-icon-wrapper {
    bottom: -20px;
  }

  .flow_icon_step5 .flow-icon-wrapper {
    bottom: -30px;
  }

  /* 点線の高さを再計算 */
  .flow-icon-wrapper::after {
    height: calc(100% - 100px + 40px);
  }
}

@media (max-width: 410px) {
  .flow-list .flow_icon_step2 {
    padding-bottom: 50px;
  }

  .flow-list .flow_icon_step4 {
    padding-bottom: 20px;
  }

  .flow_icon_step1 .flow-icon-wrapper {
    bottom: -50px;
  }

  .flow_icon_step2 .flow-icon-wrapper {
    bottom: -20px;
  }

  .flow_icon_step4 .flow-icon-wrapper {
    bottom: 15px;
  }

  .flow_icon_step5 .flow-icon-wrapper {
    bottom: -25px;
  }
}

/**** END｜就業までの流れ ****/

/**** 利用者の声 ****/
.voice-section {
  padding: 130px 0;
  width: 100%;
  /* 背景色をグラデーションで指定 */
  background-image: url('../image/voice_bg.webp');
  background-size: cover;
  background-position: center;
}
.voice-section .en-title{
  font-weight: bold;
}
/* インナー幅の制御 */
.voice-section .inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 40px;
  /* PCでの左右の余白 */
  box-sizing: border-box;
}

/* タイトルブロック */
.title-block {
  text-align: center;
  margin-bottom: 60px;
}

.en-title {
  font-size: 18px;
  color: #fff;
  margin: 0 0 10px;
}

.main-title {
  font-size: 44px;
  color: #fff;
  margin: 0;
  font-weight: bold;
}

/* カードリスト */
.card-list {
  display: flex;
  justify-content: space-between;
  gap: 30px;
  /* カード間の余白 */
}

/* カード各アイテム */
.card-item {
  width: calc(33.333% - 20px);
  /* gapを考慮した幅計算 */
  background-color: #fff;
  border-radius: 20px;
  padding: 40px;
  box-sizing: border-box;
  text-align: center;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
}

/* カード上部の人物画像エリア */
.card-img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: #3f83f8;
  /* 画像がない場合のプレースホルダー色 */
  margin: 0 auto 20px;
  overflow: hidden;
  /* 画像を円形に切り抜く */
}

/* 人物画像（imgタグを入れる場合） */
.card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.card-name {
  font-size: 20px;
  font-weight: bold;
  color: #333;
  margin: 0;
}

.card-meta {
  font-size: 14px;
  color: #666;
  margin: 5px 0 20px;
}

.card-text {
  font-size: 16px;
  color: #333;
  line-height: 1.8;
  text-align: left;
  /* 本文は左揃えの方が見やすい */
  margin: 0;
}

/* ボタン */
.more-button-wrapper {
  text-align: center;
  margin-top: 60px;
}

.more-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #1a2b5b;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  padding: 10px 10px 10px 60px;
  border-radius: 9999px;
  text-decoration: none;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
  width: 250px;
  box-shadow: 0 3px 5px #707070;
}

.more-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
  color: #fff;
}

/* ボタンの矢印 */
.more-button span {
  display: inline-block;
  margin-left: 35px;
  background-color: #fff;
  color: #374151;
  width: 35px;
  height: 35px;
  border-radius: 50%;
  line-height: 35px;
  text-align: center;
}

/* --------------------------------
  レスポンシブ対応 (992px以下)
-------------------------------- */
@media (max-width: 992px) {
  .card-list {
    flex-direction: column;
    /* 縦並びに */
    align-items: center;
    /* 中央寄せ */
    gap: 40px;
  }

  .card-item {
    width: 100%;
    max-width: 500px;
    /* スマホでの最大幅を指定 */
  }

  .main-title {
    font-size: 36px;
  }
}


/* --------------------------------
  レスポンシブ対応 (768px以下)
-------------------------------- */
@media (max-width: 768px) {
  .voice-section {
    padding: 60px 0;
  }

  .voice-section .inner {
    padding: 0 20px;
    /* スマホでの左右の余白 */
  }

  .main-title {
    font-size: 36px;
  }

  .en-title {
    font-size: 16px;
  }

  .card-item {
    padding: 30px;
  }
}

/**** END｜利用者の声 ****/

/**** 派遣用語集 ****/

/* セクション全体 */
.glossary-section {
  width: 100%;
  padding: 80px 0;
  background-color: #F2F9FD;
}

.glossary-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ヘッダー（タイトルなど）*/
.glossary-header {
  margin-bottom: 40px;
}

.glossary-subtitle {
  font-size: 18px;
  font-weight: bold;
  color: #555;
  letter-spacing: 1px;
  margin: 0 0 10px 0;
}

.glossary-title {
  font-size: 44px;
  font-weight: bold;
  color: #2c3e50;
  margin: 0 0 20px 0;
}

.glossary-description {
  font-size: 16px;
  line-height: 1.8;
  color: #555;
}

/* フィルターボタン */
.filter-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  margin-bottom: 40px;
}

.filter-btn {
  width: 150px;
  padding: 12px 25px;
  font-size: 16px;
  font-weight: 500;
  border: none;
  background-color: #F3F5F7;
  color: #34495e;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s;
}

.filter-btn:hover {
  background-color: #cadbe5;
}

.filter-btn.active {
  background-color: #189CEA;
  color: #fff;
}

@media (max-width: 992px) {
  .filter-btn {
    width: calc(98% / 4);
    padding: 10px;
  }
}

/* アコーディオン */
.accordion-container {
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

.glossary-section .accordion-item:not(:last-child) {
  border-bottom: 1px solid #e0e0e0;
}

.glossary-section .accordion-header {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 25px;
  background: linear-gradient(90deg, #189CEA, #94ACD7, #9DD6D2);
  color: #fff;
  font-size: 20px;
  font-weight: bold;
  cursor: pointer;
  border: none;
  text-align: left;
}

/* アクティブなヘッダー */
.glossary-section .accordion-item.active .accordion-header {
  background: #3498db;
}

.glossary-section .toggle-icon {
  font-size: 28px;
  font-weight: bold;
}

.glossary-section .accordion-content {
  max-height: 0;
  overflow: hidden;
  background-color: #fff;
  transition: max-height 0.4s ease-out;
}

/* アクティブ状態のスタイル */
.glossary-section .accordion-item.active .toggle-icon {
  transform: rotate(180deg);
  color: #fff;
}

.glossary-section .accordion-item.active .accordion-content {
  max-height: 500px;
  /* 必要に応じて調整 */
  transition: max-height 0.4s ease-in;
}

.terms-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background-color: #eaf1f5;
  /* グリッドの境界線色 */
  padding: 25px;
}

.term-link {
  background-color: #fff;
  padding: 20px;
  text-decoration: none;
  color: #3498db;
  font-weight: 500;
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: background-color 0.2s;
  border: none;
  /* buttonのスタイルリセット */
  width: 100%;
  font-size: 16px;
}

.term-link:hover {
  background-color: #f8fafd;
}

.term-link::after {
  content: '>';
  color: #bdc3c7;
  font-weight: bold;
}

@media (max-width: 992px) {
  .terms-grid {
    grid-template-columns: repeat(1, 1fr);
  }

  .glossary-title {
    font-size: 36px;
  }
}

/* ポップアップ（モーダル） */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;

  /* アニメーション設定 */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease;
}

.modal-overlay.visible {
  opacity: 1;
  visibility: visible;
}

.modal-content {
  background-color: #fff;
  padding: 40px;
  border-radius: 8px;
  width: 90%;
  max-width: 600px;
  position: relative;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.2);

  /* アニメーション設定 */
  transform: scale(0.95) translateY(10px);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
}

.modal-overlay.visible .modal-content {
  transform: scale(1) translateY(0);
  opacity: 1;
}

.modal-close {
  position: absolute;
  top: 15px;
  right: 15px;
  font-size: 28px;
  font-weight: bold;
  color: #95a5a6;
  cursor: pointer;
  border: none;
  background: none;
}

.modal-close:hover {
  color: #7f8c8d;
}

.modal-title {
  font-size: 24px;
  color: #2c3e50;
  margin: 0 0 20px 0;
}

.modal-body {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

/**** END｜派遣用語集 ****/

/**** よくある質問 ****/

/* FAQセクション全体 */
.faq-section {
  width: 100%;
  background-color: #fff;
  padding: 80px 0;
}

.faq-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0 20px;
}

/* 左側：タイトルとボタン */
.faq-info {
  width: 30%;
  padding-right: 40px;
}

.faq-subtitle {
  font-size: 18px;
  font-weight: bold;
  color: #555;
  margin: 0 0 10px 0;
}

.faq-title {
  font-size: 44px;
  font-weight: bold;
  margin: 0 0 20px 0;
  line-height: 1.4;
}

.faq-description {
  color: #555;
  margin-bottom: 40px;
  line-height: 1.8;
}

.contact-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 20px 40px;
  background-color: #2c3e50;
  /* 元のボタン色 */
  color: #ffffff;
  /* 元のテキスト色 */
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 50px;
  border: 2px solid #2c3e50;
  cursor: pointer;
  transition: background-color 0.3s, color 0.3s;
}

.contact-button .arrow {
  margin-left: 15px;
  background-color: #fff;
  color: #2c3e50;
  border-radius: 50%;
  width: 30px;
  height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.3s, color 0.3s;
}

/* ボタンホバー時の色の反転 */
.contact-button:hover {
  background-color: #ffffff;
  color: #2c3e50;
}

.contact-button:hover .arrow {
  background-color: #2c3e50;
  color: #ffffff;
}


/* 右側：アコーディオン */
.faq-section .accordion-container {
  width: 70%;
}

.faq-section .accordion-item {
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  margin-bottom: 32px;
  overflow: hidden;
  box-shadow: 0 3px 8px #e0e0e0;
}

.faq-section .accordion-question {
  width: 100%;
  background-color: #fff;
  padding: 18px;
  display: flex;
  align-items: center;
  cursor: pointer;
  border: none;
  /* buttonのデフォルトスタイル解除 */
  text-align: left;
  /* buttonのデフォルトスタイル解除 */
}

.q-icon,
.a-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 20px;
}

.q-icon {
  background-color: #4a90e2;
}

.a-icon {
  background-color: #e67e22;
  margin-top: 25px;
}


.question-text {
  flex-grow: 1;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.6;
}

.toggle-icon {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: #4a90e2;
  font-size: 24px;
  font-weight: bold;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s, background-color 0.3s, color 0.3s;
}

.accordion-answer {
  /* JSでmax-heightを切り替えて開閉を実現 */
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease-out, padding 0.5s ease-out;
  background-color: #f7faff;
}

.answer-content {
  padding: 0 25px;
  /* JSで開くときにpaddingを追加 */
  display: flex;
  align-items: flex-start;
}

.answer-text {
  color: #333;
  font-size: 16px;
  line-height: 1.8;
  padding: 25px 0;
  flex-grow: 1;
}

/* アクティブ状態のスタイル */
.faq-section .accordion-item.active .toggle-icon {
  transform: rotate(180deg);
  /* background-color: #4a90e2; */
  color: #4a90e2;
}

.faq-section .accordion-item.active .accordion-answer {
  /* 十分な高さを設定 */
  max-height: 500px;
  /* 回答の最大量に応じて調整 */
  transition: max-height 0.5s ease-in-out;
}

.faq-section .accordion-item.active .answer-content {
  padding-right: 25px;
  padding-left: 18px;
  /* JSで開くときにpaddingを追加 */
}


/* レスポンシブ対応 */
@media (max-width: 992px) {
  .faq-inner {
    flex-direction: column;
  }

  .faq-info,
  .faq-section .accordion-container {
    width: 100%;
  }

  .faq-info {
    padding-right: 0;
    margin-bottom: 40px;
    text-align: center;
  }

  .faq-title {
    font-size: 36px;
  }
}
@media (min-width: 993px){
  .faq-section .accordion-container {
    width: 80%;
    max-width: 800px;
    margin: auto;
  }
}
/**** END｜よくある質問 ****/

/**** コラム一覧 ****/

/* セクション全体 */
.column-section {
  width: 100%;
  padding: 130px 0 90px;
  background-color: #E3F2FA;
}

.column-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ヘッダー（タイトル）*/
.section-header {
  margin-bottom: 50px;
}

.section-subtitle {
  font-size: 18px;
  font-weight: bold;
  color: #555;
  letter-spacing: 1px;
  margin: 0 0 10px 0;
}

.section-title {
  font-size: 44px;
  font-weight: bold;
  color: #2c3e50;
  margin: 0;
}

/* コラムカードのグリッド設定 */
.column-grid {
  display: grid;
  /* PC: 4列表示 */
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}

/* コラムカード本体 */
.column-card {
  display: block;
  text-decoration: none;
  color: inherit;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.column-card:hover {
  transform: translateY(-5px);
}

/* カード上部：画像エリア */
.card-image-container {
  position: relative;
  color: #fff;
  height: 55%;
}

.card-image-container img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

/* 画像の上のオーバーレイ */
.card-image-container::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to top, rgba(44, 62, 80, 0.8), rgba(44, 62, 80, 0.1));
}

.card-category {
  position: absolute;
  top: 15px;
  left: 15px;
  background-color: rgba(0, 0, 0, 0.4);
  padding: 5px 10px;
  font-size: 12px;
  border-radius: 4px;
  z-index: 1;
}

.card-image-title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 18px;
  font-weight: bold;
  line-height: 1.4;
  z-index: 1;
  width: 85%;
  margin: 0;
}

/* カード下部：テキストエリア */
.card-content {
  padding: 20px;
}

.card-title {
  font-size: 15px;
  line-height: 1.7;
  margin: 0 0 15px 0;
  /* 複数行のテキストが長すぎる場合に省略する設定 */
  height: 51px;
  /* 1.7 * 15px * 2行 */
  overflow: hidden;
}

.card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 13px;
  color: #555;
}


/* レスポンシブ対応 */
@media (max-width: 992px) {
  .section-title {
    font-size: 36px;
  }

  .column-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .card-image-title {
    font-size: 16px;
  }

  .card-image-container {
    height: 45%;
  }

  .card-title {
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 15px 0;
    /* 複数行のテキストが長すぎる場合に省略する設定 */
    height: 45px;
    /* 1.7 * 15px * 2行 */
    overflow: hidden;
  }

  .card-content {
    padding: 20px 10px;
  }
}

/**** END｜コラム一覧 ****/

/* other */

section#why-choose-us_section {
  margin-bottom: 0;
}

section#why-choose-us_section .why-choose-us_content {
  margin-bottom: 0;
}

.form .formbox form .formpart .forminput input[type="tel"] {
  width: 100%;
  background: #f5f5f5;
  border: 1px solid #d9d9d9;
  border-radius: 4px;
  font-size: 18px;
  padding: 5px 10px;
}

/* コラム自動取得 */
/* スライダー全体 */
.column-swiper#column-top{
  width: 100%;
  padding: 20px 30px 60px;
}
/* スライド内のカードデザイン */
#column-top .swiper-slide{
  width: auto;
}
#column-top .swiper-slide a {
  display: block;
  text-decoration: none;
  color: inherit;
}
#column-top .swiper-slide .image img {
  width: 100%;
  display: block;
  height: 150px;
  object-fit: cover;
}
#column-top .swiper-slide .category {
  margin: 10px 0;
  text-align: left;
}
#column-top .swiper-slide .category span {
  border: 1px solid;
  padding: 2px;
  color: #0fa8fb;
}
#column-top .swiper-slide h3 {
  font-size: 18px;
  font-weight: bold;
  text-align: left;
  margin: 0;
  color: black;
}
#column-top .swiper-button-next,
#column-top .swiper-button-prev{
  top: 45%;
  color: white;
  background: #3f9ef0;
  width: 30px;
  height: 30px;
  border-radius: 50%;
}
#column-top .swiper-button-next:after,
#column-top .swiper-button-prev:after{
  font-size: 16px;
}
#column-top .swiper-pagination-bullet {
  background-color: #ccc;
  opacity: 1;
}
#column-top .swiper-pagination-bullet-active {
  background-color: #0fa8fb;
}
.feature-section > p{
  font-size: 12px;
  margin: 10px 0 0;
}
@media (max-width: 768px){
  .column-section{
    padding: 60px 0 90px;
  }
  #column-top .swiper-button-next,
  #column-top .swiper-button-prev{
    top: 40%;
  }
  #column-top .column-section{
    padding: 60px 0;
  }
  .feature-section > p{
    font-size: 10px;
    margin: 10px 0 0;
  }
}

/* END｜other */
