@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* -----------TOP--------------------- */

/* ヘッダー */
.l-header.-series.-series-right {
  background-image: linear-gradient(
    0deg,
    rgba(206, 219, 229, 1) 5%,
    rgba(229, 237, 241, 1) 17%,
    rgba(248, 249, 251, 1) 31%,
    rgba(255, 255, 255, 1) 50%,
    rgba(248, 249, 251, 1) 67%,
    rgba(229, 237, 241, 1) 83%,
    rgba(206, 219, 229, 1) 95%
  );
}

.l-container {
  padding-left: 0;
  padding-right: 0;
}
.l-container header {
  max-with: none !important;
}

.top #content {
  margin-bottom: 0;
}

.l-fixHeader__inner.l-container {
  background-image: linear-gradient(
    0deg,
    rgba(206, 219, 229, 1) 5%,
    rgba(229, 237, 241, 1) 17%,
    rgba(248, 249, 251, 1) 31%,
    rgba(255, 255, 255, 1) 50%,
    rgba(248, 249, 251, 1) 67%,
    rgba(229, 237, 241, 1) 83%,
    rgba(206, 219, 229, 1) 95%
  );
}

@media screen and (min-width: 769px) {
  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-39,
  .ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-41,
  .CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-42 {
    background-image: linear-gradient(0deg, rgba(24, 37, 107, 1), rgba(28, 68, 147, 1));
    color: #ffffff;
    position: relative;
    height: 83px; /* ナビの高さはそのまま */
    width: 125px;
    line-height: 50px;
    z-index: 1;
    overflow: visible; /* 下にはみ出す部分を隠さない */
  }

  /* 下に飛び出すタブ部分 */
  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-39::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -13px; /* 下に10px飛び出す */
    height: 13px;
    background-color: #18256bff; /* 親と同じグラデーション */
    border-bottom-left-radius: 20px; /* 左下だけ角丸 */
  }
  .ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-41::after,
  .CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-42::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -13px; /* 下に10px飛び出す */
    height: 13px;
    background-color: #18256bff; /* 親と同じグラデーション */
  }

  /* RECRUIT, ENTRY, CONTACT だけ hover / current 時に適用 */
  .c-gnav > .RECRUIT:hover > a,
  .c-gnav > .ENTRY:hover > a,
  .c-gnav > .CONTACT:hover > a,
  .c-gnav > .RECRUIT.-current > a,
  .c-gnav > .ENTRY.-current > a,
  .c-gnav > .CONTACT.-current > a {
    background-color: #18256bff; /* 親と同じ色 */
    color: #ffffff;
  }

  /* hoverで文字色を白 */
  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page-39:hover,
  .ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page-41:hover,
  .CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page-42:hover {
    color: #ffffff;
  }

  /* hoverで下の飛び出し部分も白くする */
  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page-39:hover::after,
  .ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page-41:hover::after,
  .CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page-42:hover::after {
    background-color: #ffffff;
  }

  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-39 .ttl,
  .ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-41 .ttl,
  .CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-42 .ttl {
    display: block;
    font-size: 20px;
  }

  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page-39 .c-smallNavTitle.desc {
    border-top: 1px solid #fff;
  }

  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-39 .ttl {
    display: inline-block; /* 幅を持たせる */
    position: relative; /* 擬似要素の基準にする */
    padding-bottom: 5px; /* 文字とボーダーの間に5px */
  }

  .RECRUIT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-39 .ttl::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0; /* paddingの内側、文字から5px下 */
    height: 1px; /* ボーダーの太さ */
    background-color: #fff; /* ボーダーの色 */
  }
}

.menu-item.menu-item-type-post_type.menu-item-object-page .ttl::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -3px; /* paddingの内側、文字から5px下 */
  height: 0.8px; /* ボーダーの太さ */
  background-color: #727070; /* ボーダーの色 */
}

.ENTRY.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-41 .ttl::after,
.CONTACT.menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-42 .ttl::after {
  content: none;
}

/* フッター */

.c-widget.widget_media_image,
.c-widget.widget_text {
  display: flex;
  justify-content: center;
}

.wp-block-button__link.has-background.has-text-align-center.wp-element-button {
  width: 200px;
  margin-left: 80px;
}

.wp-block-button__link.has-swl-main-color.has-text-color.has-link-color.has-text-align-center.wp-element-button {
  width: 200px;
  margin-right: 80px;
}

/* メインビジュアル */

.p-mainVisual__imgLayer .c-filterLayer__img {
  display: none;
}

.p-mainVisual__slideTitle {
  display: none;
}

.-height-auto .p-mainVisual__textLayer {
  padding: 0;
}

.p-mainVisual__textLayer > .p-blogParts {
  margin: 0;
  text-align: left;
}

/* 文字 */

.wp-block-group.top-catch {
  position: absolute;
  line-height: 0;
  top: 37%;
  font-size: 28px;
  text-shadow: 4px 4px 30px rgba(0, 0, 0, 1);
}

.top-title {
  margin-left: 84px;
  position: absolute;
  top: 57%;
}

.top-subcatch {
  width: 545px;
  height: auto;
  position: absolute;
  left: 13%;
  top: 66%;
}

.top-text {
  margin-left: 57px;
  margin-right: 72px;
  position: absolute;
  letter-spacing: 2px;
  line-height: 1.8;
  bottom: 19px;
  text-shadow: 4px 4px 30px rgba(0, 0, 0, 1);
}

.top-img {
  width: 550px;
  position: relative;
  bottom: -125px;
  left: 10%;
  box-shadow: 2px 6px 6px rgba(0, 0, 0, 0.4);
}

@media not all and (min-width: 960px) {
  .sp-py-40 {
    padding-bottom: 0 !important;
    padding-top: 0 !important;
  }
}

.swell-block-fullWide.pc-py-0.sp-py-0.alignfull {
  position: relative;
  top: 0px;
}

/* ---------------------共有--------------------------------- */

/* パンくず */
.-frame-on .p-breadcrumb,
.c-infoBar + .p-breadcrumb,
.c-infoBar + [data-barba="container"] > .p-breadcrumb,
.l-topTitleArea + .p-breadcrumb {
  box-shadow: 2px 6px 6px rgba(0, 0, 0, 0.4) !important;
}

/* VIEW MOREボタン */
.is-style-btn_solid a {
  box-shadow: none;
}

[class*="is-style-btn_"] a {
  background: none;
  border-radius: none;
  box-shadow: none;
}

/* ▶ */
.swl-fz.swl-inline-color svg:nth-child(2) {
  color: #26b7bc;
  opacity: 0.5;
}

/* 見出し調整 */

@media screen and (min-width: 769px) {
  .swell-block-fullWide.pc-py-0.sp-py-0.alignfull.heading {
    position: relative;
    top: 81px;
  }
}

@media screen and (max-width: 768px) {
  .swell-block-fullWide.pc-py-0.sp-py-0.alignfull.heading.sp_only {
    padding: 22px;
    margin-bottom: 40px;
    margin-top: 10px;
  }
}
/* ＥＮＴＲＹテンプレート */

.entry2 {
  top: -105px;
  position: relative;
}

.wp-block-columns.shadow_on {
  top: -182px;
  position: relative;
  box-shadow: 5px 6px 21px 0px rgba(0, 0, 0, 0.4);
}

.shadow_on > .wp-block-column {
  padding: 0;
}

.is-style-btn_line.joinus_btn a {
  background: #26b7bc;
  color: #fff;
  border-radius: 0;
  border: #fff;
}

.is-style-btn_line.joinus_btn a:hover {
  color: #fff;
  background-color: #595757;
  border: #000;
  transition: 0.25s;
}

.is-style-btn_line.joinus_btn2 a {
  border-radius: 0;
}

@media screen and (max-width: 768px) {
  .wp-block-columns.entry_box.has-background {
    height: 510px;
  }
  .wp-block-column.entry_txt .has-text-align-left {
    position: absolute;
    top: 44%;
  }
  .wp-block-column.entry_txt .has-text-align-left.entry_txt .swl-fz {
    font-size: 18px !important;
  }
  .swell-block-fullWide.alignfull.joinus_box {
    position: relative;
    top: -21px;
  }
  .wp-block-columns.joinus_btn {
    margin: 75px;
  }
  .wp-block-columns.btn,
  .footer05 {
    display: none;
  }

  .w-footer__box {
    padding: 0;
    padding-bottom: 1em;
  }

  .swell-block-fullWide.pc-py-0.sp-py-0.alignfull.entry_joinus_box {
    position: relative;
    top: 96px;
  }
  .swell-block-fullWide.pc-py-0.sp-py-0.alignfull.entry_joinus_box2 {
    position: relative;
    top: 150px;
  }

  .is-style-btn_line.joinus_btn a ,
  .is-style-btn_line.joinus_btn2 a {
   padding: 15px 24px;
  }
}

/* モバイル時ボタン調整 */

@media screen and (max-width: 781px) {
    /* ボタン全体を中央に寄せる */
    .wp-block-columns.joinus_btn {
        justify-content: center !important;
        margin: 0 auto !important;
        text-align: center !important;
        gap: 15px; /* ボタン間の余白 */
    }

    /* 各ボタンを縦並び・中央揃えに */
    .wp-block-columns.joinus_btn .wp-block-column {
        display: flex !important;
        margin-bottom: 10px !important;
    }

    /* ボタン内のテキスト余白調整 */
    .swell-block-button__link {
        display: inline-block !important;
        padding: 12px 20px !important; /* 上下・左右の余白 */
        font-size: 16px !important;
        text-align: center !important;
        box-sizing: border-box !important;
    }
}



/*--------------------各ページヒーロー画像 ----------------------------*/

.customize-support {
  padding: 0px;
}

.l-topTitleArea {
  display: none;
}

.l-content {
  padding-top: 15px;
}

@media (min-width: 600px) {
  .l-content {
    padding-top: 15px;
  }
}

/* 仕事内容 */

.wp-image-946.luminous.ls-is-cached.lazyloaded {
  width: 436px;
  position: relative;
  left: 110px;
  bottom: -50px;
  box-shadow: 6px 6px 19px rgba(0, 0, 0, 0.6) !important;
}

.department_txt {
  margin: 35px;
}

/* 福利厚生 */

.has-text-align-left.u-mb-ctrl.u-mb-10.txt {
  position: relative;
  top: -37px;
}

.u-mb-ctrl.u-mb-10.txt2.has-white-color.has-text-color.has-link-color.has-huge-font-size.wp-elements-f60c157f3fbbe51526d74345ac67550f {
  position: relative;
  bottom: -42px;
  text-shadow: rgb(255, 255, 255) 1px 1px 10px, rgb(255, 255, 255) -1px 1px 10px, rgb(255, 255, 255) 1px -1px 10px,
    rgb(255, 255, 255) -1px -1px 10px;
}

/* 社員紹介 */

.wp-block-group.is-row.member {
  padding-left: 130px;
}

.has-text-align-left.u-mb-ctrl.u-mb-10.txt {
  text-shadow: rgb(255, 255, 255) 1px 1px 10px, rgb(255, 255, 255) -1px 1px 10px, rgb(255, 255, 255) 1px -1px 10px,
    rgb(255, 255, 255) -1px -1px 10px;
}

/* 座談会*/
.has-text-align-left.txt {
  position: relative;
  top: -63px;
  text-shadow: rgb(255, 255, 255) 1px 1px 10px, rgb(255, 255, 255) -1px 1px 10px, rgb(255, 255, 255) 1px -1px 10px,
    rgb(255, 255, 255) -1px -1px 10px;
}

/* 採用情報 */

.has-text-align-left.recruit.txt {
  position: relative;
  top: -40px;
}

p.recruit.txt2 {
  font-size: larger;
  position: relative;
  bottom: -187px;
  text-shadow: rgb(38, 183, 188) 1px 1px 10px, rgb(38, 183, 188) -1px 1px 10px, rgb(38, 207, 236) 1px -1px 10px,
    rgb(37, 202, 207) -1px -1px 10px;
}

/*-------------------------トップページ---------------------------- */

.top-h3.is-style-section_ttl {
  text-shadow: 4px 4px 0px rgba(88, 83, 83, 0.5), 8px 8px 0px rgba(0, 0, 0, 0.2);
}

.top-h5 {
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 0.4);
}

.top-square {
  background-image: linear-gradient(
    90deg,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0.77) 42%,
    rgba(226, 222, 222, 0.54) 60%,
    rgba(215, 211, 211, 0.53) 100%,
    rgba(226, 222, 222, 0.47) 68%
  );
}

.top-square2 {
  background-image: linear-gradient(
    267deg,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0.77) 42%,
    rgba(226, 222, 222, 0.54) 60%,
    rgba(215, 211, 211, 0.53) 100%,
    rgba(226, 222, 222, 0.47) 68%
  );
}

.top-square3 {
  position: relative;
  z-index: 0; /* コンテンツを前面に */
}

.top-square3::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80%; /* 中央80% */
  height: 100%;
  background: rgba(215, 211, 211, 0.53);
  clip-path: polygon(0 0, 90% 0, 100% 100%, 11% 100%);
  z-index: -1; /* 背景を後ろに */
}

@media screen and (max-width: 768px) {
  .top-square3::before {
    display: none;
  }
}

/* 
.top-square3{
    background-color: rgba(209, 209, 209, 0.52);
    clip-path: polygon(0 0, 90% 0, 100% 100%, 11% 100%);
} */

@media screen and (max-width: 768px) {
  .swell-block-button.is-style-btn_solid.more {
    padding-top: 20px;
  }
  .wp-block-column.about_list {
    padding: 0 39px;
  }
}

/* TOP固定ページ */

/* .wp-image-473.luminous.ls-is-cached.lazyloaded {
  box-shadow: 2px 6px 6px rgba(0, 0, 0, 0.4);
} */

.aboutus.icon {
  opacity: 0.5;
}

.swell-block-linkList__text {
  letter-spacing: 0.3em;
}

.swell-block-linkList__text .swl-inline-color {
  letter-spacing: -0.5em;
}

.swell-block-linkList__item.triangular svg {
  display: none;
}

.has-text-align-right.member_txt.has-large-font-size {
  position: relative;
  top: -62px;
}

.swell-block-button.is-style-btn_solid.member_txt.u-mb-ctrl.u-mb-0 {
  position: relative;
  top: -62px;
}

@media (min-width: 960px) {
  .pc-py-60 {
    padding-bottom: 3em !important;
  }
}

@media screen and (max-width: 768px) {
  .swell-block-linkList__text {
    font-size: 20px;
  }
  .swell-block-linkList__text .swl-inline-color {
    font-size: 25px;
  }

  .swell-block-button.is-style-btn_solid.btn1 .swl-fz {
    font-size: 30px !important;
  }
  .swell-block-button.is-style-btn_solid.more.btn2 .swell-block-button__link {
    font-size: 0.7em !important;
  }
}

/* --------------------------------会社情報---------------------------------- */

.wp-block-group.is-stack.has-huge-font-size {
  padding-left: 110px;
}

.p-block-group.is-stack.has-huge-font-size {
  position: relative;
  left: 130px;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 1.9);
}

.wp-block-group.is-stack.txt.has-huge-font-size {
  position: relative;
  left: 132px;
  top: -45px;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 1.9);
}

.has-text-align-left.kaisyajyouhou_txt {
  position: relative;
  top: -37px;
}

.wp-image-980.luminous.ls-is-cached.lazyloaded {
  position: relative;
  bottom: -100px;
  box-shadow: 0px 6px 19px rgba(0, 0, 0, 0.6) !important;
}

.wp-block-group.system.has-background {
  border-radius: 20px;
  position: relative;
  top: 79px;
}

/* グラフ関係 */

.wp-block-heading.is-style-section_ttl.list_title.has-huge-font-size .swl-bg-color {
  padding: 20px 50px 18px 50px;
  border-radius: 40px;
}

.swell-block-fullWide.pc-py-60.sp-py-40.alignfull.top-square {
  /* display: flex; */
  text-align: left;
}

@media screen and (max-width: 768px) {
  .l-content {
    padding-top: 0;
  }
  .wp-block-spacer.spacer_0 {
    display: none;
  }
}

/* ----------------------------------沿革-------------------------------------------*/

.timeline {
  width: 96%;
  max-width: 940px;
  margin: 28px auto;
  border: 1px solid #eeeeee;

  &-list {
    padding: 40px 0;

    &-item {
      display: flex;
      line-height: 1.5;
      font-size: 16px;

      .date {
        width: 20%;
        padding: 0 0 0 20px;
        color: #888888;
        font-weight: bold;
      }

      .content {
        position: relative;
        width: 80%;
        padding: 0 20px 60px 30px;
        border-left: 1px solid #aaaaaa;
      }
    }
  }
}

.timeline {
  width: 96%;
  max-width: 940px;
  margin: 28px auto;
  border: 1px solid #eeeeee;
}

.timeline-list {
  padding: 40px 0;
}

.timeline-list-item {
  display: flex;
  line-height: 1.5;
  font-size: 16px;
}

.timeline-list-item .date {
  width: 24%;
  padding: 0 0 0 20px;
  font-weight: bold;
  font-size: x-large;
  margin-right: 58px;
}

@media screen and (max-width: 767px) {
  .timeline-list-item .date {
    width: 50%;
    padding: 0;
    font-weight: bold;
    font-size: 16px;
    margin-right: 0px;
  }
}

.timeline-list-item .content {
  position: relative;
  width: 80%;
  padding: 0 20px 100px 30px;
  border-left: 1px solid #aaaaaa;
  font-size: 20px;
}

.timeline-list-item .content::before {
  content: "";
  position: absolute;
  top: -11px;
  left: -7px;
  width: 20px;
  height: 20px;
  border-top: 16px solid transparent;
  border-bottom: 14px solid transparent;
  border-left: 21px solid #00c2bc;
}

.wp-block-heading.is-style-section_ttl.list_title.has-huge-font-size .swl-bg-color {
  padding: 14px 20px 14px 20px;
  left: 1px;
}

@media screen and (max-width: 767px) {
  .timeline-list-item .content {
    font-size: 14px;
  }
  .wp-block-image.padding_20px {
    padding: 15px 30px;
  }

  .fs_xl,
  .has-huge-font-size,
  .has-xl-font-size,
  .swl-fz.u-fz-xl {
    font-size: 18px !important;
  }

  .wp-block-list .has-medium-font-size,
  .u-fz-m {
    margin: 15px;
    font-size: 16px !important;
  }

  .business_txt {
    padding: 0px 50px 0 50px;
  }
}

/* 表 */
.company_table {
  padding: 0px 15px 0 15px;
}

@media screen and (max-width: 767px) {
  .wp-block-table .has-text-align-centerth th {
    font-size: 18px !important;
  }
  .wp-block-table td {
    font-size: 14px !important;
  }
  .wp-block-group.u-mb-ctrl.u-mb-0.company_table2 p {
    font-size: 14px;
  }
}

/* ------------------------------職種------------------------------ */

.wp-block-table {
  border: #000 solid 1px;
}

.wp-block-table td,
.wp-block-table th {
  padding: 1.8em;
}

.wp-block-table th {
  font-size: larger;
}

.wp-block-table td {
  background-color: #fff;
  font-size: 20px;
}

.business p {
  margin: 0 15px 0 15px;
}

.swell-block-accordion.is-style-main .swell-block-accordion__body {
  background-color: #fff;
}

/* --------------------------仕事内容--------------------------------- */

@media screen and (min-width: 769px) {
  .wp-block-image.u-mb-ctrl.u-mb-20.work.img {
    width: 500px;
    position: relative;
    top: -72px;

    box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.3);
  }

  .wp-block-group.department_group1 {
    position: relative;
    left: 48px;
  }
  .wp-block-group.has-border.-border04.u-mb-ctrl.u-mb-10.department_group2 {
    position: relative;
    right: 48px;
  }
}

.wp-block-group.department_group1,
.wp-block-group.has-border.-border04.u-mb-ctrl.u-mb-10.department_group2 {
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.3);
}

.wp-block-image.u-mb-ctrl.u-mb-20.work.img {
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.3);
}

@media screen and (max-width: 767px) {
  .wp-block-heading.department_title .swl-fz.u-fz-xl {
    font-size: 25px !important;
  }
}

/* 福利厚生 */

@media screen and (min-width: 769px) {
  .wp-block-image.size-full.system.img {
    width: 500px;
    position: relative;
    top: -72px;
    left: 76px;
  }

  .wp-block-image.size-full.system.imgs {
    width: 450px;
    position: relative;
    bottom: -190px;
    box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.4);
  }

  .wp-block-heading.has-text-align-left.is-style-section_ttl.u-mb-ctrl.u-mb-10.has-medium-font-size {
    margin-bottom: 0 !important;
  }
}

.wp-block-group.has-border.-border04.system_shadow {
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.4);
  border-radius: 20px;
  margin: 20px;
}

/* 社員紹介 */

.swell-block-bannerLink.member_img {
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.4);
}
.member_title {
  margin: 0px 40px;
}
.wp-block-image.member_left_img {
  margin-left: 380px;
}
.has-text-align-center.member_left_title {
  margin-left: 380px;
}
.wp-block-image.member_right_img {
  margin-right: 380px;
}
.has-text-align-center.member_right_title {
  margin-right: 380px;
}
.has-text-align-right.member_right_txt {
  margin-right: 380px;
}

/* ===== モバイルで4列グリッド（画像の下に文字、比率そのまま） ===== */
@media (max-width: 767px) {
  /* 親（4列グリッド） */
  .wp-block-columns.member_list {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 5px !important; /* カード間の隙間 */
  }

  /* 各カード */
  .wp-block-columns.member_list > .wp-block-column {
    margin: 0 !important;
    padding: 6px;
    background: #fff;
    /*  border-radius: 1px; */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  /* 画像（元比率を保持して縮小） */
  .member_list .member_img {
    width: 100%;
    margin-bottom: 6px;
  }
  .member_list .member_img img {
    width: 100%;
    height: auto; /* 比率そのまま縮小 */
    border-radius: 6px;
    display: block;
  }

  /* テキスト */
  .member_list p.has-text-align-center {
    font-size: 10px;
    margin: 2px 0;
  }
  .member_list .member_title {
    font-size: 11px;
    color: #555;
    margin: 2px 0 6px;
  }

  /* ボタン */
  .member_list .swell-block-button {
    margin-top: auto;
  }
  /* ===== JANP▶▶ ボタンを小さく ===== */
  .member_list .swell-block-button__link {
    padding: 2px 3px; /* ←内側の余白を小さく */
    border-radius: 999px;
  }

  .member_list .swell-block-button__link .swl-fz.u-fz-xl {
    font-size: 12px !important; /* ←文字サイズを調整 */
  }
}

/* PSリストのボタン調節 */
@media screen and (max-width: 767px) {
    .wp-block-column .swell-block-button.-size-s.is-style-btn_solid.member_btn a {
        padding: 0 !important;
    }
}

@media screen and (max-width: 767px) {
  .fs_xl,
  .has-huge-font-size,
  .has-xl-font-size,
  .swl-fz.u-fz-xl {
    font-size: 30px !important;
  }
  .wp-block-heading.has-text-align-left.is-style-section_ttl.u-mb-ctrl.u-mb-20.member_title {
    position: relative;
    top: 48px;
  }

  .wp-block-media-text.has-media-on-the-right.is-stacked-on-mobile .wp-block-heading.member_list_title {
    font-size: 18px !important;
  }
  .wp-block-heading.member_list_title .swl-fz.u-fz-l {
    font-size: 16px !important;
  }
  .wp-block-heading.member_list_title {
    font-size: 18px !important;
  }

  .wp-block-heading.has-text-align-left.is-style-section_ttl.u-mb-ctrl.u-mb-20.member_subtitle .swl-fz.u-fz-xl {
    font-size: 18px !important;
  }

  .swell-block-columns .member_list_txt2.has-huge-font-size {
    font-size: 18px !important;
    padding-left: 20px;
    display: flex;
    justify-content: center;
  }
  .swell-block-columns.member_list_block .swell-block-columns__inner {
    row-gap: 0;
  }

  .eagle_size {
    width: 80%;
    margin: 0 auto;
  }
}

@media (max-width: 767px) {
  .member_area > .wp-block-column > .wp-block-columns {
    display: grid;
    grid-template-columns: 1fr 1fr; /* 横2列 */
    gap: 20px;
    padding: 0 10px; /* 左右に余白追加 */
    text-align: center;
  }

  .member_area .member_left,
  .member_area .member_right {
    width: 100%;
  }

  /* 写真サイズをさらに小さく（120px） */
  .member_area .member_left img,
  .member_area .member_right img {
    width: 120px;
    height: auto;
  }

  /* PC用 margin をリセット */
  .member_area .wp-block-image.member_left_img,
  .member_area .has-text-align-center.member_left_title,
  .member_area .wp-block-image.member_right_img,
  .member_area .has-text-align-center.member_right_title,
  .member_area .has-text-align-right.member_right_txt {
    margin: 0 !important;
  }

  /* テキスト（名前・役職）は中央寄せ */
  .member_area .has-text-align-center.member_left_title,
  .member_area .has-text-align-center.member_right_title {
    text-align: center !important;
    font-size: 13px;
    margin-top: 6px;
  }

  /* 右側テキスト（入社年など）は右詰め */
  .member_area .has-text-align-right.member_right_txt {
    text-align: right !important;
    font-size: 13px;
    margin-top: 4px;
  }

  .swell-block-fullWide.pc-py-60.sp-py-60.alignfull.member_footer {
    padding-bottom: 0 !important;
    margin-bottom: 0;
  }

  .block-space {
    padding: 1rem;
  }
}

.wp-image-1794.luminous.ls-is-cached.lazyloaded {
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.4);
}

/* -----------------------------座談会-------------------------- */

.-circle > .c-balloon__iconImg {
  border: 4px solid #26b7bc;
}

@media (min-width: 600px) {
  .c-balloon .c-balloon__iconImg {
    height: 95px;
    width: 95px;
  }
}

@media (min-width: 600px) {
  .c-balloon__icon {
    width: 100px;
  }
}

.wp-block-columns.icon1_1 .c-balloon.-bln-left {
  display: none;
}

.c-balloon__body.-speaking.-border-none {
  display: none;
}

.c-balloon -bln-left {
  justify-content: space-between;
}

.wp-block-columns.zadankai_icon {
  gap: 1em;
}

.c-balloon__text {
  box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.2);
}

.zadankai_img {
  box-shadow: 7px 7px 7px rgba(0, 0, 0, 0.2);
}

.wp-block-column.has-background {
  border-radius: 20px;
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.4);
}

.has-white-background-color.has-background {
  border-radius: 20px;
}

.swl-bg-color {
  position: relative;
  left: -27px;
}

/* --- PC時：3列 --- */

.member_profile {
  padding: 16px;
  border-radius: 12px;
  overflow: hidden;
}

.swell-block-fullWide.padding4em {
  padding: 2em !important;
}

@media (max-width: 768px) {
  /* カード全体を縮小して左右に余白 */
  .wp-block-column.member_profile {
    max-width: 90%;
    margin: 0 auto 24px auto;
  }

  /* 写真＋名前肩書きを横並び */
  .member_profile .wp-block-media-text {
    display: flex;
    align-items: center;
    gap: 12px;
  }

  .member_profile .wp-block-media-text__media {
    flex: 0 0 auto;
  }

  .member_profile .wp-block-media-text__media img {
    width: 140px; /* 横幅100px */
    height: auto; /* 縦は比率維持 */
  }

  .member_profile .wp-block-media-text__content {
    flex: 1;
  }

  /*   項目を中央配置  */
  .wp-block-columns.member_profile_box {
    justify-content: center;
  }

  /* プロフィール説明文は下に出す */
  .member_profile_txt {
    margin-top: 12px;
    padding: 12px;
    font-size: 14px;
  }

  /* モバイル時にアイコンを横並び */
  /* 全体を横一列に配置 */
  .wp-block-columns.zadankai_icon {
    display: flex;
    align-items: flex-start;
    gap: 20px; /* アイコンブロックと吹き出しの間隔 */
  }

  /* 左側アイコン用のラッパー */
  .zadankai_icon .icon-wrap {
    display: flex;
    gap: 5px; /* アイコン同士の間隔 */
  }

  /* 各アイコンのスタイル（中央寄せ） */
  .zadankai_icon .icon-wrap .wp-block-column {
    display: flex;
    justify-content: center;
    align-items: center;
  }

  /* 768px以下でも横並びを維持 */
  @media (max-width: 768px) {
    .wp-block-columns.zadankai_icon {
      flex-wrap: nowrap; /* 横並びを維持 */
    }
    .zadankai_icon .icon-wrap {
      flex-wrap: nowrap;
    }
  }
}

/* --------------------------------募集要項--------------------------------- -*/

.is-style-bb > .c-tabList .c-tabList__button:hover,
.is-style-bb > .c-tabList .c-tabList__button[aria-selected="true"] {
  color: #fff;
  background-image: linear-gradient(0deg, rgba(38, 183, 188, 1), rgba(185, 249, 249, 0.89) 50%, rgba(38, 183, 188, 1));
  text-shadow: 2px 3px 3px rgba(0, 0, 0, 1.4);
  font-weight: bold;
  font-size: 20px;
}
.c-tabList__item {
  border: solid 1px #595757;
  background-image: linear-gradient(0deg, rgba(223, 228, 232, 1), rgba(255, 255, 255, 1) 50%, rgba(223, 228, 232, 1));
}

.is-style-bb > .c-tabList .c-tabList__button {
  padding: 0.6em 50px 20px 50px;
}

.c-tabList__button {
  font-size: 20px;
  font-weight: bold;
}

.c-tabList__button {
  display: inline;
}

/* アコーディオン */

.swell-block-accordion.is-style-main .swell-block-accordion__title {
  background-color: #26b7bc;
}

.swell-block-accordion__title {
  padding: 1em 2em 1em 2em;
}

.recruit_table {
  margin: 0px 15px 0 15px;
}

.recruit_txt.text.pc_only {
  padding: 0px 20px 25px 20px;
}

@media screen and (max-width: 767px) {
  .fs_xl,
  .has-huge-font-size,
  .has-xl-font-size,
  .swl-fz.u-fz-xl {
    font-size: 18px !important;
  }

  .recruit_txt.text.sp_only {
    padding: 0px 20px 35px 20px;
  }
}

/* -----------お問合せ--------------------- */

.wpcf7 {
  max-width: 100%;
  box-sizing: border-box;
  position: relative;
  justify-content: center;
  padding: 20px;
}
.wpcf7-form {
  margin: 0 auto;
  text-align: center;
  top: 36%;
  left: 50%;
  height: auto;
  width: 80%;
}
.wpcf7 dd {
  margin: 0 0 30px 0;
}
.wpcf7 dt {
  font-size: larger;
  font-weight: bold;
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.wpcf7 input,
.wpcf7 textarea {
  width: auto;
  box-sizing: border-box;
  width: 100%;
  border: 1px solid #ccc;
  line-height: 1.2;
  padding: 8px;
}
.wpcf7 select,
.wpcf7 input[type="checkbox"],
.wpcf7 input[type="radio"] {
  width: auto;
  max-width: 97%;
  border: 1px solid #ccc;
  padding: 8px;
}
/* 必須マーク */
.wpcf7 .must {
  color: #fff;
  border-radius: 3px;
  font-size: 10px;
  margin-left: 10px;
  padding: 5px 10px;
  letter-spacing: 2px;
  background: #ed6d46;
}
/* 同意チェック */
.accept-this {
  text-align: center;
}
/* 送信ボタン */
.btn_contact7 {
  margin-top: 5%;
  text-align: center;
  position: relative;
}
.btn_contact7 input {
  width: 70%;
  padding: 2% 0%;
  background-color: #27a6af;
  color: #fff;
  font-size: 1.1em;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid #27a6af;
  -webkit-transition: 0.3s;
  -moz-transition: 0.3s;
  -o-transition: 0.3s;
  -ms-transition: 0.3s;
  transition: 0.3s;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
.btn_contact7 input:hover {
  background-color: #fff;
  color: #27a6af;
}

@media screen and (min-width: 769px) {
  .cf7 {
    padding: 10%;
    background-color: #dcdddd;
    border: 1px solid #ccc;
    box-shadow: 14px 14px 0px 0px rgb(0 0 0 / 30%);
  }
}

.wpcf7 {
  padding-bottom: 100px;
}

.wpcf7 dd {
  margin: 34px 0 30px 0;
}

.cf7_title {
  font-size: 28px;
  font-weight: bold;
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}

.cf7__list {
  display: flex;
  flex-wrap: wrap;
}

.cf7__list dt:nth-of-type(n + 2),
.cf7__list dd:nth-of-type(n + 2) {
  margin-top: 30px;
}

.cf7__list dt {
  width: 35%;
  margin-top: 30px;
  margin-bottom: 30px;
}

.cf7__list dd {
  width: 65%;
}

.wpcf7-list-item {
  display: inline-block;
  margin: 62px 0 0 1em;
}

/* 必須・任意 */
.cf7__required,
.cf7__optional {
  margin-right: 15px;
  padding: 6px 14px;
  color: #fff;
  font-size: 12px;
  vertical-align: 1px;
}

.cf7__required {
  background: #be1d1d;
}

.cf7__optional {
  background: #878d8e;
}

/* input・textarea */
.cf7__list dd input[type="text"],
.cf7__list dd input[type="tel"],
.cf7__list dd input[type="email"],
.cf7__list dd textarea {
  width: 100%;
  padding: 15px 20px;
  background: #f4f4f4;
}

/* ドロップダウンメニュー */
.cf7__select {
  position: relative;
}

.cf7__select:before {
  position: absolute;
  top: 50%;
  right: 20px;
  z-index: 10;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-top: 8px solid #000;
  border-right: 6px solid transparent;
  border-left: 6px solid transparent;
  pointer-events: none;
  content: "";
}

.cf7__select select {
  width: 100%;
  padding: 19px 20px;
  background: #f4f4f4;
  color: #a5a5a5;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* チェックボックス・ラジオボタン */
.cf7__list dd .wpcf7-checkbox,
.cf7__list dd .wpcf7-radio {
  display: inline-flex;
  padding: 15px 0 10px;
  gap: 97px;
}

/* 縦並び（チェックボックス・ラジオボタン） */
.cf7__list dd .wpcf7-list-item {
  display: block;
  margin: 0;
}

/* .cf7__list dd .wpcf7-list-item:nth-child(n + 2) {
  margin-top: 18px;
} */

/* マウスカーソル（チェックボックス・ラジオボタン） */
.cf7__list dd .wpcf7-list-item label {
  cursor: pointer;
}

/* チェックボックス・ラジオボタン */
input[type="checkbox"],
input[type="radio"] {
  position: relative;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  border: 1px solid #bcbcbc;
  vertical-align: -3px;
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/* チェックボックス */
input[type="checkbox"]:checked {
  border: 1px solid #000;
  background: #000;
}

input[type="checkbox"]:checked:before {
  position: absolute;
  top: 2px;
  left: 5px;
  transform: rotate(50deg);
  width: 6px;
  height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  content: "";
}

/* ラジオボタン */
input[type="radio"] {
  border-radius: 50%;
}

input[type="radio"]:checked:before {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #000;
  content: "";
}

/* プレースホルダー */
/* Google Chrome / Safari / Mozilla Firefox / Opera */
.cf7__list dd input[type="text"]::placeholder,
.cf7__list dd input[type="tel"]::placeholder,
.cf7__list dd input[type="email"]::placeholder,
.cf7__list dd textarea::placeholder {
  color: #a5a5a5;
}

/* Microsoft Edge */
.cf7__list dd input[type="text"]::-ms-input-placeholder,
.cf7__list dd input[type="tel"]::-ms-input-placeholder,
.cf7__list dd input[type="email"]::-ms-input-placeholder,
.cf7__list dd textarea::-ms-input-placeholder {
  color: #a5a5a5;
}

/* Internet Explorer */
.cf7__list dd input[type="text"]:-ms-input-placeholder,
.cf7__list dd input[type="tel"]:-ms-input-placeholder,
.cf7__list dd input[type="email"]:-ms-input-placeholder,
.cf7__list dd textarea:-ms-input-placeholder {
  color: #a5a5a5;
}

/* 送信ボタン */
.cf7__button {
  padding-left: 72px;
  text-align: center;
}

input[type="submit"] {
  width: 260px;
  height: 60px;
  background: #000;
  color: #fff;
  transition: opacity 0.6s;
}

input[type="submit"]:hover {
  opacity: 0.6;
}

/* ajax-loader */
.wpcf7-spinner {
  vertical-align: middle;
}

@media screen and (max-width: 767px) {
  .cf7__list dt {
    width: 100%;
    margin-bottom: 15px;
    padding-top: 0;
  }

  .cf7__list dd {
    width: 100%;
  }

  .cf7__list dd:nth-of-type(n + 2) {
    margin-top: 0;
  }

  .cf7__list dd .wpcf7-checkbox,
  .cf7__list dd .wpcf7-radio {
    display: inline-flex;
    padding: 15px 0 10px;
    gap: 97px;
  }

  /* 送信ボタン */
  input[type="submit"] {
    width: 213px;
    height: 56px;
  }
}

/* エントリーテンプレート */

.has-text-align-left {
  position: absolute;
  top: 48%;
  transform: translateY(-50%);
  padding: 5px;
}
/* 
.swl-fz{
    font-size: 100px;
    top: -10px;
    position: relative;
    } */

/* フッター */

.footer05 {
  color: #4c4948;
  padding: 15px;
}
.footer05 a {
  color: #808080;
  text-decoration: none;
}
.footer05 li a:hover {
  text-decoration: underline;
}
.footer05 .wrap {
  width: 900px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.footer05 .wrap h3 {
  margin: 0 0 10px 0;
  padding: 0;
  border-bottom: 1px #c4c4c4 solid;
}
.footer05 .wrap p {
  margin: 0;
  padding: 0 0 20px 0;
}
.footer05 .wrap .box {
  width: 22%;
}
.footer05 .wrap .box ul {
  margin: 0;
  padding: 0 0 20px 0;
  list-style: none;
}
.footer05 .wrap .copyright {
  width: 100%;
  padding: 20px 0 0 0;
}

@media only screen and (max-width: 599px) {
  .footer05 .wrap {
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box;
  }
  .footer05 .wrap h3 {
    border: none;
  }
  .footer05 .wrap .box {
    width: 100%;
  }
  .footer05 .wrap .box ul {
    border-top: 1px #c4c4c4 solid;
  }
  .footer05 .wrap .box ul li a {
    display: block;
    padding: 5px 15px;
    border-bottom: 1px #c4c4c4 solid;
  }
  .entry_text {
    padding: 13px;
    font-size: 15px;
  }
}

.wp-block-buttons.is-content-justification-center.is-layout-flex.wp-container-core-buttons-is-layout-16018d1d.wp-block-buttons-is-layout-flex {
  margin-left: 10%;
}

.wp-block-button__link.has-swl-main-color.has-text-color.has-link-color.has-text-align-center.wp-element-button {
  background: none;
  border: 1px solid;
  color: var(--the-btn-color, var(--color_main));
  position: relative;
  transition: background-color 0.25s;
  font-size: 1.125em;
}

.wp-block-button__link.has-background.has-text-align-center.wp-element-button {
  background: none;
  border: 1px solid;
  color: #fff;
  position: relative;
  transition: background-color 0.25s;
  font-size: 1.125em;
  padding-right: 3em;
  padding-left: 3em;
}

.swell-block-fullWide.pc-py-60.sp-py-40.alignfull.joinus_space {
  padding-bottom: 0em !important;
}
@media (min-width: 960px) {
  .pc-py-60 {
    padding-bottom: 0em !important;
  }
}

.swell-block-fullWide.privacypolicy {
  padding: 20px;
}