@charset "UTF-8";
/************************************************************************
download font
*************************************************************************/
/* font-family */
/*  font-size */
/*  content width */
/*  color */
/*  break point */
/* 自動フォントサイズレスポンシブ対応 */
/* 最小値、最大値、最小画面、最大画面 */
.mt-15 {
  margin-top: 15px;
}
@media (max-width: 1023px) {
  .mt-15 {
    margin-top: 7.5px;
  }
}

.mt-30 {
  margin-top: 30px;
}
@media (max-width: 1023px) {
  .mt-30 {
    margin-top: 15px;
  }
}

.mt-45 {
  margin-top: 45px;
}
@media (max-width: 1023px) {
  .mt-45 {
    margin-top: 22.5px;
  }
}

.mt-60 {
  margin-top: 60px;
}
@media (max-width: 1023px) {
  .mt-60 {
    margin-top: 30px;
  }
}

.mt-75 {
  margin-top: 75px;
}
@media (max-width: 1023px) {
  .mt-75 {
    margin-top: 37.5px;
  }
}

.mt-90 {
  margin-top: 90px;
}
@media (max-width: 1023px) {
  .mt-90 {
    margin-top: 45px;
  }
}

.mt-105 {
  margin-top: 105px;
}
@media (max-width: 1023px) {
  .mt-105 {
    margin-top: 52.5px;
  }
}

.mt-120 {
  margin-top: 120px;
}
@media (max-width: 1023px) {
  .mt-120 {
    margin-top: 60px;
  }
}

.mt-135 {
  margin-top: 135px;
}
@media (max-width: 1023px) {
  .mt-135 {
    margin-top: 67.5px;
  }
}

.mt-150 {
  margin-top: 150px;
}
@media (max-width: 1023px) {
  .mt-150 {
    margin-top: 75px;
  }
}

.mt-165 {
  margin-top: 165px;
}
@media (max-width: 1023px) {
  .mt-165 {
    margin-top: 82.5px;
  }
}

.mt-180 {
  margin-top: 180px;
}
@media (max-width: 1023px) {
  .mt-180 {
    margin-top: 90px;
  }
}

.mt-195 {
  margin-top: 195px;
}
@media (max-width: 1023px) {
  .mt-195 {
    margin-top: 97.5px;
  }
}

@media (width >= 1025px) {
  .sp {
    display: none !important;
  }
}
@media (width < 1014px) {
  .pc {
    display: none !important;
  }
}
/************************************************************************
 common setting
 ***********************************************************************/
* {
  position: relative;
}

hr {
  width: 80%;
  margin: auto;
  color: #d1d1d1;
}

h1,
h2,
h3,
h4 {
  font-weight: bold;
}

html {
  font-size: 17px;
  line-height: 1.8;
}
@media (max-width: 1023px) {
  html {
    font-size: 14px;
  }
}

body {
  width: 100%;
  font-family: "source-han-sans-japanese";
  background-color: white;
}

a:hover {
  opacity: 0.8;
  filter: contrast(0.9);
}

img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}

.sectionHeader {
  padding: 1px;
}

.icon.arrow {
  display: block;
  width: auto;
  height: 11px;
  min-height: -moz-fit-content;
  min-height: fit-content;
  aspect-ratio: 1;
  margin: auto 0;
  background-image: url("/sansei/wp-content/themes/kirara_v.0.8/svg/icon_arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
}

.btn {
  display: flex;
  gap: 18px;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 220px;
  padding: 16px 34px;
  font-family: "toppan-bunkyu-midashi-go-std";
  font-weight: bold;
  border-radius: 50px;
  box-shadow: inset 0 3px 8px rgba(0, 0, 0, 0.5019607843);
}

.icon-circle {
  display: flex;
  width: auto;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 1;
  padding: 5px;
  margin: auto 0;
  background: white;
  border-radius: 50%;
}

.btn.-r {
  margin-left: auto;
}

.btn.-blue {
  color: white;
  background: #273556;
}
.btn.-blue .icon {
  filter: invert(48%) sepia(8%) saturate(3706%) hue-rotate(173deg) brightness(87%) contrast(98%);
}

.btn.-white {
  color: #3a75bb;
  background: white;
}
.btn.-white .icon {
  filter: invert(37%) sepia(60%) saturate(625%) hue-rotate(172deg) brightness(101%) contrast(85%);
}

.pageIntro {
  display: flex;
  justify-content: space-evenly;
  margin-top: 8vw;
  margin-bottom: 13vw;
}
@media (max-width: 1023px) {
  .pageIntro {
    flex-direction: column;
    justify-content: space-evenly;
    width: 90%;
    margin: auto;
    margin-top: 50px;
    margin-bottom: 20px;
  }
}

.pageIntro_paragraph_text {
  width: 51vw;
  max-width: 600px;
  font-size: clamp(1.1764705882rem, 0.8431372549rem + 0.5555555556vw, 1.4705882353rem);
}
@media (max-width: 1023px) {
  .pageIntro_paragraph_text {
    width: 100%;
    max-width: none;
    margin-top: 30px;
    font-size: 18px;
  }
}

.pageIntro_slogan_text {
  font-size: 2.9vw;
  font-weight: bold;
}
@media (max-width: 1023px) {
  .pageIntro_slogan_text {
    font-size: 7vw;
  }
}

.sectionTitle {
  display: flex;
  flex-direction: column-reverse;
}

.sectionTitle_en {
  font-family: "poppins";
  font-size: 4.25vw;
  font-weight: bold;
  line-height: 1;
  text-transform: capitalize;
}
@media (max-width: 1023px) {
  .sectionTitle_en {
    font-size: 20px;
  }
}

.sectionTitle_ja {
  font-size: clamp(1.1764705882rem, 0.5098039216rem + 1.1111111111vw, 1.7647058824rem);
}
@media (max-width: 1023px) {
  .sectionTitle_ja {
    font-size: 30px;
  }
}

.sectionHeader-a {
  padding-left: 50px;
}
@media (max-width: 1023px) {
  .sectionHeader-a {
    padding-left: 20px;
    margin-left: 30px;
  }
}

.sectionHeader-a::before {
  position: absolute;
  top: 17px;
  left: 0;
  display: block;
  width: auto;
  height: 24px;
  aspect-ratio: 1;
  content: "";
  background: red;
  border-radius: 50%;
}
@media (max-width: 1023px) {
  .sectionHeader-a::before {
    top: 50%;
    height: 15px;
    transform: translateY(-50%);
  }
}

/* スクロールダウンの位置 */
.scroll_container {
  position: fixed;
  bottom: 50px;
  left: 50%;
  z-index: 9;
  transform: translateX(-50%);
}

.scroll {
  position: relative;
  padding-top: 60px;
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
}

/* 矢印のアニメーション部分 */
.scroll::before,
.scroll::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  width: 30px;
  height: 30px;
  margin: auto;
  content: "";
  border-bottom: 3px solid #000;
  border-left: 3px solid #000;
  animation: scroll 2s infinite;
}

.scroll::after {
  bottom: 6px;
  width: 20px;
  height: 20px;
  border-bottom: 3px solid #565656;
  border-left: 3px solid #565656;
}

/* 矢印のアニメーション */
@keyframes scroll {
  0% {
    opacity: 0;
    transform: rotate(-45deg) translate(0, 0);
  }
  40% {
    opacity: 1;
  }
  80% {
    opacity: 0;
    transform: rotate(-45deg) translate(-20px, 20px);
  }
  100% {
    opacity: 0;
  }
}
/*************************************************************************
layout
*************************************************************************/
/* レイアウト */
main {
  z-index: 0;
  display: block;
  padding-bottom: 13.5vw;
  contain: layout paint;
}

section {
  padding-top: 1px;
}

section:not(.full) {
  padding-right: calc(50dvw - 625px);
  padding-left: calc(50dvw - 625px);
}
@media screen and (width <= 1350px) {
  section:not(.full) {
    padding: 0 50px;
  }
}
@media (max-width: 1023px) {
  section:not(.full) {
    padding: 0 10px;
  }
}

.content {
  background: #f8fcff;
}

.main_article {
  margin-top: 7.95vw;
}

.footer {
  z-index: 10;
}

/* header */
.header {
  position: fixed;
  top: 2%;
  left: 50%;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: space-around;
  width: 95%;
  height: 100px;
  max-height: 8vw;
  padding: 0;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.4117647059);
  border-radius: 15px;
  transform: translateX(-50%);
}
@media (max-width: 1023px) {
  .header {
    top: 0;
    left: 0;
    justify-content: flex-start;
    width: 100%;
    height: 70px;
    max-height: unset;
    background: white;
    border-radius: 0;
    transform: translateX(0);
  }
}

.header_title {
  z-index: 9999;
  height: 100%;
}

.header_title_link {
  display: flex;
  align-items: center;
  width: -moz-max-content;
  width: max-content;
  height: 100%;
  color: white;
}
@media (max-width: 1023px) {
  .header_title_link {
    padding: 10px;
  }
}

.change-bg .header {
  background-color: white;
  transition: 0.3s;
}
.change-bg .header .header_menu_item:not(:last-child),
.change-bg .header .header_title_link {
  color: black;
}
@media (max-width: 1023px) {
  .change-bg .header {
    background-color: rgba(255, 255, 255, 0.85);
  }
}

.header_menu {
  width: 100%;
  height: 100%;
  margin-left: auto;
}

.header_menu_list {
  display: flex;
  gap: 2%;
  align-items: center;
  justify-content: flex-end;
  height: 100%;
}

/* ////////////////////////////////////////////
// hamburger
//////////////////////////////////////////// */
.hamburger {
  position: fixed;
  top: 10px;
  right: 10px;
  z-index: 999;
  display: none;
}
@media (max-width: 1023px) {
  .hamburger {
    display: block;
    background: white;
    border: 1px solid lightgray;
    border-radius: 5px;
  }
}

.hamburger::before {
  position: absolute;
  bottom: 50%;
  left: 50%;
  display: block;
  width: 40px;
  height: 3px;
  content: "";
  background: gray;
  border-radius: 90px;
  transform: translate(-50%, 50%);
  transition: 0.3s;
}

.hamburger.is-active::before {
  bottom: 0;
  transition: 0.3s;
}

.hamburger_icon {
  position: relative;
  display: block;
  height: 50px;
  aspect-ratio: 1;
}

.hamburger_icon::before,
.hamburger_icon::after {
  position: absolute;
  top: 10px;
  left: 50%;
  display: block;
  width: 40px;
  height: 3px;
  content: "";
  background: gray;
  border-radius: 90px;
  transform: translateX(-50%);
  transition: 0.3s;
}

.hamburger_icon::after {
  top: auto;
  bottom: 10px;
}

.is-active .hamburger_icon::before,
.is-active .hamburger_icon::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 40px;
  height: 3px;
  content: "";
  background: gray;
  border-radius: 90px;
  transform: translate(-50%, -50%) rotate(45deg);
  transition: 0.3s;
}

.is-active .hamburger_icon::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

@media (max-width: 1023px) {
  .header_menu {
    position: fixed;
    inset: 0;
    display: none;
    visibility: hidden;
    opacity: 0;
    transition: 0.3s ease;
  }
  .header_menu.is-active {
    z-index: 999;
    display: block;
    visibility: visible;
    width: 100%;
    height: 100vh;
    opacity: 1;
    transition: 0.5s ease;
  }
  .overlay.is-active {
    position: fixed;
    inset: 0;
    z-index: 1;
    display: block;
    width: 100vw;
    height: 100vh;
    background: #1c1c1c;
  }
  .header_menu_list {
    z-index: 100;
    display: flex;
    flex-direction: column;
    gap: 24px;
    justify-content: center;
    height: 100dvh;
    padding-left: 10%;
    font-size: 1.1764705882rem;
    list-style-type: none;
  }
}
.header_title img {
  height: 40%;
  margin-left: 50px;
  -o-object-fit: contain;
  object-fit: contain;
}
@media (max-width: 1023px) {
  .header_title img {
    width: 60vw;
    height: 100%;
    margin-left: 2vw;
  }
}

#recruit {
  height: 100%;
  color: white;
  background: #444;
}

#recruit a {
  display: block;
  align-content: center;
  height: 100%;
  padding: 0 43px;
}

#contact {
  align-content: center;
  height: 100%;
  margin-left: -2%;
  color: white;
  background: linear-gradient(0deg, #181a4a, #6467b0);
}

#contact a {
  display: block;
  align-content: center;
  height: 100%;
  padding: 0 50px;
}

.footerMegaMenu {
  display: flex;
  color: white;
}
@media (max-width: 1023px) {
  .footerMegaMenu {
    flex-direction: column;
  }
}

.footerMegaMenu_list {
  width: calc(50% - 2px);
  background-color: #515151;
}
@media (max-width: 1023px) {
  .footerMegaMenu_list {
    width: 100%;
  }
}

.footerMegaMenu_list.-right {
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: white;
}

.footerMegaMenu_list.-left {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
  background: #c9c9c9;
}

.-left .footerMegaMenu_item {
  width: calc(50% - 2px);
  background: #515151;
}
@media (max-width: 1023px) {
  .-left .footerMegaMenu_item {
    width: 100%;
  }
}

.-right .footerMegaMenu_item {
  background: #787878;
}

.footerMegaMenu_link {
  display: block;
  padding: 40px 20px 20px 40px;
  padding: 2.08vw 1.04vw 1.04vw 2.08vw;
}
@media (max-width: 1023px) {
  .footerMegaMenu_link {
    padding: 30px;
  }
}

.footerMegaMenu_title-en {
  font-family: "toppan-bunkyu-midashi-go-std";
  font-size: 12px;
  line-height: 1;
  text-transform: capitalize;
}

.footerMegaMenu_title-ja {
  font-size: 25px;
}

.footerMegaMenu_btn {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  margin-top: 50px;
  margin-top: 2.6vw;
  font-family: "toppan-bunkyu-midashi-go-std";
}

.footerMegaMenu_link .icon.arrow {
  width: 10px;
  filter: invert(48%) sepia(8%) saturate(3706%) hue-rotate(173deg) brightness(87%) contrast(98%);
}

.footerBottom_container {
  height: 32vw;
  background-image: url("/sansei/wp-content/uploads/s-town.webp");
  background-position: bottom;
  background-size: cover;
}
@media (max-width: 1023px) {
  .footerBottom_container {
    height: auto;
  }
}

.footerBottomBanner {
  position: absolute;
  right: 0;
  padding: 50px;
}
@media (max-width: 1023px) {
  .footerBottomBanner {
    position: relative;
    right: unset;
    padding: 0;
  }
}

.footerBottomBanner_list {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 1023px) {
  .footerBottomBanner_list {
    width: 80%;
    padding: 50px 0;
    margin: auto;
  }
}

.footerBottomBanner .icon {
  filter: invert(48%) sepia(8%) saturate(3706%) hue-rotate(173deg) brightness(87%) contrast(98%);
}

.footerBottomBanner_item_link {
  display: flex;
  gap: 0.9vw;
  justify-content: space-between;
  padding: 1.2vw 1.5vw;
  font-size: 1.2vw;
  font-weight: bold;
  color: white;
  background-color: #888;
  border-radius: 0.6vw;
}
@media (max-width: 1023px) {
  .footerBottomBanner_item_link {
    padding: 20px;
    font-size: 20px;
    border-radius: 10px;
  }
}

.-blue .footerBottomBanner_item_link {
  background-color: #3a75bb;
}

.footerBottomMenu {
  position: absolute;
  bottom: 60px;
  left: 5%;
  display: flex;
  width: 90%;
}
@media (max-width: 1023px) {
  .footerBottomMenu {
    position: relative;
    bottom: unset;
    left: unset;
    flex-direction: column;
    width: 100%;
    padding-bottom: 50px;
  }
}

.footerBottomMenu_logo {
  height: 2.7vw;
}
@media (max-width: 1023px) {
  .footerBottomMenu_logo {
    height: 50px;
  }
}

.footerBottomMenu_list {
  display: flex;
  gap: 2vw;
  align-items: center;
  margin-left: 5.2vw;
  font-size: 1.3vw;
  font-weight: bold;
}
@media (max-width: 1023px) {
  .footerBottomMenu_list {
    justify-content: space-evenly;
    margin: auto;
    margin-top: 30px;
    font-size: 18px;
  }
}

.copyright {
  margin-top: auto;
  margin-left: auto;
  line-height: 1;
}
@media (max-width: 1023px) {
  .copyright {
    padding: 20px;
  }
}

.footerBottomMenu_logo_link img {
  -o-object-fit: contain;
  object-fit: contain;
}

/* hamburger overlay */
.js-overlay {
  position: fixed;
  inset: 0;
  z-index: 995;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.25s ease,
    visibility 0.25s ease;
}

.js-overlay.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* SP: footer as full-screen mega menu */
@media (max-width: 768px) {
  .footer {
    /* 通常時は “ページ下のフッター” として残す */
  }
  /* 開いたときだけ全画面化 */
  .footer.is-active {
    position: fixed;
    inset: 0;
    z-index: 998;
    background: #fff;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    /* ふわっと出す */
    opacity: 1;
  }
  /* 閉じてる時は見せない（スクロール末尾のフッターが消えるのが嫌ならここは外す） */
  .footer:not(.is-active) .footerMegaMenu {
    display: none;
  }
  /* メガメニューをSPで縦積みに */
  .footer.is-active .footerMegaMenu {
    display: block;
    padding: clamp(80px, 18vw, 110px) 14px 20px; /* 上にハンバーガー領域分 */
  }
  /* recruitページ専用：ヘッダー分を上乗せ */
  .recruitContent + .footer.is-active .footerMegaMenu {
    padding-top: calc(clamp(80px, 18vw, 110px) + clamp(56px, 14vw, 90px));
  }
  .footer.is-active .footerMegaMenu_list {
    width: 100%;
    margin: 0;
    padding: 0;
  }
  .footer.is-active .footerMegaMenu_item {
    margin-bottom: 10px;
  }
  /* 下部のフッター要素はメニュー時は邪魔なら隠す */
  .footer.is-active .footerBottom {
    display: none;
  }
}
@media (max-width: 1023px) {
  .breadcrumb {
    display: none;
  }
}

.breadcrumb_list {
  display: flex;
  gap: 15px;
  justify-content: flex-start;
  padding-left: 250px;
  margin-top: 1.7647058824rem;
}
@media (max-width: 1023px) {
  .breadcrumb_list {
    padding-left: 50px;
  }
}

.breadcrumb_item.breadcrumb-top {
  color: #98a3ae;
}

.breadcrumb_item {
  font-size: 0.8823529412rem;
  color: #0060cc;
}

.breadcrumb_item:not(:last-child)::after {
  padding-left: 15px;
  font-family: monospace;
  font-weight: bold;
  content: ">";
}

.table {
  width: 1000px;
  max-width: 100%;
  margin: auto;
  table-layout: fixed;
  border-bottom: 1px solid #707070;
}
@media (max-width: 1023px) {
  .table {
    width: 100%;
    border: 0;
  }
}
.table tr {
  border-top: 1px solid #707070;
}
@media (max-width: 1023px) {
  .table tr {
    border: 0;
  }
}
.table th {
  width: 250px;
  padding: 20px;
  background: lightgray;
}
@media (max-width: 1023px) {
  .table th {
    display: block;
    width: 100%;
  }
}
.table td {
  display: block;
  padding: 20px;
  background: white;
  box-shadow: -2px 0 0 #98a3ae;
}
.table td li {
  margin-bottom: 20px;
}
@media (max-width: 1023px) {
  .table td {
    box-shadow: none;
  }
}

/* フォーム全体 */
.pagination {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: center;
  margin-top: 150px;
  margin-bottom: 100px;
  text-align: center;
}
@media (max-width: 1023px) {
  .pagination {
    margin-top: 50px;
    margin-bottom: 50px;
  }
}

.pagination_numbers a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: auto;
  aspect-ratio: 1;
  font-weight: bold;
  color: #0060cc;
  border: 1px solid;
  border-radius: 50%;
}

.pagination_arrow a {
  display: flex;
}

.pagination_numbers a:hover {
  color: white;
  background: #0060cc;
}

.pagination_numbers.current a {
  color: white;
  background: #0060cc;
}

.pagination_arrow a span {
  display: flex;
}

.relatedLinks {
  padding: 5.3vw 0;
  background: white;
}

.relatedLinks_list {
  display: flex;
  justify-content: space-around;
  padding-right: calc(50vw - 625px);
  padding-left: calc(50vw - 625px);
  margin-top: 50px;
}
@media (max-width: 1023px) {
  .relatedLinks_list {
    flex-direction: column;
    gap: 30px;
    width: 80%;
    padding: 0;
    margin: auto;
  }
}

.relatedLinks_header {
  font-size: 35px;
  font-weight: bold;
  text-align: center;
}

@media (max-width: 1023px) {
  .relatedLinks_img {
    display: none;
  }
}

.relatedLinks_link {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  height: auto;
  aspect-ratio: 2;
  padding: 20px;
  color: white;
  background-color: #3a75bb;
  border-radius: 15px;
}
@media (max-width: 1023px) {
  .relatedLinks_link {
    aspect-ratio: unset;
  }
}

.relatedLinks_item {
  width: 48.5%;
}
@media (max-width: 1023px) {
  .relatedLinks_item {
    width: 100%;
  }
}

.relatedLinks_img img {
  border-radius: 30px;
}

.relatedLinks_title {
  font-size: 1.9vw;
}
@media (max-width: 1023px) {
  .relatedLinks_title {
    font-size: 40px;
    line-height: 1.2;
  }
}

.relatedLinks_content .btn {
  margin-top: 50px;
}

.relatedLinks_content {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 45%;
}
@media (max-width: 1023px) {
  .relatedLinks_content {
    width: 100%;
  }
}

.-next .relatedLinks_link {
  flex-direction: row-reverse;
  justify-content: space-between;
  padding-right: 50px;
}

@media (max-width: 1023px) {
  .-prev .relatedLinks_link {
    padding-left: 50px;
  }
}

.btn.-related {
  justify-content: center;
  min-width: 12vw;
  padding: 0.8vw 1.7vw;
  color: #3a75bb;
  background-color: #dedee0;
}
@media (max-width: 1023px) {
  .btn.-related {
    min-width: 100%;
    padding: 10px;
    margin: 20px auto;
  }
}

.relatedLinks_link::before {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 0;
  display: block;
  width: auto;
  height: 37%;
  aspect-ratio: 0.4;
  content: "";
  background: white;
  border-radius: 0 100% 100% 0%/50%;
  box-shadow: inset 6px 0 6px rgba(0, 0, 0, 0.4117647059);
  transform: translateY(-50%);
}
@media (max-width: 1023px) {
  .relatedLinks_link::before {
    height: 85px;
  }
}

.relatedLinks_link::after {
  position: absolute;
  top: 50%;
  left: 12px;
  z-index: 2;
  display: block;
  width: auto;
  height: 20px;
  aspect-ratio: 1;
  content: "";
  background-image: url("/sansei/wp-content/themes/kirara_v.0.8/svg/icon_arrow.svg");
  filter: invert(48%) sepia(8%) saturate(3706%) hue-rotate(173deg) brightness(87%) contrast(98%);
  transform: translateY(-50%);
  transform-origin: top;
  rotate: 180deg;
}

.-next .relatedLinks_link::after {
  right: 12px;
  left: auto;
  rotate: 0deg;
}

.-next .relatedLinks_link::before {
  right: 0;
  left: auto;
  border-radius: 100% 0 0% 100%/50%;
  box-shadow: inset -6px 0 6px rgba(0, 0, 0, 0.4117647059);
}

.pageTop {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 999;
  display: none;
  width: 66px;
  height: auto;
  aspect-ratio: 1;
  color: #fff;
  cursor: pointer;
  background-color: #263770;
  border-radius: 50%;
}

.pageTop svg {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 23px;
  transform: translate(-50%, -50%);
}

.pageHeader_heading {
  display: flex;
  flex-direction: column-reverse;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.pageHeader {
  height: 32vw;
  background-color: white;
  background-image: url("/sansei/wp-content/uploads/pageheader.png");
  background-size: cover;
}
@media (max-width: 1023px) {
  .pageHeader {
    height: 38vw;
    margin-top: 70px;
    background-size: contain;
  }
}

.pageHeader_heading_en {
  font-family: "poppins";
  font-size: 4.3vw;
  font-weight: bold;
  line-height: 1.3;
  text-transform: capitalize;
  background: linear-gradient(90deg, #5380ce, #9cf3d6);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.pageHeader_heading_ja {
  font-size: 1.5vw;
  color: #707070;
}
@media (max-width: 1023px) {
  .pageHeader_heading_ja {
    font-size: 5.5vw;
  }
}

.mainHeader {
  margin-bottom: 40px;
}
@media (max-width: 1023px) {
  .mainHeader {
    width: 90%;
    margin: auto;
  }
}
.mainHeader-center {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  margin-bottom: 40px;
  text-align: center;
}
.mainHeader_eng {
  font-family: sans-serif;
  font-size: 5.8823529412rem;
  font-weight: bold;
  line-height: 1;
  text-transform: uppercase;
  background: linear-gradient(155deg, #0060cc 0%, #0060cc 25%, black 0%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media (max-width: 1023px) {
  .mainHeader_eng {
    font-size: 2.9411764706rem;
  }
}
.mainHeader_ja {
  font-size: 1.4117647059rem;
  font-weight: bold;
}

.frontPageHeader {
  width: 100%;
}

.hero-image {
  height: 100vh;
}

.header_text {
  position: absolute;
  top: 40%;
  left: 10%;
  z-index: 2;
}
@media (max-width: 1023px) {
  .header_text {
    top: 10%;
  }
}

.header_text-ja {
  font-family: "toppan-bunkyu-midashi-go-std";
  font-size: 2.5rem;
  line-height: 1.7;
  color: #273556;
}

.hero-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: bottom;
  object-position: bottom;
}

.hero_news {
  position: absolute;
  right: 2%;
  bottom: 5%;
}
@media (max-width: 1023px) {
  .hero_news {
    width: 96%;
  }
}

.hero_news_item a {
  display: block;
  width: 460px;
  padding: 20px;
  padding-left: 100px;
  background: white;
  border-radius: 5px;
}
@media (max-width: 1023px) {
  .hero_news_item a {
    width: 100%;
  }
}

.hero_news_date {
  display: block;
  font-size: 15px;
  color: #818181;
}

.hero_news_img {
  position: absolute;
  top: 50%;
  left: 30px;
  width: 50px;
  height: auto;
  aspect-ratio: 1;
  background: #cac2c2;
  border-radius: 50%;
  transform: translateY(-50%);
}

.hero_news_img img {
  -o-object-fit: contain;
  object-fit: contain;
  -o-object-position: center;
  object-position: center;
}

.hero_news_item::after {
  position: absolute;
  top: 50%;
  right: 30px;
  display: block;
  width: 25px;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background: #3a75bb;
  border-radius: 50%;
  transform: translateY(-50%);
}

.hero_news_item::before {
  position: absolute;
  top: 50%;
  right: 37px;
  z-index: 2;
  display: block;
  width: 11px;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-image: url("/sansei/wp-content/themes/kirara_v.0.8/svg/icon_arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  filter: invert(1);
  transform: translateY(-50%);
}

.header_text-ja .blue {
  color: #216292;
}

.header_text-ja .red {
  color: #db2439;
}

.header_text-ja span {
  margin-right: 10px;
  font-size: 3.2rem;
}

.header_text-en {
  font-family: "toppan-bunkyu-midashi-go-std";
  font-size: 1.2rem;
  line-height: 2;
  color: #273556;
}

.top-aboutUs_slogan {
  margin: 100px 50px;
  font-family: "toppan-bunkyu-midashi-go-std";
  font-size: 4rem;
  line-height: 1;
  color: #216292;
  text-align: center;
  text-transform: uppercase;
}
@media (max-width: 1023px) {
  .top-aboutUs_slogan {
    margin: 17vw 5vw;
    font-size: 11vw;
  }
}

main.main.page-front-page {
  background-color: #d7e0e6;
}

.top-aboutUs_3d {
  position: absolute;
  width: 240px;
}
@media (max-width: 1023px) {
  .top-aboutUs_3d {
    opacity: 0.5;
  }
}

.top-aboutUs_text {
  z-index: 2;
  width: 625px;
  margin-bottom: 150px;
  margin-left: auto;
  font-size: 25px;
}
@media (max-width: 1023px) {
  .top-aboutUs_text {
    width: 100%;
    margin-bottom: 50px;
    font-size: 20px;
  }
}

.top-aboutUs {
  place-self: center;
}

.top-aboutUs_3d.-a {
  transform: translateX(60px);
}

.top-aboutUs_3d.-b {
  transform: translateX(-90px);
}

.top-aboutUs_text.-b {
  margin-right: 100px;
}

.top-aboutUs_deco {
  position: absolute;
  height: auto;
  aspect-ratio: 1;
  border-radius: 50%;
}
@media (max-width: 1023px) {
  .top-aboutUs_deco {
    z-index: -1;
    opacity: 0.5;
  }
}

.top-aboutUs_deco.-red {
  top: 40%;
  left: calc(-50dvw + 51%);
  width: 250px;
  background: #db2439;
}
@media (max-width: 1023px) {
  .top-aboutUs_deco.-red {
    width: 150px;
  }
}

.top-aboutUs_deco.-red::before {
  position: absolute;
  right: -40px;
  bottom: 0;
  z-index: -1;
  display: block;
  width: 100px;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background: #216292;
  border-radius: 50%;
}

.top-aboutUs_deco.-yellow {
  bottom: -60px;
  left: 10%;
  width: 160px;
  background: #f6d6a2;
}

.top-aboutUs_deco.-orange {
  top: 50%;
  right: -27vw;
  width: 320px;
  background: #f4b69f;
}
@media (max-width: 1023px) {
  .top-aboutUs_deco.-orange {
    width: 170px;
  }
}

.top-service {
  margin-top: 200px;
}
@media (max-width: 1023px) {
  .top-service {
    margin-top: 50px;
  }
}

.top-service_item {
  display: flex;
  flex-direction: row-reverse;
  gap: 5%;
  width: 94%;
  padding: 2%;
  margin: 0 1%;
  background: #216292;
  border-radius: 30px 10px 10px 30px;
}
@media (max-width: 1023px) {
  .top-service_item {
    flex-direction: column-reverse;
    width: 90%;
    padding-bottom: 30px;
    border-radius: 15px 5px 5px 15px;
  }
}

.top-service_item::before {
  position: absolute;
  top: 0;
  right: -4.2%;
  display: block;
  width: 4%;
  height: 100%;
  content: "";
  background: #216292;
  border-radius: 10px 30px 30px 10px;
}
@media (max-width: 1023px) {
  .top-service_item::before {
    right: -9.2%;
    width: 8%;
    border-radius: 5px 15px 15px 5px;
  }
}

.top-service_item::after {
  position: absolute;
  top: 6%;
  right: -4.2%;
  display: block;
  width: 150px;
  width: 4%;
  font-size: 25px;
  font-weight: bold;
  color: white;
  content: "Service";
  rotate: 90deg;
}
@media (max-width: 1023px) {
  .top-service_item::after {
    position: absolute;
    right: -7.2%;
    font-size: 15px;
  }
}

.top-service_image {
  width: 50%;
  height: -moz-fit-content;
  height: fit-content;
  aspect-ratio: 1;
  contain: paint;
  background: aliceblue;
  border-radius: 20px;
}
@media (max-width: 1023px) {
  .top-service_image {
    width: 100%;
    aspect-ratio: 1;
  }
}

.top-service_title {
  font-size: 86px;
  font-size: 4.5vw;
  font-weight: bold;
}
@media (max-width: 1023px) {
  .top-service_title {
    font-size: 9vw;
  }
}

.top-service_content {
  width: 50%;
  color: white;
}
@media (max-width: 1023px) {
  .top-service_content {
    width: 100%;
  }
}

.top-service_content::before {
  position: absolute;
  right: 0;
  bottom: -17%;
  font-size: 225px;
  font-weight: bold;
  content: counter(count, decimal-leading-zero);
  counter-increment: count;
  opacity: 0.1;
}

.top-service_list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  counter-reset: count;
}

.top-service_slogan {
  font-size: 2.25vw;
  font-weight: bold;
  line-height: 1.2;
}
@media (max-width: 1023px) {
  .top-service_slogan {
    font-size: 7vw;
  }
}

.top-service_text {
  max-width: 625px;
  margin-top: clamp(0.8235294118rem, -1.5764705882rem + 4vw, 2.9411764706rem);
  margin-bottom: clamp(0.8235294118rem, -1.5764705882rem + 4vw, 2.9411764706rem);
  font-size: clamp(0.8235294118rem, 0.1568627451rem + 1.1111111111vw, 1.4117647059rem);
}
@media (max-width: 1023px) {
  .top-service_text {
    margin: 30px 0;
    font-size: 4vw;
  }
}

.top-service_item:nth-child(even) {
  flex-direction: row;
  justify-content: flex-end;
  margin-left: auto;
  background: #5380ce;
  border-radius: 10px 30px 30px 10px;
}
@media (max-width: 1023px) {
  .top-service_item:nth-child(even) {
    flex-direction: column-reverse;
    border-radius: 5px 15px 15px 5px;
  }
}

.top-service_item:nth-child(even)::before {
  right: auto;
  left: -4.3%;
  background: #5380ce;
  border-radius: 30px 10px 10px 30px;
}
@media (max-width: 1023px) {
  .top-service_item:nth-child(even)::before {
    left: -9.2%;
    border-radius: 15px 5px 5px 15px;
  }
}

.top-service_item:nth-child(even)::after {
  right: auto;
  left: -4.2%;
}
@media (max-width: 1023px) {
  .top-service_item:nth-child(even)::after {
    left: -7.2%;
  }
}

.top-service_item:nth-child(even) .top-servicer_content {
  width: -moz-fit-content;
  width: fit-content;
}

label {
  display: block;
  display: flex;
  gap: 100px;
  justify-content: flex-end;
  padding: 10px;
  padding-top: 10px;
  margin-bottom: 20px;
  font-weight: bold;
  text-wrap-mode: nowrap;
}
@media (max-width: 1023px) {
  label {
    flex-direction: column;
    gap: 20px;
    margin-bottom: 0;
  }
}

.wpcf7-form-control {
  width: 400px;
  padding: 10px;
  padding-left: 20px;
  margin-top: -10px;
  border: 1px solid;
  border-radius: 3px;
}
@media (max-width: 1023px) {
  .wpcf7-form-control {
    width: 100%;
  }
}

.wpcf7-textarea {
  resize: vertical;
}

form.wpcf7-form {
  width: -moz-fit-content;
  width: fit-content;
  max-width: 98%;
  padding: 50px;
  margin: auto;
  background: white;
  border-radius: 20px;
}
@media (max-width: 1023px) {
  form.wpcf7-form {
    padding: 0;
  }
}

.wpcf7-submit {
  position: relative;
  display: block;
  width: 300px;
  height: 70px;
  margin: auto;
  margin-top: 50px;
  font-weight: bold;
  color: white;
  text-align: center;
  background: #0060cc;
  border-radius: 150px;
}

.wpcf7-submit::after {
  position: absolute;
  top: 50%;
  right: 0;
  display: block;
  width: 25px;
  height: 25px;
  font-size: 1.4117647059rem;
  color: #b90f0f;
  content: "";
  background: antiquewhite;
}

.contactForm {
  margin-bottom: 150px;
}
@media (max-width: 1023px) {
  .contactForm {
    margin-bottom: 50px;
  }
}

.wpcf7-form-control-wrap:has(.wpcf7-validates-as-required)::before {
  position: absolute;
  left: -90px;
  width: 55px;
  font-size: 0.8235294118rem;
  line-height: 1.9;
  color: white;
  text-align: center;
  content: "必須";
  background: #0060cc;
  border-radius: 20px;
}
@media (max-width: 1023px) {
  .wpcf7-form-control-wrap:has(.wpcf7-validates-as-required)::before {
    left: auto;
    right: 0;
    top: -40px;
  }
}

.service_list_container {
  margin-top: 100px;
}
@media (max-width: 1023px) {
  .service_list_container {
    margin-top: 50px;
  }
}

.service_list {
  display: flex;
  flex-wrap: wrap;
  gap: 50px 5%;
  justify-content: center;
}
@media (max-width: 1023px) {
  .service_list {
    flex-direction: column;
    gap: 20px;
    justify-content: center;
  }
}

.service_item {
  display: flex;
  flex-direction: column;
  gap: 3%;
  align-items: center;
  justify-content: center;
  width: 40%;
  height: auto;
  aspect-ratio: 1;
}
@media (max-width: 1023px) {
  .service_item {
    width: 100%;
  }
}

.service_img {
  position: absolute;
  z-index: 0;
  width: 100%;
  height: 100%;
  contain: paint;
  border-radius: 25px;
  filter: contrast(0.5);
}

.service_item .btn_container {
  position: absolute;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
}

.service_item:hover .service_img {
  filter: opacity(0.5);
}

.service_title {
  font-size: 35px;
  color: white;
}

.service_text {
  visibility: hidden;
  width: 80%;
  height: 0;
  opacity: 0;
  transition: 0.3s;
}

.service_item:hover .service_text {
  visibility: visible;
  height: auto;
  opacity: 1;
}

.service_item:hover .service_title {
  color: black;
}

.serviceAbout_container {
  padding: 2.65vw;
  margin-top: 100px;
  background: white;
  border-radius: 27px;
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.1882352941);
}
@media (max-width: 1023px) {
  .serviceAbout_container {
    padding: 10px;
    padding: 30px 20px;
    margin-top: 10px;
  }
}

.serviceAbout_content {
  display: flex;
  gap: 5.3vw;
}
@media (max-width: 1023px) {
  .serviceAbout_content {
    flex-direction: column;
    gap: 20px;
  }
}

.serviceAbout_title {
  margin-bottom: 50px;
  font-size: 35px;
  color: #343844;
  text-align: center;
}

.serviceAbout_text {
  width: 50%;
  font-size: 18px;
  font-weight: bold;
  color: #343844;
}
@media (max-width: 1023px) {
  .serviceAbout_text {
    width: 100%;
  }
}

.serviceDetail {
  margin-top: 100px;
}

.serviceDetail_title {
  padding-bottom: 10px;
  padding-left: 40px;
  font-size: 35px;
  border-color: #3a75bb;
  border-bottom: 3px solid;
}
@media (max-width: 1023px) {
  .serviceDetail_title {
    font-size: 20px;
  }
}

.serviceDetail_title::before {
  position: absolute;
  top: 50%;
  left: 0;
  display: block;
  width: auto;
  height: 24px;
  aspect-ratio: 1;
  content: "";
  background: red;
  border-radius: 50%;
  transform: translateY(-50%);
}
@media (max-width: 1023px) {
  .serviceDetail_title::before {
    height: 15px;
  }
}

.serviceDetail_text {
  width: 70vw;
  max-width: 625px;
  font-size: 18px;
  font-weight: bold;
  color: #343844;
}
@media (max-width: 1023px) {
  .serviceDetail_text {
    width: 100%;
  }
}

@media (max-width: 1023px) {
  .serviceDetail_examples {
    font-size: 17px;
  }
}
.serviceDetail_content {
  display: flex;
  gap: 100px;
  justify-content: flex-start;
  margin-top: 50px;
  color: #343844;
}
@media (max-width: 1023px) {
  .serviceDetail_content {
    flex-direction: column;
    gap: 50px;
    margin-top: 50px;
  }
}

.serviceDetail_list {
  padding-left: 30px;
  margin-top: 10px;
  font-weight: bold;
  list-style: disc;
}

.serviceDetail_imgs {
  display: none;
  justify-content: space-evenly;
  width: 80%;
  margin: 50px auto;
}
@media (max-width: 1023px) {
  .serviceDetail_imgs {
    flex-direction: column;
    gap: 20px;
    align-items: center;
    width: 50%;
  }
}

.serviceDetail_img {
  width: 210px;
  height: auto;
}
@media (max-width: 1023px) {
  .serviceDetail_img {
    width: 100%;
  }
}

.serviceDetail_img img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  border-radius: 30px;
}

figcaption {
  margin-top: 20px;
  font-size: 25px;
  font-weight: bold;
  color: #343844;
  text-align: center;
}
@media (max-width: 1023px) {
  figcaption {
    margin-top: 10px;
    font-size: 18px;
  }
}

.specialHeader {
  display: none;
}

.page-special .main_article {
  padding-right: 50px;
  margin: 0;
}

.specialFront_title {
  position: absolute;
  top: 10vh;
  right: 8vw;
  z-index: 1;
  font-family: serif;
  font-size: 2.1vw;
  line-height: 1;
  color: white;
  writing-mode: vertical-rl;
}

.specialFront {
  display: flex;
  width: 100%;
  margin-bottom: 13.2vw;
}

.specialFront_img {
  flex: 1;
}

.specialFront_slogan {
  height: -moz-fit-content;
  height: fit-content;
  padding: 5.3vw 2.65vw;
  font-family: serif;
  font-size: 4.25vw;
  font-weight: bold;
  text-align: right;
  writing-mode: vertical-rl;
}

.specialFront_title span {
  display: block;
  height: -moz-fit-content;
  height: fit-content;
  padding: 30px 20px;
  margin: 0 40px;
  background: #3a2da8;
}

.specialFront_logo {
  position: absolute;
  right: 100px;
  bottom: 30px;
  width: 10vw;
}

.specialTitle {
  margin-top: 5.3vw;
  font-family: serif;
  font-size: 3.9vw;
  font-weight: bold;
  text-align: center;
}

.specialIntro_img {
  position: absolute;
}

.specialIntro_text {
  z-index: 1;
  width: 50vw;
  padding: 50px;
  margin: auto;
  margin-top: 8.3vw;
  font-size: 23px;
  font-weight: bold;
  background-color: rgba(255, 255, 255, 0.7294117647);
}

.specialIntro_img.-a {
  top: -4vw;
  left: 5vw;
  width: 19vw;
  height: auto;
  aspect-ratio: 1.9;
}

.specialIntro_img.-b {
  bottom: 0;
  left: 6vw;
  width: 20vw;
  height: auto;
  aspect-ratio: 1.6;
}

.specialIntro_img.-c {
  top: 50%;
  right: 0;
  width: 30vw;
  height: auto;
  aspect-ratio: 1.4;
}

.specialContent {
  display: flex;
  justify-content: space-around;
  padding: 7.95vw 2.65vw;
  margin-top: 7.95vw;
  color: white;
  background-color: #708180;
}

.specialContent_text {
  width: 25vw;
  margin-top: 5.3vw;
  font-size: clamp(0.8823529412rem, 0.3490196078rem + 0.8888888889vw, 1.3529411765rem);
  font-weight: bold;
}

.specialContent_title {
  font-family: serif;
  font-size: 3.87vw;
  font-weight: bold;
}

.specialContent_img {
  width: 29.7vw;
}

.specialContent_text::first-letter {
  font-size: 3.18vw;
}

.specialConclusion_title {
  font-family: serif;
  font-size: 3.87vw;
  font-weight: bold;
  text-align: center;
}

.specialConclusion {
  margin-top: 70px;
}

.specialConclusion_content {
  display: flex;
  gap: 5%;
  justify-content: center;
  margin-top: 50px;
}

.specialConclusion_text {
  width: 26.5vw;
  font-size: 1.5vw;
  font-weight: bold;
}

.specialConclusion_img {
  width: 26.5vw;
}

.specialConclusion_text::first-letter {
  font-size: 2.7vw;
}

/* =========================
   SP: 〜768px
========================= */
@media (max-width: 768px) {
  .page-special .main_article {
    padding-right: 0;
  }
  /* ---------- FV（specialFront） ---------- */
  .specialFront {
    position: relative;
    flex-direction: column;
    margin-bottom: 56px; /* 13.2vwだとSPで間延びしがち */
  }
  .specialFront_img {
    order: 1;
  }
  .specialFront_img img {
    width: 100%;
    height: auto;
    display: block;
  }
  /* タイトル：縦書きを解除してSPは横書きで読みやすく */
  .specialFront_title {
    position: absolute;
    top: 12px;
    right: 12px;
    left: 12px; /* 右寄せ固定を解除 */
    writing-mode: horizontal-tb;
    font-size: clamp(16px, 4.6vw, 20px);
    line-height: 1.3;
    text-align: left;
    z-index: 2;
  }
  .specialFront_title span {
    display: inline-block;
    padding: 8px 10px;
    margin: 0 6px 6px 0;
    background: #3a2da8;
  }
  /* スローガン：縦書き解除＋画像の上に被せる */
  .specialFront_slogan {
    position: absolute;
    right: 12px;
    bottom: 12px;
    z-index: 2;
    color: white;
    writing-mode: horizontal-tb;
    text-align: right;
    padding: 10px 12px;
    font-size: clamp(18px, 6vw, 26px);
    line-height: 1.1;
    background: rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(2px);
    border-radius: 10px;
  }
  .specialFront_logo {
    position: absolute;
    right: 12px;
    bottom: 72px; /* スローガンと干渉しないよう上へ */
    width: clamp(72px, 22vw, 110px);
    z-index: 2;
  }
  .specialFront_logo img {
    width: 100%;
    height: auto;
    display: block;
  }
  /* ---------- 見出し ---------- */
  .specialTitle {
    margin-top: 28px;
    font-size: clamp(18px, 5.2vw, 24px);
    padding: 0 14px;
  }
  /* ---------- Intro（specialIntro） ---------- */
  .specialIntro {
    position: relative;
    padding: 0 14px;
  }
  /* 絶対配置の装飾画像はSPでは崩れやすいので“流し込み”に変更 */
  .specialIntro_img {
    position: static;
    width: 100%;
    margin: 10px 0;
  }
  .specialIntro_img img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
  }
  /* -a/-b/-c の個別指定を解除（SPでは一律でOK） */
  .specialIntro_img.-a,
  .specialIntro_img.-b,
  .specialIntro_img.-c {
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    width: 100%;
    aspect-ratio: auto;
  }
  .specialIntro_text {
    width: 100%;
    margin-top: 16px;
    padding: 14px;
    font-size: clamp(14px, 4vw, 16px);
    line-height: 1.9;
    background-color: rgba(255, 255, 255, 0.92);
    border-radius: 12px;
  }
  /* ---------- Content（specialContent） ---------- */
  .specialContent {
    flex-direction: column;
    gap: 18px;
    padding: 26px 14px;
    margin-top: 28px;
  }
  .specialContent_header {
    width: 100%;
  }
  .specialContent_title {
    font-size: clamp(18px, 5.2vw, 24px);
    line-height: 1.35;
  }
  .specialContent_img {
    width: 100%;
    max-width: 420px;
    margin-top: 12px;
  }
  .specialContent_text {
    width: 100%;
    margin-top: 0;
    font-size: clamp(14px, 4vw, 16px);
    line-height: 1.9;
  }
  .specialContent_text::first-letter {
    font-size: clamp(24px, 7vw, 34px);
  }
  /* ---------- Conclusion（specialConclusion） ---------- */
  .specialConclusion {
    margin-top: 44px;
    padding: 0 14px;
  }
  .specialConclusion_title {
    font-size: clamp(18px, 5.2vw, 24px);
  }
  .specialConclusion_content {
    flex-direction: column;
    gap: 14px;
    margin-top: 18px;
  }
  .specialConclusion_text,
  .specialConclusion_img {
    width: 100%;
  }
  .specialConclusion_text {
    font-size: clamp(14px, 4vw, 16px);
    line-height: 1.9;
  }
  .specialConclusion_text::first-letter {
    font-size: clamp(24px, 7vw, 34px);
  }
  .specialConclusion_img img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 10px;
  }
}
/* =========================
   さらに小さいSP: 〜390px
========================= */
@media (max-width: 390px) {
  .specialFront_slogan {
    bottom: 10px;
    right: 10px;
    padding: 8px 10px;
  }
  .specialFront_logo {
    bottom: 66px;
  }
  .specialFront_title span {
    padding: 7px 9px;
  }
}
/* =========================================================
   Recruit (PC: default)
========================================================= */
/* ---------- Recruit Header (FV) ---------- */
.recruitHeader_container {
  min-height: 100vh;
}

.recruitHeader_container::before,
.recruitHeader_container::after {
  position: absolute;
  top: 28vw;
  left: 27vw;
  z-index: 0;
  display: block;
  width: 20vw;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-color: #ce538c;
  background-image: url("/wp-content/uploads/concrete-wall-2.png");
  background-size: cover;
  border-radius: 50%;
}

.recruitHeader_container::before {
  top: -10vw;
  left: -13vw;
  z-index: 1;
  width: 53vw;
  background-color: #5380ce;
}

.recruitHeader_topMenu {
  position: absolute;
  bottom: 150px;
  left: 150px;
  z-index: 1;
}

.recruitHeader_topMenu_list {
  font-size: 21px;
  font-weight: bold;
  line-height: 2;
  list-style: inside;
}

.recruitHeader_title {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  width: -moz-max-content;
  width: max-content;
  font-weight: bold;
  transform: translate(-50%, -50%);
}

.recruitHeader_title::before {
  position: absolute;
  top: -6vw;
  right: 4vw;
  z-index: 0;
  display: block;
  width: 14vw;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-image: url("/wp-content/uploads/dammy-35-e1763019925532.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  filter: opacity(0.5);
}

.recruitHeader_slogan {
  font-size: 4vw;
  line-height: 1.3;
}

.recruitHeader_slogan::after {
  position: absolute;
  inset: 0;
  z-index: 2;
  color: transparent;
  white-space: pre-wrap;
  pointer-events: none;
  content: "創るだけじゃない。\a再び輝かせるのも、私たちの仕事。";
  background-image: url("/wp-content/uploads/concrete-wall-2.png");
  -webkit-background-clip: text;
  background-clip: text;
  background-size: contain;
}
@media (max-width: 1023px) {
  .recruitHeader_slogan::after {
    content: "創るだけじゃない。\a再び輝かせるのも、\a私たちの仕事。";
  }
}

.recruitHeader_heading {
  margin-top: 2vw;
  font-size: 1.5vw;
  line-height: 1;
  color: #1d1e1f;
  text-align: center;
}

/* ---------- Page Header (nav) ---------- */
.recruitContent {
  background: none;
}

.recruitPageHeader {
  position: fixed;
  top: 50px;
  left: 50%;
  z-index: 999;
  display: flex;
  justify-content: space-between;
  width: 90%;
  max-width: 1700px;
  transform: translateX(-50%);
}

.recruitPageHeader_title_link img {
  display: block;
  width: 270px;
  -o-object-fit: contain;
  object-fit: contain;
}

.recruitPageHeader_title {
  display: flex;
  gap: 20px;
  align-items: center;
  height: 100%;
  line-height: 1;
}

.recruitPageHeader_menu_list {
  display: flex;
  gap: 30px;
}

.recruitPageHeader_menu_link {
  display: flex;
  gap: 20px;
  padding: 15px 54px;
  font-weight: bold;
  background: linear-gradient(91deg, #bbcbff, #fff);
  border-radius: 50px;
}

.recruitPageHeader_menu_link.-book {
  background: linear-gradient(270deg, rgb(0, 47, 47), rgb(111, 165, 0));
  filter: invert(1);
}

/* ---------- Article ---------- */
.recruitArticle {
  margin-top: 0;
}

/* ---------- About ---------- */
.recruitAbout {
  display: flex;
  justify-content: space-evenly;
  width: 100%;
}

.recruitAbout_text {
  font-size: 2.2vw;
  font-weight: bold;
}

.recruitAbout_link {
  display: block;
  width: 32vw;
  padding: 4.25vw 10px;
  background: #e8ebed;
  border-radius: 15px;
}

.recruitAbout_title {
  font-size: 2.12vw;
  font-weight: normal;
  text-align: center;
}

.recruitAbout_caption {
  margin-top: 30px;
  font-size: clamp(1.1764705882rem, 0.5098039216rem + 1.1111111111vw, 1.7647058824rem);
  font-weight: bold;
  text-align: center;
}

.recruitAbout_img {
  margin: 30px;
}

.recruitAbout_img img {
  width: 11vw;
  height: auto;
  aspect-ratio: 1;
  margin: auto;
  border-radius: 50%;
}

.recruitAbout_content {
  width: 80%;
  margin: auto;
  font-size: clamp(1.0588235294rem, 0.6588235294rem + 0.6666666667vw, 1.4117647059rem);
}

/* ---------- Interview / Analytics / Job (titles) ---------- */
.recruitInterview_title,
.recruitAnalytics_title,
.recruitJob_title {
  margin-bottom: 20px;
  font-size: 4.3vw;
  text-align: center;
}

/* ---------- Interview teaser ---------- */
.recruitInterview_img {
  left: -30%;
  z-index: 3;
  width: 37vw;
}

.recruitInterview_content {
  top: -10vw;
  right: -9vw;
  z-index: 1;
  width: 45vw;
  padding: 3.2vw;
  padding-left: 18vw;
  background: linear-gradient(90deg, #ffb9d3, #b2fdff);
  border-radius: 30px;
}

.recruitInterview_contentTitle {
  font-size: clamp(1.4705882353rem, 1.137254902rem + 0.5555555556vw, 1.7647058824rem);
  font-weight: bold;
}

.recruitInterview_text {
  margin-top: 20px;
  font-size: clamp(0.8235294118rem, 0.4235294118rem + 0.6666666667vw, 1.1764705882rem);
}

.recruitInterview_link {
  display: block;
  font-size: 20px;
  font-weight: bold;
  text-align: right;
}

/* ---------- scroll wrapper ---------- */
.wrapper {
  height: 100vh;
  overflow-y: hidden;
}

.wrapper.is-scrolling {
  touch-action: none;
}

.l-wrapper {
  position: relative;
  height: 100%;
  min-height: 100vh;
  padding: 1px;
  overflow-y: scroll;
}

.p-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  padding: 130px 20px 30px;
}

/* ---------- background svg ---------- */
.bg-svg-wrap {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

.bg-svg {
  width: 100%;
  height: 100%;
}

/* ---------- Recruit analytics (top) ---------- */
.recruitAnalytics {
  z-index: 1;
}

.recruitAnalytics_list {
  display: flex;
  justify-content: space-around;
  width: 60vw;
  padding: 3.2vw 3.2vw 5.3vw;
  background: white;
  border-radius: 15px;
}

.recruitAnalytics_item {
  width: 30%;
  height: auto;
  aspect-ratio: 1;
  background-image: linear-gradient(to right, #a8edea 0%, #fed6e3 100%);
  border-radius: 1.35vw;
}

.recruitAnalytics_link {
  display: block;
  margin: 20px auto;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

.recruitAnalytics_icon {
  position: absolute;
  top: -2.65vw;
  left: 50%;
  width: 5.3vw;
  height: auto;
  aspect-ratio: 1;
  padding: 1.2vw;
  background: white;
  border-radius: 50%;
  box-shadow: 0 3px 3px rgba(0, 0, 0, 0.42);
  transform: translateX(-50%);
}

.recruitAnalytics_icon img {
  -o-object-fit: contain;
  object-fit: contain;
}

.recruitAnalytics_caption {
  margin-top: 3.7vw;
  font-size: clamp(1rem, 0.7333333333rem + 0.4444444444vw, 1.2352941176rem);
  font-weight: bold;
  text-align: center;
}

.recruitAnalytics_number {
  font-weight: bold;
  text-align: center;
}

.num {
  font-size: 3.72vw;
  font-weight: bold;
  color: #ff8300;
}

.unit {
  right: -10px;
  font-size: 20px;
}

.recruitAnalytics_subCaption {
  font-size: 12px;
  color: gray;
  text-align: center;
}

/* ---------- Job (swiper) ---------- */
.recruitJob {
  max-width: 100%;
}

.recruitJob_list {
  display: flex;
  gap: 30px;
}

.recruitJob_link {
  display: block;
  background-color: white;
  border: 5px solid #3a75bb;
  border-radius: 20px;
}

.recruitJob_item {
  width: 333px;
  max-width: 30vw;
}

.swiper-slide {
  max-width: 90%;
}

.recruitJob_itemTitle {
  width: 85%;
  padding: 5px 20px;
  margin: 20px auto;
  color: white;
  background-color: #006fb9;
  border-radius: 50px;
}

.recruitJob_caption {
  display: flex;
  gap: 10px;
  width: 90%;
  margin: auto;
  font-size: 20px;
  font-weight: bold;
}

.recruitJob_caption img {
  width: 20px;
  padding-top: 13px;
}

.recruitJob_content {
  width: 80%;
  margin: auto;
  line-height: 1.5;
}

.recruitJob_open {
  margin: 20px;
  font-size: 20px;
  font-weight: bold;
  text-align: right;
}

.swiper-slide-shadow.swiper-slide-shadow-cards {
  border-radius: 20px;
}

.recruitJob_item.swiper-slide {
  width: 333px;
}

.swiper-3d .recruitJob_item.swiper-cube-shadow,
.swiper-3d .recruitJob_item.swiper-slide,
.swiper-3d .recruitJob_item.swiper-slide-shadow,
.swiper-3d .recruitJob_item.swiper-slide-shadow-bottom,
.swiper-3d .recruitJob_item.swiper-slide-shadow-left,
.swiper-3d .recruitJob_item.swiper-slide-shadow-right,
.swiper-3d .recruitJob_item.swiper-slide-shadow-top,
.swiper-3d .recruitJob_item.swiper-wrapper {
  transform-style: preserve-3d;
  -webkit-transform-style: preserve-3d;
}

/* ---------- Casual interview ---------- */
.casualInterview_title {
  font-size: 90px;
  text-align: center;
}

.casualInterview_text {
  max-width: 800px;
  font-size: 20px;
  font-weight: bold;
}

.casualInterview_link {
  display: block;
  margin-top: 30px;
  font-size: 35px;
  font-weight: bold;
  color: red;
  text-align: right;
}

/* ---------- Sub page header ---------- */
.recruitSubPageHeader {
  height: 29.7vw;
}

.recruitSubPageHeader_heading {
  height: 100%;
}

.recruitSubPageHeader_heading_ja {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 4.24vw;
  font-weight: normal;
  transform: translate(-50%, -50%);
}

.recruitSubPageHeader_heading_en {
  position: absolute;
  right: 3%;
  bottom: 0;
  z-index: -1;
  font-family: none;
  font-size: 14.3vw;
  font-weight: bold;
  color: #f1f1ee;
  text-transform: capitalize;
}

.recruitSubPageHeader_heading_ja::before {
  position: absolute;
  top: 50%;
  left: -50px;
  display: block;
  width: 36px;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-color: #ce6593;
  border-radius: 50%;
  transform: translateY(-50%);
}

.recruitSubPageHeader_heading::before,
.recruitSubPageHeader_heading::after {
  position: absolute;
  top: 50%;
  left: 21vw;
  z-index: 0;
  display: block;
  width: 8vw;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-color: #ce538c;
  background-image: url("/wp-content/uploads/concrete-wall-2.png");
  background-size: cover;
  border-radius: 50%;
}

.recruitSubPageHeader_heading::after {
  top: 5vw;
  left: 11vw;
  z-index: 1;
  width: 15vw;
  background-color: #5380ce;
}

.recruitSubPageHeader::before {
  position: absolute;
  top: 6vw;
  left: 34vw;
  z-index: 0;
  display: block;
  width: 6vw;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-image: url("/wp-content/uploads/dammy-35-e1763019925532.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  filter: opacity(0.3);
}

.recruitSubPageHeader_subMenu {
  position: absolute;
  right: 5%;
  bottom: 20%;
  font-size: clamp(0.8235294118rem, 0.4235294118rem + 0.6666666667vw, 1.1764705882rem);
  font-weight: bold;
}

.recruitSubPageHeader_list {
  list-style: disc;
}

.recruitSubPageHeader_item.now {
  transform: translateX(-40px);
}
@media (max-width: 1023px) {
  .recruitSubPageHeader_item.now {
    transform: translateX(-70px);
  }
}

.recruitSubPageHeader_item.now::after {
  position: absolute;
  top: -0.1vw;
  right: -2.2vw;
  display: block;
  width: 2.2vw;
  height: auto;
  aspect-ratio: 1;
  content: "";
  background-image: url("/wp-content/themes/kirara_v.0.8/svg/finger.svg");
  filter: invert(65%) sepia(17%) saturate(2400%) hue-rotate(295deg) brightness(85%) contrast(87%);
  transform: scaleX(-1);
}
@media (max-width: 1023px) {
  .recruitSubPageHeader_item.now::after {
    right: -40px;
    width: 30px;
  }
}

.recruitSubPageHeader_item.now::before {
  position: absolute;
  right: -5vw;
  display: block;
  color: #cd6592;
  content: "イマ";
}
@media (max-width: 1023px) {
  .recruitSubPageHeader_item.now::before {
    right: -70px;
  }
}

/* ---------- Interview page ---------- */
.interviewIntro_list {
  display: flex;
  justify-content: space-around;
  width: 70%;
  min-width: 960px;
  margin: auto;
  margin-bottom: 7.95vw;
}

.interviewIntro_item {
  width: 30%;
  padding: 20px 0;
  font-weight: bold;
  border-radius: 35px;
  box-shadow: 6px 6px 6px rgba(0, 0, 0, 0.1803921569);
}

.interviewIntro_title {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
  font-family: toppan-bunkyu-midashi-go-std;
  font-size: clamp(1.1176470588rem, 0.7176470588rem + 0.6666666667vw, 1.4705882353rem);
}

.interviewIntro_img {
  width: 70%;
  height: auto;
  aspect-ratio: 1;
  margin: auto;
  clip-path: ellipse(34% 48% at 50% 50%);
  rotate: 26deg;
}

.interviewIntro_prof {
  rotate: -26deg;
}

.interviewIntro_content {
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}

.interview_header {
  left: 50%;
  display: flex;
  justify-content: center;
  width: 99.5vw;
  padding: 2.65vw 15vw;
  background: #c8d6ee;
  transform: translateX(-50%);
}

.interview_header_img {
  width: 40%;
  height: auto;
  aspect-ratio: 1;
  clip-path: ellipse(34% 48% at 50% 50%);
  rotate: 26deg;
}

.interview_header_content {
  width: 50%;
}

.interview_header_title {
  margin-top: 30px;
  font-family: toppan-bunkyu-midashi-go-std;
  font-size: 2.39vw;
  font-weight: bold;
}

.interview_header_prof {
  rotate: -26deg;
}

.interview_header_text {
  position: absolute;
  bottom: 0;
  font-size: clamp(0.9411764706rem, 0.6745098039rem + 0.4444444444vw, 1.1764705882rem);
  font-weight: bold;
}

.interview_content_container {
  display: flex;
  gap: 2%;
}

.interview_content_container:nth-child(even) {
  flex-direction: row-reverse;
  gap: 2%;
}

.interview_content_wrapper {
  width: 50%;
}

.interview_content_img {
  width: 50%;
}

.interview_content_question {
  margin-top: 7.95vw;
  font-size: clamp(0.9411764706rem, 0.3411764706rem + 1vw, 1.4705882353rem);
}

.interview_content_answer {
  margin-top: 2.65vw;
  font-family: toppan-bunkyu-midashi-go-std;
  font-size: clamp(0.9411764706rem, 0.3411764706rem + 1vw, 1.4705882353rem);
  line-height: 2;
}

.interview_content_prof {
  -o-object-fit: contain;
  object-fit: contain;
}

.interview {
  margin-bottom: 150px;
}

/* ---------- Analytics page (tiles) ---------- */
.analytics_list {
  display: flex;
  flex-wrap: wrap;
}

.analytics_item {
  height: 27.2vw;
  max-height: 400px;
  padding: 1.59vw;
  background-image: linear-gradient(to right, #a8edea 0%, #fed6e3 100%);
  border: 4px solid white;
  border-radius: 15px;
}

.analytics_icon {
  width: 3.7vw;
  margin: auto;
}

.analytics_title {
  margin-top: 20px;
  font-weight: bold;
  text-align: center;
}

.analytics_value {
  margin-top: 2.65vw;
  font-size: 5.56vw;
  font-weight: bold;
  line-height: 1;
  color: #f80;
  text-align: center;
}

.analytics_value-unit {
  position: absolute;
  bottom: 5px;
  font-size: 1.3vw;
  color: black;
  white-space: nowrap;
  transform: translateX(10px);
}

.analytics_mention {
  font-size: 13px;
  color: gray;
  text-align: center;
}

.analytics_mention::before {
  content: "※";
}

/* size mid */
.-flex3 .analytics_header {
  display: flex;
  align-items: flex-end;
  justify-content: space-around;
  margin-bottom: 2.65vw;
}

.-flex3 .analytics_value {
  margin: 0;
  font-size: 7.15vw;
}

.-flex3 .analytics_mention {
  text-align: right;
}

/* size large */
.-flex4 .analytics_icon {
  position: absolute;
  right: 25px;
  width: 7.16vw;
}

.-flex4 .analytics_title {
  margin: 0;
  text-align: left;
}

.-flex4 .analytics_value {
  margin: 0 0 1.35vw;
  font-size: 8.75vw;
  text-align: left;
}

.-flex4 .analytics_mention {
  text-align: right;
}

.analytics_text {
  font-size: clamp(0.8235294118rem, 0.5568627451rem + 0.4444444444vw, 1.0588235294rem);
}

/* =========================================================
   TAB / your breakpoint (@include tab)
========================================================= */
@media (max-width: 1023px) {
  .recruitHeader_container {
    height: calc(100vh - 116px);
    min-height: auto;
    border: none; /* debug削除 */
  }
  .recruitHeader_topMenu {
    bottom: 80px;
  }
  .recruitHeader_topMenu_list {
    font-size: 16px;
  }
  .recruitHeader_title {
    top: 30%;
    transform: translate(-50%, -50%);
  }
  .recruitHeader_slogan {
    font-size: 10vw;
    line-height: 1.7;
  }
  .recruitHeader_heading {
    font-size: 3.5vw;
  }
  .recruitPageHeader {
    position: sticky;
    top: 0;
    left: 0;
    gap: 5vw;
    justify-content: flex-start;
    width: 100%;
    padding-bottom: 10px;
    background: aliceblue;
    transform: translateX(0);
  }
  .recruitPageHeader_title_link {
    padding: 20px;
    padding-right: 30px;
    background: white;
    border-radius: 0 0 40px;
  }
  .recruitPageHeader_title_link img {
    width: 38vw;
  }
  .recruitPageHeader_title {
    flex-direction: column;
    gap: 10px;
  }
  .recruitPageHeader_menu_list {
    flex-direction: column;
    gap: 7px;
    padding-right: 60px;
    width: 100%;
    padding-top: 10px;
  }
  .recruitPageHeader_menu_item .icon {
    display: none;
  }
  .recruitPageHeader_menu {
    width: 100%;
    margin-right: 10px;
  }
  .recruitPageHeader_menu_link {
    justify-content: center;
    padding: 5px;
    border: 1px solid lightgray;
    border-radius: 10px;
  }
  .recruitPageHeader_menu_link.-book {
    align-items: center;
    justify-content: center;
    height: 50px;
    padding: 0;
    font-size: 3vw;
  }
  .recruitAbout {
    flex-direction: column;
    gap: 20px;
  }
  .recruitAbout_text {
    font-size: 4.6vw;
  }
  .recruitAbout_link {
    width: 100%;
    padding: 10px;
  }
  .recruitAbout_title {
    font-size: 16px;
  }
  .recruitAbout_caption {
    margin-top: 0;
    font-size: 17px;
  }
  .recruitAbout_img {
    position: absolute;
    top: 0;
    margin: 0;
  }
  .recruitAbout_content {
    width: 100%;
    font-size: 16px;
  }
  .recruitInterview_img {
    left: auto;
    width: 100%;
  }
  .recruitInterview_title,
  .recruitAnalytics_title,
  .recruitJob_title {
    font-size: 7.8vw;
  }
  .recruitInterview_content {
    top: auto;
    right: auto;
    width: 100%;
    padding: 10px;
    margin-top: 10px;
    border-radius: 15px;
  }
  .recruitInterview_text {
    margin-top: 10px;
    font-size: 16px;
  }
  .p-section {
    height: calc(100vh - 90px);
    min-height: auto;
    padding: 20px;
    border: none; /* debug削除 */
  }
  .recruitAnalytics_list {
    flex-flow: row wrap;
    gap: 10px;
    width: 100%;
    padding: 11px;
  }
  .recruitAnalytics_item {
    flex: 1;
    width: -moz-fit-content;
    width: fit-content;
    aspect-ratio: auto;
    padding: 20px;
  }
  .recruitAnalytics_icon {
    width: 40px;
  }
  .recruitAnalytics_caption {
    font-size: 20px;
    white-space: nowrap;
  }
  .num {
    font-size: 30px;
  }
  .recruitJob.swiper {
    width: 90%;
    max-width: 420px;
    height: 460px;
    margin: 0 auto;
  }
  .recruitJob_item {
    max-width: none;
  }
  .recruitJob_itemTitle {
    margin: 10px auto;
  }
  .recruitJob_caption {
    font-size: 16px;
  }
  .recruitJob_open {
    margin: 10px;
    font-size: 16px;
  }
  .recruitJob_item.swiper-slide {
    height: -moz-fit-content;
    height: fit-content;
    width: 100%;
  }
  .casualInterview_title {
    font-size: 9vw;
  }
  .casualInterview_link {
    font-size: 7vw;
  }
}
/* =========================================================
   SP: 〜768px（SPでのみ強制上書きする“壊れ防止”）
   ※ @include tab より後ろに置くのが重要
========================================================= */
@media (max-width: 768px) {
  /* ---- scroll wrapper: SPは通常スクロール ---- */
  .wrapper {
    height: auto;
    overflow-y: visible;
  }
  .wrapper.is-scrolling {
    touch-action: auto;
  }
  .l-wrapper {
    height: auto;
    min-height: auto;
    overflow-y: visible;
  }
  .p-section {
    height: auto;
    min-height: auto;
    padding: 20px 14px 30px;
  }
  /* ---- recruitHeader ---- */
  .recruitHeader_container {
    position: relative;
    min-height: auto;
    height: auto;
    padding: 110px 14px 70px;
  }
  .recruitHeader_container::before,
  .recruitHeader_container::after {
    top: -14vw;
    left: -18vw;
    width: 56vw;
  }
  .recruitHeader_container::after {
    top: 22vw;
    left: auto;
    right: -18vw;
    width: 44vw;
  }
  .recruitHeader_title {
    position: relative;
    top: auto;
    left: auto;
    width: 100%;
    transform: none;
    text-align: center;
    margin: 0 auto 18px;
  }
  .recruitHeader_title::before {
    top: -18px;
    right: 8px;
    width: 80px;
  }
  .recruitHeader_slogan {
    font-size: clamp(26px, 8.5vw, 40px);
    line-height: 1.35;
  }
  .recruitHeader_heading {
    margin-top: 12px;
    font-size: clamp(14px, 4.2vw, 18px);
    line-height: 1.4;
  }
  .recruitHeader_topMenu {
    position: relative;
    bottom: auto;
    left: auto;
    margin: 18px auto 0;
    width: 100%;
    max-width: 520px;
  }
  .recruitHeader_topMenu_list {
    font-size: 14px;
    line-height: 1.9;
  }
  /* ---- recruitPageHeader: SP横並び ---- */
  .recruitPageHeader {
    position: sticky;
    top: 0;
    left: 0;
    width: 100%;
    max-width: none;
    background: rgba(240, 248, 255, 0.92);
    backdrop-filter: blur(6px);
    transform: none;
    gap: 10px;
  }
  .recruitPageHeader_menu_list {
    gap: 8px;
    width: 100%;
    padding-top: 10px;
  }
  .recruitPageHeader_menu_link {
    padding: 7px 8px;
    font-size: 3vw;
    height: 50px;
    align-items: center;
  }
  /* ---- recruitAbout ---- */
  .recruitAbout {
    flex-direction: column;
    gap: 12px;
  }
  .recruitAbout_text {
    font-size: clamp(16px, 4.6vw, 20px);
    text-align: center;
  }
  .recruitAbout_link {
    width: 100%;
    padding: 14px 12px;
  }
  .recruitAbout_img {
    position: static;
    margin: 10px 0 0;
    text-align: center;
  }
  .recruitAbout_img img {
    width: 90px;
  }
  .recruitAbout_content {
    width: 100%;
    font-size: 15px;
    line-height: 1.9;
  }
  /* ---- recruitInterview teaser ---- */
  .recruitInterview_img {
    position: static;
    left: auto;
    width: 100%;
    max-width: 520px;
    margin: 0 auto;
  }
  .recruitInterview_title,
  .recruitAnalytics_title,
  .recruitJob_title {
    font-size: clamp(22px, 7.5vw, 34px);
    margin-bottom: 12px;
  }
  .recruitInterview_content {
    position: static;
    top: auto;
    right: auto;
    width: 100%;
    padding: 14px;
    margin-top: 12px;
    border-radius: 14px;
  }
  .recruitInterview_text {
    font-size: 15px;
    line-height: 1.9;
  }
  /* ---- recruitAnalytics (top): 2col grid ---- */
  .recruitAnalytics_list {
    width: 100%;
    padding: 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .recruitAnalytics_item {
    width: 100%;
    aspect-ratio: auto;
    padding: 16px 12px 14px;
    border-radius: 14px;
  }
  .recruitAnalytics_icon {
    position: static;
    transform: none;
    margin: 0 auto 6px;
    width: 44px;
    padding: 10px;
  }
  .recruitAnalytics_caption {
    margin-top: 6px;
    font-size: 14px;
    white-space: normal;
  }
  .num {
    font-size: 28px;
  }
  .unit {
    font-size: 14px;
    position: static;
  }
  /* ---- job(swiper) ---- */
  .recruitJob.swiper {
    width: 92%;
    max-width: 420px;
    height: auto;
    margin: 0 auto;
  }
  .recruitJob_item,
  .recruitJob_item.swiper-slide {
    width: 100%;
    max-width: none;
    height: auto;
  }
  .recruitJob_caption,
  .recruitJob_open {
    font-size: 15px;
  }
  /* ---- sub page header: menu overlap fix ---- */
  .recruitSubPageHeader {
    position: relative;
    height: auto;
    padding: 28px 14px 18px;
  }
  .recruitSubPageHeader_heading {
    position: relative;
    height: auto;
  }
  .recruitSubPageHeader_heading_ja {
    position: relative;
    top: auto;
    left: auto;
    z-index: 2;
    transform: none;
    font-size: clamp(20px, 6.2vw, 28px);
    text-align: center;
    margin: 10px 0 6px;
  }
  .recruitSubPageHeader_heading_en {
    position: relative;
    right: auto;
    bottom: auto;
    z-index: 0;
    font-size: clamp(44px, 14vw, 72px);
    text-align: center;
    line-height: 1;
    margin: 0 0 10px;
  }
  .recruitSubPageHeader_subMenu {
    position: relative;
    right: auto;
    bottom: auto;
    z-index: 2;
    width: 100%;
    margin-top: 10px;
    font-size: 14px;
  }
  .recruitSubPageHeader_list {
    margin: 0 0 0 auto;
    width: -moz-fit-content;
    width: fit-content;
    padding-left: 18px;
  }
  /* ---- interview intro: min-width解除 ---- */
  .interviewIntro_list {
    width: 100%;
    min-width: 0;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 30px;
    padding: 0 14px;
  }
  .interviewIntro_item {
    width: 100%;
    border-radius: 18px;
    padding: 14px 12px;
  }
  .interviewIntro_title {
    font-size: 16px;
    line-height: 1.4;
  }
  .interviewIntro_img {
    width: 56%;
    margin: 10px auto;
  }
  /* ---- interview body: 2col -> 1col ---- */
  .interview_header {
    width: 100%;
    padding: 18px 14px;
    transform: none;
    flex-direction: column;
    gap: 10px;
    align-items: center;
    left: auto;
  }
  .interview_header_img {
    width: 78%;
    max-width: 360px;
  }
  .interview_header_content {
    width: 100%;
  }
  .interview_header_title {
    font-size: clamp(18px, 5.2vw, 22px);
    margin-top: 6px;
    text-align: center;
  }
  .interview_header_text {
    position: static;
    margin-top: 10px;
    font-size: 14px;
    text-align: center;
  }
  .interview_content_container,
  .interview_content_container:nth-child(even) {
    flex-direction: column;
    gap: 10px;
  }
  .interview_content_wrapper,
  .interview_content_img {
    width: 100%;
  }
  .interview_content_question {
    margin-top: 18px;
    font-size: 16px;
    line-height: 1.6;
  }
  .interview_content_answer {
    margin-top: 10px;
    font-size: 15px;
    line-height: 1.95;
  }
  .interview {
    margin-bottom: 60px;
  }
  /* ---- analytics page tiles: 2col grid ---- */
  .analytics {
    padding: 0 14px;
  }
  .analytics_list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin: 0;
    padding: 0;
  }
  .analytics_item {
    height: auto;
    max-height: none;
    padding: 14px 12px;
    border-radius: 14px;
    border-width: 3px;
    flex: unset !important; /* inline style無効化 */
  }
  .analytics_header,
  .-flex3 .analytics_header,
  .-flex4 .analytics_header {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 8px;
    margin-bottom: 10px;
  }
  .analytics_icon,
  .-flex4 .analytics_icon {
    position: static;
    width: 42px;
    margin: 0 auto;
  }
  .analytics_titleBlock {
    width: 100%;
    text-align: center;
  }
  .analytics_title,
  .-flex4 .analytics_title {
    margin-top: 6px;
    font-size: 14px;
    line-height: 1.3;
    text-align: center;
  }
  .analytics_value,
  .-flex3 .analytics_value,
  .-flex4 .analytics_value {
    margin: 0;
    font-size: 30px;
    text-align: center;
    line-height: 1.1;
  }
  .analytics_value-unit {
    position: static;
    display: inline-block;
    margin-left: 6px;
    font-size: 13px;
    transform: none;
    white-space: nowrap;
  }
  .analytics_text {
    font-size: 14px;
    line-height: 1.8;
  }
  .analytics_mention {
    margin-top: 8px;
    font-size: 12px;
  }
}
/* =========================================================
   Small: 〜390px
========================================================= */
@media (max-width: 390px) {
  .recruitPageHeader_menu_list {
    gap: 6px;
  }
  .recruitPageHeader_menu_link {
    padding: 7px 8px;
    font-size: 3vw;
  }
  .recruitAnalytics_list {
    grid-template-columns: 1fr;
  }
  .analytics_list {
    grid-template-columns: 1fr;
  }
}
/* ===== モーダル土台（中央固定） ===== */
.jobModal {
  position: absolute;
  inset: 0;
  top: 50%;
  transform: translate(0px, 2%);
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity 0.2s ease,
    visibility 0.2s ease;
}

.jobModal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.jobModal_overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
}

/* 常に“今見ている画面の中央” */
.jobModal_panel {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(92vw, 860px);
  max-height: 88vh;
  overflow: hidden;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
}

/* ヘッダー */
.jobModal_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 18px 12px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  background: linear-gradient(90deg, rgba(255, 185, 211, 0.55), rgba(178, 253, 255, 0.45));
}

.jobModal_kicker {
  margin: 0 0 6px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: rgba(0, 0, 0, 0.6);
}

.jobModal_title {
  margin: 0;
  font-weight: 900;
  font-size: clamp(18px, 2.6vw, 26px);
  line-height: 1.2;
}

.jobModal_close {
  flex: 0 0 auto;
  width: 44px;
  text-align: center;
  height: 44px;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  cursor: pointer;
  font-size: 22px;
}

/* 本体：2カラム（スクロールは中だけ） */
.jobModal_grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 14px;
  padding: 14px 18px 0;
  max-height: calc(88vh - 64px - 74px);
  overflow: auto;
  padding-bottom: 100px;
  /* ←中だけスクロール */
}

/* 左右カラムをカード風に */
.jobModal_left,
.jobModal_right {
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px;
  padding: 14px;
}

/* セクション */
.jobModal_section + .jobModal_section {
  margin-top: 14px;
}

.jobModal_h {
  margin: 0 0 8px;
  font-weight: 900;
  font-size: 14px;
  padding-left: 10px;
  border-left: 4px solid #ce6593;
}

.jobModal_p {
  margin: 0;
  font-size: 14px;
  line-height: 1.9;
  white-space: pre-wrap;
  color: rgba(0, 0, 0, 0.78);
}

/* 条件（定義リスト） */
.jobModal_dl {
  display: grid;
  grid-template-columns: 5.8em 1fr;
  gap: 10px 12px;
  margin: 0;
}

.jobModal_dl dt {
  font-weight: 800;
  font-size: 13px;
  color: rgba(0, 0, 0, 0.65);
  padding: 8px 10px;
  background: rgba(240, 248, 255, 0.8);
  border-radius: 10px;
}

.jobModal_dl dd {
  margin: 0;
  font-size: 13px;
  line-height: 1.7;
  padding: 8px 10px;
  background: rgba(0, 0, 0, 0.03);
  border-radius: 10px;
  white-space: pre-wrap;
}

/* フッターCTA：固定で常に見える */
.jobModal_footer {
  position: sticky;
  bottom: 0;
  padding: 12px 18px 16px;
  background: #fff;
  border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.jobModal_cta {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  border-radius: 14px;
  font-weight: 900;
  text-decoration: none;
  color: #fff;
  background: linear-gradient(270deg, rgb(0, 47, 47), rgb(111, 165, 0));
}

/* SP：1カラムにする（見た目を崩さない） */
@media (max-width: 768px) {
  .jobModal_panel {
    width: calc(100vw - 28px);
    max-height: 90vh;
    border-radius: 14px;
  }
  .jobModal_grid {
    grid-template-columns: 1fr;
    padding: 12px 14px 0;
    max-height: calc(90vh - 64px - 74px);
  }
  .jobModal_left,
  .jobModal_right {
    padding: 12px;
    border-radius: 12px;
  }
  .jobModal_dl {
    grid-template-columns: 1fr;
    /* SPは縦並びが読みやすい */
  }
}
/* =========================
   Job Modal：SP下固定版
========================= */
@media (max-width: 768px) {
  .jobModal_panel {
    position: sticky;
    left: auto;
    transform: none;
    width: 90vw;
    max-width: none;
    height: calc(80dvh - clamp(80px, 18vw, 110px) - 10px);
    border-radius: 16px 16px 0 0;
    overflow: hidden;
    top: 20%;
    margin: 0 auto;
  }
  /* モーダル中身だけスクロール */
  .jobModal_body {
    height: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 16px;
  }
  .recruitJob_list {
    display: flex;
    gap: 30px;
    flex-direction: column;
  }
}
.companyIntro {
  display: flex;
  flex-direction: row-reverse;
  gap: 3%;
  align-items: center;
  justify-content: flex-end;
  width: 73%;
  padding: 20px;
  margin-top: 100px;
  margin-left: 12%;
  color: white;
  background-color: #3a75bb;
  border-radius: 30px 10px 10px 30px;
}
@media (max-width: 1023px) {
  .companyIntro {
    flex-direction: column-reverse;
    width: 90%;
    padding-bottom: 30px;
    margin-top: 50px;
    margin-right: auto;
    margin-left: auto;
    border-radius: 5px 5px 15px 15px;
  }
}

.companyIntro_slogan {
  font-size: 2.3vw;
  font-weight: bold;
  line-height: 1.5;
}
@media (max-width: 1023px) {
  .companyIntro_slogan {
    margin-top: 20px;
    font-size: 6.3vw;
  }
}

.companyIntro_image {
  width: 40%;
  height: auto;
  aspect-ratio: 1.2;
  contain: paint;
  border-radius: 20px;
}
@media (max-width: 1023px) {
  .companyIntro_image {
    width: 100%;
  }
}

.companyIntro_text {
  max-width: 36vw;
  margin-top: 3.2vw;
  font-size: clamp(0.8235294118rem, 0.0901960784rem + 1.2222222222vw, 1.4705882353rem);
}
@media (max-width: 1023px) {
  .companyIntro_text {
    max-width: 100%;
    font-size: 16px;
  }
}

.companyIntro::before {
  position: absolute;
  top: 0;
  right: -4.2%;
  display: block;
  width: 4%;
  height: 100%;
  content: "";
  background-color: #3a75bb;
  border-radius: 10px 30px 30px 10px;
}
@media (max-width: 1023px) {
  .companyIntro::before {
    top: -22px;
    right: auto;
    width: 100%;
    height: 20px;
    border-radius: 10px 10px 5px 5px;
  }
}

.companyIntro::after {
  position: absolute;
  top: 6%;
  right: -4.2%;
  display: block;
  width: 150px;
  width: 4%;
  font-size: 1.5vw;
  font-weight: bold;
  color: white;
  content: "Principle";
  rotate: 90deg;
}
@media (max-width: 1023px) {
  .companyIntro::after {
    top: -25px;
    right: auto;
    left: 10px;
    font-size: 14px;
    rotate: 0deg;
  }
}

.companyProfile {
  margin-top: 150px;
}
@media (max-width: 1023px) {
  .companyProfile {
    margin-top: 50px;
  }
}

.companyProfileTable {
  padding: 100px;
  margin-top: 100px;
  background: white;
}
@media (max-width: 1023px) {
  .companyProfileTable {
    padding: 30px;
    margin-top: 50px;
  }
}

.companyProfileTable_th {
  width: 18.5vw;
  padding-top: 30px;
}
@media (max-width: 1023px) {
  .companyProfileTable_th {
    width: 100%;
  }
}

.companyProfileTable_item {
  border-bottom: 1px solid #707070;
}
@media (max-width: 1023px) {
  .companyProfileTable_item {
    display: flex;
    flex-direction: column;
  }
}

.companyProfileTable_list {
  width: 100%;
  max-width: 900px;
  margin: auto;
  font-size: 18px;
  border-top: 1px solid #707070;
}

.companyProfileTable_td {
  padding: 30px;
}

.parallax {
  min-height: 500px;
  margin-top: 150px;
  background-image: url("/sansei/wp-content/uploads/s-town.webp");
  background-repeat: no-repeat;
  background-attachment: fixed;
  background-position: center;
  background-size: cover;
}
@media (max-width: 1023px) {
  .parallax {
    min-height: 700px;
    margin-top: 50px;
  }
}

.access {
  width: calc(100% - (50dvw - 625px));
  padding: 100px;
  margin-top: -350px;
  margin-left: auto;
  background: white;
}
@media (max-width: 1023px) {
  .access {
    width: 100%;
    padding: 0;
    padding-top: 50px;
    margin-top: 50px;
  }
}

.access_list {
  display: flex;
  flex-flow: row wrap;
  gap: 50px 10%;
  justify-content: flex-start;
  margin-top: 100px;
}
@media (max-width: 1023px) {
  .access_list {
    flex-direction: column;
    gap: 20px;
    align-items: center;
    justify-content: center;
    margin-top: 50px;
  }
}

.access_item {
  width: 30%;
}
@media (max-width: 1023px) {
  .access_item {
    width: 90%;
  }
}

iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  margin-bottom: 30px;
}

.access_title {
  font-size: 30px;
}

.access_address {
  font-size: 18px;
}

.single_header {
  display: flex;
  width: 900px;
  height: auto;
  margin: auto;
  margin-top: 100px;
  margin-bottom: 30px;
  background: whitesmoke;
  border-top: 15px solid #0060cc;
  border-radius: 15px 15px 0 0;
}
@media (max-width: 1023px) {
  .single_header {
    flex-direction: column;
    width: 90%;
  }
}

.single_heading {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 20px 50px;
}
@media (max-width: 1023px) {
  .single_heading {
    padding: 10px;
  }
}

.single_title {
  max-width: 100%;
  font-size: 2.2352941176rem;
  line-height: 1.5;
}

.single_info {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
}

.single_cat {
  padding: 8px 20px;
  font-weight: bold;
  line-height: 1;
  color: white;
  background: black;
  border-radius: 5px;
}

.single_thumbnail {
  width: 100%;
  height: auto;
}

.single_thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
}

.single_content {
  max-width: 900px;
  padding: 50px;
  margin: auto;
  margin-bottom: 150px;
  font-size: 1.0588235294rem;
  line-height: 2;
  background: whitesmoke;
  border-radius: 20px;
}
@media (max-width: 1023px) {
  .single_content {
    padding: 30px;
    margin-bottom: 50px;
    border-radius: 0;
  }
}
.single_content h2.wp-block-heading {
  padding: 5px 20px;
  margin-top: 50px;
  margin-bottom: 30px;
  font-size: 1.4117647059rem;
  background: white;
  border-left: 15px solid #0060cc;
}
@media (max-width: 1023px) {
  .single_content h2.wp-block-heading {
    margin-top: 25px;
    margin-bottom: 15px;
    line-height: 1.5;
  }
}
.single_content h3.wp-block-heading {
  margin-top: 50px;
  margin-bottom: 10px;
  font-size: 1.7647058824rem;
  text-align: center;
}
@media (max-width: 1023px) {
  .single_content h3.wp-block-heading {
    margin-top: 25px;
    line-height: 1.5;
  }
}
.single_content p {
  margin-bottom: 20px;
}
.single_content .wp-block-image {
  margin-bottom: 50px;
}

.backToList {
  margin-bottom: 150px;
}
@media (max-width: 1023px) {
  .backToList {
    margin-bottom: 50px;
  }
}

.backToList_btn {
  text-align: center;
}

.backToList_btn a {
  display: block;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 350px;
  height: 70px;
  margin: auto;
  font-size: 1.1764705882rem;
  font-weight: bold;
  color: white;
  background: #0060cc;
  border-radius: 50px;
}
@media (max-width: 1023px) {
  .backToList_btn a {
    width: 90%;
  }
}

.column {
  display: flex;
  flex-wrap: wrap;
  gap: 70px 0;
  justify-content: space-around;
  margin-top: 100px;
}
@media (max-width: 1023px) {
  .column {
    gap: 30px 0;
    margin-top: 50px;
  }
}

.columnPost_item {
  width: 30%;
}
@media (max-width: 1023px) {
  .columnPost_item {
    width: 48%;
  }
}

.columnPost_time {
  font-family: Poppins;
  font-size: 28px;
  font-weight: bold;
  color: #707070;
}
@media (max-width: 1023px) {
  .columnPost_time {
    font-size: 18px;
  }
}

.columnPost_img img {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  border-radius: 30px;
}

.columnPost_title {
  margin-top: 10px;
  font-size: 28px;
  font-weight: bold;
  color: #707070;
}
@media (max-width: 1023px) {
  .columnPost_title {
    font-size: 18px;
    line-height: 1.3;
  }
} /*# sourceMappingURL=style.css.map */
