/* =========================================
  ヘッダーメニューの反転打消し
========================================= */
.page-id-141 #gMenu .menu li.current-page-ancestor>a,
.page-id-20154 #gMenu .menu li.current-page-ancestor>a,
.page-id-20150 #gMenu .menu li.current-page-ancestor>a {
  background-color: #FFFFFF;
}

/* =========================================
  ぱんくず
========================================= */
.new-panList {
  @media screen and (width >=970px) {
    padding-left: 1.5em;
    padding-right: 1.5em;

    #panList {
      width: 94%;
      margin-left: auto;
      margin-right: auto;
    }

    #panList #panListInner {
      padding: 0;
    }

    .innerBox {
      width: 100% !important;
      padding-left: 20px;
    }
  }

  * {
    font-family: 'Noto Sans JP', sans-serif;
  }
}

/* =========================================
  会社情報トップ
========================================= */
.new-company * {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 18px;
  color: #334155;
  font-weight: 300;
  line-height: 1.625;
}

.new-company a {
  color: #3b82f6;
  text-decoration: none;
  transition: all cubic-bezier(0.4, 0, 0.2, 1) 0.15s;
}

.new-company a:hover {
  color: #3b82f6;
  text-decoration: underline;
}

.new-company .text-blue {
  color: #3b82f6 !important;
  font-weight: 700;
}

.new-company .text-uppercase {
  text-transform: uppercase;
}

.new-company .en-text {
  font-size: 14px;
  letter-spacing: 0.3em;
}

.new-company h2 {
  font-size: 30px;
  font-weight: 700;
  color: #0f172a;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 2rem;
}

.new-company h3 {
  font-size: 24px;
  font-weight: 700;
  color: #0f172a;
}

.new-company .company-header__box {
  margin-bottom: 3rem;
}

.new-company .company-header__section-intro {
  color: #64748b;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.8;
}

@media screen and (width >=850px) {
  .new-company .company-header__box {
    max-width: 800px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* ******************************** */
/* ヒーローセクション */
/* ******************************** */
.new-company .company-hero {
  position: relative;
}

.new-company .company-hero__card {
  position: absolute;
  top: 100%;
  left: 0;
  background-color: rgba(255, 255, 255, 0.7);
  padding: 20px;
}

.new-company .company-hero .company-hero__card__title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  font-size: 36px;
  margin-bottom: 10px;
  font-weight: 700;
  color: #0f172a;
}

.new-company .company-hero .company-hero__card__title::after {
  content: "";
  width: 50px;
  border-bottom: 4px solid #3b82f6;
  border-radius: 2px;
}

.new-company .company-hero .company-hero__card__description {
  text-align: left;
  font-weight: 400;
}

.new-company .company-hero .company-hero__card__image {
  width: 100%;
  height: 250px;
  background-image: url("/wp-content/uploads/company-bk.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

@media screen and (width >=769px) {
  .new-company .company-hero__card {
    width: 430px;
    top: 50%;
    transform: translateY(-50%);
    padding-left: 6rem;
    padding-right: 6rem;
  }

  .new-company .company-hero .company-hero__card__image {
    min-height: 500px;
  }
}

/* ******************************** */
/* 代表メッセージ */
/* ******************************** */
.new-company .company-message {
  padding-top: 16rem;
  padding-left: 1rem;
  padding-right: 1rem;
  padding-bottom: 6rem;
}

.new-company .company-message .company-president-message__box {
  padding: 2rem;
  background-color: rgba(239, 246, 255, 0.5);
  border: 1px solid rgb(219, 234, 254);
  border-radius: 1.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3rem;
}

.new-company .company-message .president-message {
  order: 2;
}

.new-company .company-message .president-message__title {
  text-align: left;
}

.new-company .company-message .president-message__quote {
  text-align: left;
}

.new-company .company-message .president-message__quote--para {
  margin-top: 1.5rem;
}

.new-company .company-message .president-message__footer {
  text-align: left;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgb(191 219 254 / 0.5);
}

.new-company .company-message .president-message__footer__address {
  font-style: normal;
}

.new-company .company-message .president-name {
  font-size: 20px;
  font-weight: 700;
  color: #0f172a;
}

.new-company .company-message .president-title {
  font-size: 14px;
  line-height: 130%;
  display: inline-block;
}

.new-company .company-message .president-photo__box {
  order: 1;
  background-color: #ffffff;
  border-radius: 1rem;
  padding: 1rem;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 20px 25px -5px #dbeafe, 0 8px 10px -6px #dbeafe;
}

.new-company .company-message .president-photo__image {
  max-width: 100%;
  height: auto;
}

@media screen and (width >=769px) {
  .new-company .company-message {
    padding-top: 6rem;
  }

  .new-company .company-message .company-message__wrapper {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (width >=1024px) {
  .new-company .company-message .company-president-message__box {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 3erm;
    align-items: center;
  }

  .new-company .company-message .president-message {
    order: 1;
  }

  .new-company .company-message .president-photo__box {
    order: 2;
    aspect-ratio: 1 / 0.8;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}

/* ******************************** */
/* 会社概要 */
/* ******************************** */
.new-company .company-profile {
  padding-top: 6rem;
  padding-bottom: 6rem;
  background-color: rgb(248 250 252);
}

.new-company .company-profile .company-header__box {
  padding-left: 1rem;
  padding-right: 1rem;
}

.new-company .company-profile .company-profile__box {
  padding-left: 1rem;
  padding-right: 1rem;
}

.new-company .company-profile .company-profile__info {
  border: 1px solid #e5e7eb;
  border-radius: 1.5rem;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
  text-align: left;
  background-color: #FFFFFF;
}

.new-company .company-profile .company-profile__info-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 2rem;
  border-bottom: 1px solid #e5e7eb;
}

.new-company .company-profile__info .company-profile__info-row:last-child {
  border: none;
}

.new-company .company-profile__info dt {
  font-size: 14px;
  margin-bottom: 0.5rem;
}

.new-company .company-profile__info dd {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75rem;
  width: 100%;
}

.new-company .company-profile .company-profile__info-row--company dd {
  font-size: 18px;
}

.new-company .company-profile__info .company-profile__info-row--address {
  font-style: normal;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75rem;
}

.new-company .company-profile__info dd .company-profile__info-row--small {
  font-size: 12px;
  font-weight: 700;
  color: #94a3b8;
}

.new-company .company-profile__info .company-profile__info-row--text {
  font-size: 12px;
  font-weight: 400;
  color: #94a3b8;
}

.new-company .company-profile__info .company-profile__info-row--tel-fax {
  font-size: 14px;
  font-weight: 500;
  color: #94a3b8;
}

.new-company .company-profile__info .company-profile__info-row__list--disc {
  list-style: disc;
  margin-left: 1.5rem;
}

.new-company .company-profile__info .company-profile__info-row__list--remakrs,
.new-company .company-profile__info .company-profile__info-row__list--remakrs a {
  font-size: 14px;
}

.new-company .company-profile__info .company-profile__info-row__list li {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 0.5rem;
}

.new-company .company-profile__info .company-profile__info-row__list li a {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 0.5rem;
}

.new-company .company-profile__info .company-profile__info-row__list--flex li {
  display: flex;
  align-items: center;
}

.new-company .company-profile__info .company-profile__info-row__list--flex li span {
  display: inline-block;
  width: 115px;
}

.new-company .company-profile__info .company-profile__info-row--link {
  font-size: 16px;
  font-weight: 400;
  margin-bottom: 0.5rem;
}

@media screen and (width >=640px) {
  .new-company .company-profile .company-profile__info-row__list--flex {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media screen and (width >=769px) {
  .new-company .company-profile .company-profile__wrapper {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }

  .new-company .company-profile .company-profile__info-row {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .new-company .company-profile__info dd {
    grid-column: span 3 / span 3;
  }
}

/* ******************************** */
/* 沿革 */
/* ******************************** */
.new-company .company-history {
  padding: 6rem 1rem;
}

.new-company .company-history .timeline-container {
  text-align: left;
}

.new-company .company-history .timeline-list {
  border-left: 1px solid #eff6ff;
  margin-left: 1rem;
}

.new-company .company-history .timeline-item {
  position: relative;
  border-left: 1px solid #eff6ff;
  padding-bottom: 4rem;
  padding-left: 2.5rem;
}

.new-company .company-history .timeline-dot {
  display: block;
  width: 8px;
  height: 8px;
  position: absolute;
  top: 18px;
  left: -7px;
  border-radius: 8px;
  background-color: #dbeafe;
  border: 2px solid #3b82f6;
}

.new-company .company-history .timeline-header {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-bottom: 0.75rem;
}

.new-company .company-history .year {
  color: #0f172a;
  font-weight: 700;
  font-size: 30px;
}

.new-company .company-history .year-wareki {
  font-weight: 400;
  font-size: 22px;
}

.new-company .company-history .description {
  color: #64748b;
  font-size: 14px;
  font-weight: 400;
}

@media screen and (width >=769px) {
  .new-company .company-history .company-history__wrapper {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }

  .new-company .company-history .timeline-container {
    max-width: 850px;
    margin-left: auto;
    margin-right: auto;
  }

  .new-company .company-history .description {
    font-size: 16px;
  }
}

/* ******************************** */
/* ソーバルグループについて */
/* ******************************** */
.new-company .company-group {
  padding: 6rem 1rem;
  background-color: rgba(239, 246, 255, 0.5);
}

.new-company .company-group__features {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.new-company .company-group__features .feature-item {
  background-color: #FFFFFF;
  border: 1px solid #dbeafe;
  border-radius: 1.5rem;
  padding: 2rem;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.new-company .company-group__features .feature-item--title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.new-company .company-group__features .feature-item--title .icon-square {
  width: 64px;
  height: 64px;
  background-color: #EFF6FF;
  border-radius: 15px;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 0.75em;
}

.new-company .company-group__features .feature-item--description {
  color: #64748b;
  font-size: 14px;
  font-weight: 400;
}

.new-company .company-group .company-group-link {
  margin-top: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.new-company .company-group .company-group-link--button {
  display: inline-block;
  border: 1px solid #dbeafe;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  border-radius: 5rem;
  background-color: #FFFFFF;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
  padding: 1.5rem 3rem;
  width: fit-content;
}

@media screen and (width >=431px) {
  .new-company .company-group .company-group-link--button {
    font-size: 16px;
  }
}

@media screen and (width >=769px) {
  .new-company .company-group .company-group__wrapper {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }

  .new-company .company-group__features {
    flex-direction: row;
  }

  .new-company .company-group .company-group-link--button {
    font-size: 16px;
  }
}

/* ******************************** */
/* アクセス */
/* ******************************** */
.new-company .company-access {
  padding: 6rem 1rem 3rem;
}

.new-company .company-access .access-details {
  border: 1px solid #e5e7eb;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 25px 50px -12px #bfdbfe33;
  border-radius: 1.5rem;
}

.new-company .company-access .access-details__inner {
  padding: 3rem;
  text-align: left;
}

.new-company .company-access .access-details__inner__title {
  font-size: 14px;
  letter-spacing: 0.1rem;
  color: #2563eb;
  margin-bottom: 1rem;
}

.new-company .company-access .access-details__inner__address {
  margin-bottom: 2.5rem;
  color: #0f172a;
  font-style: normal;
  font-weight: 500;
  line-height: 1.625
}

.new-company .company-access .access-details__inner__stations--item {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.new-company .company-access .access-details__inner__stations--title {
  font-weight: 700;
  font-size: 16px;
}

.new-company .company-access .access-details__inner__stations--details {
  font-size: 14px;
  color: #64748b;
  font-weight: 500;
}

.new-company .company-access .access-details__inner__stations--button {
  color: #FFFFFF;
  background-color: #2563eb;
  width: 100%;
  font-size: 16px;
  font-weight: 700;
  border-radius: 0.75rem;
  margin-top: 3rem;
  padding: 1rem 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 10px 15px -3px #dbeafe, 0 4px 6px -4px #dbeafe;
  transition: all cubic-bezier(0.4, 0, 0.2, 1) 0.15s;
}

.new-company .company-access .access-details__inner__stations--button:hover {
  text-decoration: none;
  background-color: #1d4ed8;
}

.new-company .company-access .company-map {
  display: flex;
  border-radius: 0 0 1.5rem 1.5rem;
  overflow-y: hidden;
}

.new-company .company-access .company-map__iframe {
  flex: 1;
  min-height: 300px;
  border: none;
  margin-bottom: 0;
  display: block;
  filter: grayscale(100%) sepia(30%) hue-rotate(180deg) brightness(1) saturate(1.5);
}

@media screen and (width >=769px) {
  .new-company .company-access .company-access__wrapper {
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
  }
}

@media screen and (width >=1024px) {
  .new-company .company-access .access-details {
    display: flex;
  }

  .new-company .company-access .access-details__inner {
    width: 40%;
  }

  .new-company .company-access .company-map {
    width: 60%;
    border-radius: 0 1.5rem 1.5rem 0;
  }
}

/* =========================================
  求人案内ページ
========================================= */
.new-recruit {
  --color-primary: #1e3a8a;
  --color-secondary: #0284c7;
  --color-accent: #0d9488;
  --bg-page: #f0f7ff;
  --bg-card: #ffffff;
  --gradient-main: linear-gradient(135deg, #1e3a8a 0%, #0284c7 50%, #0d9488 100%);
  --text-main: #0f172a;
  --text-sub: #334155;
  --card-border: #d1e9ff;
  --container-max: 1400px;
}

/* ページ固有のグローバル上書き（スコープ外） */
.page-id-141 #footerSection #pagetop {
  background-color: #f8fafc;
}

.new-recruit {
  /* =========================================
  Global & Layout
  ========================================= */
  color: var(--text-main);
  transition: background-color 0.5s ease, color 0.5s ease;
  overflow-x: hidden;
  line-height: 1.6;
  font-size: 16px;
  font-family: 'Noto Sans JP', sans-serif;

  /* フォントサイズレスポンシブ */
  @media screen and (width >=430px) {
    font-size: 18px;
  }

  @media screen and (width >=768px) {
    font-size: 20px;
  }

  /* 特定要素のみボックスサイズ調整（全称セレクタ * は避ける） */
  *,
  ::before,
  ::after {
    box-sizing: border-box;
  }

  /* デフォルトマージンリセットが必要な主要要素のみ指定 */
  h1,
  h2,
  h3,
  h4,
  p,
  ul,
  figure,
  blockquote,
  dl,
  dd {
    margin: 0;
    padding: 0;
    font-family: 'Noto Sans JP', sans-serif;
  }

  .container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 2em;
    width: 100%;
  }

  section {
    padding: 5em 0;
    position: relative;
  }

  .bg-white {
    background-color: #ffffff;
  }

  .bg-light {
    background-color: #f8faff;
  }

  .border-y {
    border-top: 1px solid #f1f5f9;
    border-bottom: 1px solid #f1f5f9;
  }

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

  .italic {
    font-style: italic;
  }

  .h2-narrow {
    letter-spacing: -3.5px;
  }

  /* =========================================
  Common Components
  ========================================= */
  .top-divider {
    height: 8px;
    width: 100%;
    background: var(--gradient-main);
    /* background-color fallback is implicit via gradient, redundant prop removed */
    position: relative;
    z-index: 100;
  }

  /* 重複していた定義を統合 */
  .hero-gradient-text {
    color: var(--color-primary);
    font-weight: 900;
    background: var(--gradient-main);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .bento-card {
    background: var(--bg-card);
    border: 2px solid var(--card-border);
    box-shadow: 0 4px 20px -5px rgba(0, 0, 0, 0.05);
    transition: all 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.2);
    overflow: hidden;
    border-radius: 2em;
  }

  .bento-card-header {
    display: flex;
    align-items: center;
    gap: 1.5em;
    margin-bottom: 2em;
  }

  .bento-card-header .icon-circle,
  .bento-card-header h3 {
    margin-bottom: 0;
  }

  .bento-card .lead {
    font-size: 1.125em;
    font-weight: 900;
    color: var(--color-primary);
    margin-bottom: 1.5em;
    font-style: italic;
  }

  .btn-main {
    background: var(--gradient-main);
    color: white !important;
    font-weight: 900;
    padding: 1.5em 4em;
    border-radius: 9999px;
    display: inline-block;
    text-decoration: none;
    transition: all 0.3s ease;
    border: none;
    cursor: pointer;
    font-size: 1.25em;
    /* 不要な長いbox-shadow定義を整理 */
    box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  }

  .btn-main:hover {
    transform: scale(1.05);
    filter: brightness(1.1);
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.2);
  }

  .btn-secondary {
    background: #fff;
    color: #0f172a !important;
    border: 4px solid #e2e8f0;
  }

  .badge-ui {
    display: inline-flex;
    align-items: center;
    gap: 0.6em;
    padding: 0.6em 2em;
    border: 2px solid #f1f5f9;
    border-radius: 9999px;
    font-size: 0.75em;
    font-weight: 900;
    background: #fff;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-bottom: 2em;
    color: var(--color-primary);
  }

  .badge-blue {
    background: #f0f7ff;
    color: #2563eb;
    border-color: #bfdbfe;
    font-size: 0.625em;
    padding: 0.25em 1em;
  }

  .badge {
    width: 1.3em;
    height: auto;
  }

  .badge-text {
    /* 固定幅を廃止し、コンテンツに合わせる */
    display: inline-block;
    width: auto;
  }

  .section-tag {
    font-size: 0.75em;
    font-weight: 900;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    font-style: italic;
    color: var(--color-primary);
    margin-bottom: 1.5em;
    display: block;
  }

  .section-tag-small {
    font-size: 0.6875em;
  }

  .section-tag-secondary {
    color: var(--color-secondary);
  }

  .section-tag-normal {
    font-style: normal;
  }

  .text-secondary {
    color: var(--color-secondary) !important;
  }

  .text-accent {
    color: var(--color-accent) !important;
  }

  /* =========================================
  Hero
  ========================================= */
  .hero {
    height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    background-color: #fff;
    text-align: center;
  }

  @media screen and (width >=768px) {
    .hero {
      align-items: center;
      min-height: 830px;
    }
  }

  .hero h1 {
    font-size: 2.3em;
    font-weight: 900;
    line-height: 1.4;
    margin-top: 1em;
    margin-bottom: 2em;
    letter-spacing: -0.05em;
    color: #0f172a;
  }

  @media screen and (width >=768px) {
    .hero h1 {
      font-size: 3.5em;
      margin-bottom: 1.5em;
    }
  }

  .hero p {
    font-size: 1.125em;
    font-weight: bold;
    color: var(--text-sub);
    max-width: 48em;
    margin: 0 auto 3.5em;
  }

  @media screen and (width >=768px) {
    .hero p {
      font-size: 1em;
      margin-bottom: 5em;
    }
  }

  .scroll-indicator {
    width: 3.5em;
    height: 3.5em;
    background: #fff;
    border-radius: 1em;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #f1f5f9;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.05);
    margin: 0 auto;
  }

  .scroll-indicator img {
    width: 2em;
    height: 2em;
    color: #cbd5e1;
  }

  /* =========================================
  Global Talent
  ========================================= */
  .global-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4em;
    align-items: center;
  }

  @media (min-width: 1024px) {
    .global-grid {
      grid-template-columns: 7fr 5fr;
    }
  }

  .global-content {
    text-align: left;
  }

  .global-content h2 {
    font-size: 2.25em;
    font-weight: 900;
    margin-bottom: 1em;
    line-height: 1.25;
  }

  .global-content p {
    font-size: 1.125em;
    font-weight: bold;
    color: var(--text-sub);
  }

  @media screen and (width >=768px) {
    .global-content p {
      font-size: 1em;
    }
  }

  .global-card {
    background: #0f172a;
    color: #fff;
    padding: 3em 2em;
    position: relative;
  }

  .global-card h3 {
    color: var(--color-primary);
    font-style: italic;
    font-size: 24px;
    margin-bottom: 1.5em;
    font-weight: 900;
  }

  .global-card .main-text {
    font-size: 1.125em;
    font-weight: 700;
    margin-bottom: 2em;
  }

  .global-card .sub-text {
    font-size: 0.875em;
    opacity: 0.8;
    font-weight: 500;
    text-align: left;
    letter-spacing: -0.5px;
  }

  .global-bg-icon {
    position: absolute;
    top: 0;
    right: 0;
    padding: 2em;
    opacity: 0.1;
    width: 10em;
    height: 10em;
  }

  /* =========================================
  Work (Business)
  ========================================= */
  .section-header {
    text-align: center;
    margin-bottom: 5em;
  }

  .section-header.requirements-benefits {
    margin-top: 5em;
  }

  .section-header h2 {
    font-size: 2.25em;
    font-weight: 900;
    margin-bottom: 0.5em;
    line-height: 1.2;
  }

  .section-header .sub {
    letter-spacing: 0.4em;
    font-weight: 900;
    text-transform: uppercase;
    font-style: italic;
    font-size: 0.875em;
    color: var(--color-primary);
  }

  .section-header .sub-orange {
    color: #ea580c;
  }

  .section-header .sub.secondary {
    color: #4f46e5;
  }

  .card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3em;
  }

  @media screen and (width >=768px) {
    .card-grid {
      grid-template-columns: 1fr 1fr;
      gap: 1em;
    }
  }

  .work-card {
    padding: 2em;
    text-align: left;
  }

  .icon-circle {
    width: 5em;
    height: 5em;
    border: 1px solid #dbeafe;
    border-radius: 1.5em;
    box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 2.5em;
    background: #eff6ff;
  }

  .icon-circle img {
    width: 2.5em;
    height: 2.5em;
    color: var(--color-primary);
  }

  .icon-circle.sky {
    background: #f0f9ff;
  }

  .icon-circle.sky img {
    color: var(--color-secondary);
  }

  .sky-purple {
    background-color: #eef2ff;
  }

  .work-card h3 {
    font-size: 1.5em;
    font-weight: 900;
    margin-bottom: 1em;
  }

  .work-card .h3-training {
    margin-bottom: 0;
  }

  .work-card .desc {
    font-weight: bold;
    color: var(--text-sub);
    margin-bottom: 2em;
    font-size: 0.875em;
  }

  .search-btns {
    display: flex;
    gap: 1em;
    flex-wrap: wrap;
    margin-top: 1em;
  }

  .search-btn {
    background: #fff;
    border: 2px solid #e2e8f0;
    padding: 1em 1.5em;
    border-radius: 1.25em;
    font-weight: 900;
    font-size: 0.875em;
    text-decoration: none;
    color: #475569;
    display: flex;
    align-items: center;
    gap: 0.5em;
    transition: 0.3s;
  }

  .search-btn img {
    transition: 0.3s;
    opacity: 1;
  }

  .search-btn:hover {
    box-shadow: 0 4px 20px -5px rgba(0, 0, 0, 0.2);
    border-color: var(--color-secondary);
  }

  /* =========================================
  Movie
  ========================================= */
  .movie-wrapper {
    padding: 0 1em;
  }

  .movie-container {
    margin-top: 5em;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1.5em;
    overflow: hidden;
    position: relative;
    aspect-ratio: 16 / 9.5;
    display: block;
    max-width: var(--container-max);
    padding: 0.5em;
    box-shadow: 0px 5px 19px 2px rgba(0, 0, 0, 0.35);
    border-radius: 1em;
    width: 100%;
  }

  .movie-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    box-shadow: 0px 5px 19px 2px rgba(0, 0, 0, 0.35);
  }

  .movie-chapter-desc {
    padding: 0 1em;
    margin-bottom: 1em;
    color: #94a3b8;
    display: flex;
    justify-content: space-between;
  }

  .movie-chapter__title {
    font-size: 0.65em;
    font-weight: 900;
    letter-spacing: 0.1em;
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
  }

  .movie-chapter__title img {
    width: 16px;
    height: 16px;
  }

  .movie-chapter__remarks {
    color: #cbd5e1;
    font-weight: 700;
    font-size: 0.65em;
  }

  .chapter-swiper {
    padding-left: 1em;
  }

  .chapter-item {
    background-color: #f8fafc;
    border: 1px solid #f8fafc;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 0.75em;
    width: 75%;
    padding: 1em;
    border-radius: 0.75em;
    transition: all 0.3s ease;
  }

  .chapter-item:hover {
    background-color: #FFFFFF;
    border-color: #94a3b8;
    box-shadow: 2px 2px 8px -2px #bdbdbd;
  }

  .chapter-time {
    font-size: 0.6em;
    font-weight: 700;
    font-style: italic;
    color: #94a3b8;
  }

  .chapter-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #475569;
    font-size: 0.7em;
    font-weight: 700;
  }

  @media screen and (width >=1024px) {
    .movie-container {
      margin-top: 0;
    }

    .movie-wrapper {
      display: grid;
      grid-template-columns: repeat(12, minmax(0, 1fr));
      padding: 0 2em;
    }

    .movie-container {
      grid-column: 1 / 8;
    }

    .movie-chapters {
      grid-column: 8 / 13;
    }

    .movie-chapter__title {
      font-size: 0.5em;
    }

    .movie-chapter__remarks {
      display: none;
    }

    .swiper-wrapper {
      display: block;
    }

    .chapter-item {
      width: 98%;
      margin-bottom: 0.4em;
    }
  }


  /* Plyr Overrides */
  .plyr--video .plyr__controls {
    border-radius: 1em;
  }

  .plyr__video-wrapper {
    border: 1px solid var(--text-sub);
    border-radius: 1em;
  }

  .plyr__progress {
    overflow: visible !important;
  }

  .custom-marker {
    display: none;
  }

  @media screen and (width >=768px) {
    .custom-marker {
      display: block;
      width: 4px;
      height: 40%;
      background-color: rgba(255, 255, 255, 0.7);
      z-index: 5;
      cursor: pointer;
      pointer-events: auto;
    }
  }

  .custom-marker:hover::after {
    content: attr(data-label);
    position: absolute;
    bottom: 25px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.8);
    color: #fff;
    padding: 5px 10px;
    border-radius: 4px;
    font-size: 12px;
    white-space: nowrap;
    z-index: 10;
  }

  .custom-marker:hover::before {
    content: '';
    position: absolute;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    border-left: 5px solid transparent;
    border-right: 5px solid transparent;
    border-top: 5px solid rgba(0, 0, 0, 0.8);
  }

  .movie-container .plyr {
    width: 100%;
    height: auto;
  }

  .movie-container video {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain;
  }

  /* =========================================
  Member Voices
  ========================================= */
  .voice-card-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3em;
  }

  @media screen and (width >=768px) {
    .voice-card-grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 1em;
    }
  }

  @media screen and (width >=1024px) {
    .voice-card-grid {
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 1em;
    }
  }

  .voice-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 1.75em;
    position: relative;
    box-shadow: 0 4px 20px -5px rgba(0, 0, 0, 0.05);
  }

  .voice-card.link {
    background: none;
    box-shadow: none;
    border: none;
    justify-content: center;
    align-items: center;
    padding: 0;
    overflow: visible;
  }

  .voice-card.link .voice-card__inner {
    width: 100%;
  }

  @media screen and (width >=768px) {
    .voice-card {
      padding: 1.25em;
    }
  }

  .voice-card .number {
    position: absolute;
    right: 0.8em;
    top: 0.2em;
    font-size: 3em;
    font-style: italic;
    font-weight: 900;
    opacity: 0.8;
    line-height: 1;
    background-clip: text;
    color: transparent;
    padding-right: 0.1em;
  }

  @media screen and (width >=768px) {
    .voice-card .number {
      font-size: 2.5em;
    }
  }

  .number-color-1 {
    background-image: linear-gradient(to right, #60a5fa, #67e8f9);
  }

  .number-color-2 {
    background-image: linear-gradient(to right, #c084fc, #f9a8d4);
  }

  .number-color-3 {
    background-image: linear-gradient(to right, #34d399, #5eead4);
  }

  .number-color-4 {
    background-image: linear-gradient(to right, #fdba74, #fef08a);
  }

  .number-color-5 {
    background-image: linear-gradient(to right, #818cf8, #c4b5fd);
  }

  .voice-card__inner {
    text-align: left;
  }

  .member-name {
    font-size: 12px;
    font-weight: 900;
    color: var(--color-primary);
    font-style: italic;
    margin-bottom: 3em;
    margin-top: 1em;
    letter-spacing: 0.2em;
  }

  .member-voice {
    font-size: 1.25em;
    font-weight: 900;
    line-height: 1.25;
    margin-bottom: 0.5em;
  }

  @media screen and (width >=768px) {
    .member-voice {
      font-size: 1em;
    }
  }

  .member-voice--en {
    font-size: 0.625em;
    font-weight: 700;
    font-style: italic;
    line-height: 1.625;
    margin-bottom: 2em;
    color: #94a3b8;
    letter-spacing: 0.1em;
  }

  .tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75em;
    margin-bottom: 1em;
  }

  .tag-item {
    font-size: 0.625em;
    font-weight: 900;
    color: #94a3b8;
    display: flex;
    align-items: center;
    gap: 0.25em;
  }

  .link-to-voice {
    display: flex;
    justify-content: flex-end;
  }

  .link-to-voice__text {
    color: var(--color-primary);
    font-size: 10px;
    font-weight: 900;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 1em;
  }

  .link-to-voice__text:hover {
    text-decoration: underline;
  }

  .link-to-voice__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    border: 1px solid #e5e7eb;
    width: 3em;
    height: 3em;
    box-shadow: 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 0 #0000, 0 1px 2px 0 rgb(0 0 0 / 0.05);
  }

  .link-to-voice__icon img {
    transition: all 0.1s;
    opacity: 1;
  }

  .link-to-voice__text:hover .link-to-voice__icon img {
    margin-left: 3px;
  }

  .read-all-btn {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 40px;
    background: linear-gradient(to right, #1d4ed8, #38bdf8);
    box-shadow: 0 10px 25px -5px rgba(56, 189, 248, 0.5);
    color: #ffffff;
    font-size: 1.8em;
    font-weight: 900;
    font-style: italic;
    text-decoration: none;
    padding: 0.8em 0;
    line-height: 1;
    transition: all 0.3s ease;
  }

  .read-all-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 15px 30px -5px rgba(56, 189, 248, 0.6);
  }

  .voice-link-title {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }

  .voice-link-subtitle {
    font-size: 0.4em;
    font-weight: 400;
    font-style: normal;
  }

  .voice-link-icon {
    position: absolute;
    top: 50%;
    right: 10%;
    transform: translateY(-50%);
    font-size: 16px;
    width: 24px;
    height: 24px;
    border-radius: 24px;
    background-color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .voice-link-icon img {
    opacity: 1;
  }

  /* =========================================
  Timeline (Schedule)
  ========================================= */
  .timeline-wrapper {
    position: relative;
    max-width: 56em;
    margin: 4em auto 0;
  }

  .timeline-line {
    position: absolute;
    left: 1.5em;
    top: 0;
    bottom: 0;
    width: 4px;
    background: #e2e8f0;
    transform: translateX(-50%);
  }

  @media screen and (width >=768px) {
    .timeline-line {
      left: 50%;
    }
  }

  .timeline-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    margin-bottom: 4em;
    position: relative;
  }

  .timeline-item:nth-child(even) {
    flex-direction: row-reverse;
  }

  @media screen and (width >=768px) {
    .timeline-item:nth-child(even) {
      flex-direction: row;
    }
  }

  .timeline-item.finish .bento-card {
    box-shadow: 0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);
  }

  .timeline-dot {
    width: 3em;
    height: 3em;
    background: #fff;
    border: 4px solid var(--color-primary);
    border-radius: 50%;
    position: absolute;
    left: 1.5em;
    transform: translateX(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .timeline-dot.second-dot {
    border-color: var(--color-secondary);
  }

  .timeline-dot.final-dot {
    border-color: var(--color-accent);
  }

  .timeline-dot::after {
    content: "";
    width: 0.75em;
    height: 0.75em;
    background: var(--color-primary);
    border-radius: 50%;
  }

  @media screen and (width >=768px) {
    .timeline-dot {
      left: 50%;
    }
  }

  .timeline-item .bento-card {
    width: calc(100% - 4em);
    padding: 1.5em 1em;
    margin-left: 4em;
    text-align: left !important;
  }

  @media screen and (width >=768px) {
    .timeline-item .bento-card {
      margin-left: 0;
      width: 42%;
    }

    .timeline-item:nth-child(even) .bento-card {
      text-align: right !important;
    }
  }

  .timeline-item .bento-card h4 {
    font-size: 1.25em;
    margin-bottom: 0.5em;
  }

  @media screen and (width >=768px) {
    .timeline-item .bento-card h4 {
      font-size: 1em;
    }

    .timeline-item .bento-card .timeline-desc {
      font-size: 0.75em;
      font-weight: 700;
    }
  }

  .timeline-label {
    display: none;
  }

  @media screen and (width >=768px) {
    .timeline-label {
      display: block;
      width: 42%;
      font-size: 2.5em;
      font-weight: 900;
      font-style: italic;
      color: #e2e8f0;
    }
  }

  .timeline-item.finish .bento-card {
    background: var(--gradient-main);
    background-color: var(--color-primary);
    color: #fff;
    border: none;
  }

  .timeline-item.finish h4 {
    color: #fff !important;
  }

  /* =========================================
  Stats (Numbers)
  ========================================= */
  .stats-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 2em;
  }

  @media (min-width: 640px) {
    .stats-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media (min-width: 1024px) {
    .stats-grid {
      grid-template-columns: repeat(4, 1fr);
    }
  }

  .stat-card {
    padding: 1em;
    text-align: center;
  }

  .stat-icon {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    border-radius: 1em;
    padding: 1em;
    margin-bottom: 1em;
  }

  .stat-icon-blue {
    background-color: #eff6ff;
  }

  .stat-icon-purple {
    background-color: #eef2ff;
  }

  .stat-icon-green {
    background-color: #f0f9ff;
  }

  .stat-icon-orange {
    background-color: #fff7ed;
  }

  .stat-icon img {
    width: 2em;
    height: 2em;
  }

  .stat-label {
    font-size: 0.75em;
    font-weight: 900;
    color: #94a3b8;
    letter-spacing: 0.1em;
    display: block;
  }

  .stat-value {
    font-size: 3em;
    font-weight: 900;
    font-style: italic;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 0.25em;
  }

  @media screen and (width >=768px) {
    .stat-value {
      font-size: 2em;
    }
  }

  .stat-unit {
    font-size: 1em;
    font-style: normal;
  }

  .stats-remarks {
    margin-top: 4em;
    font-size: 0.625em;
    color: #94a3b8;
    font-weight: 700;
    letter-spacing: 0.1em;
  }

  /* =========================================
  Requirements & Benefits
  ========================================= */
  .req-box {
    max-width: 60em;
    margin: 0 auto;
    text-align: left;
  }

  .req-row {
    display: flex;
    flex-direction: column;
    padding: 2.5em 2em;
    border-bottom: 2px solid #f8faff;
    transition: 0.3s;
    gap: 0.5em;
  }

  .req-row:last-child {
    border-bottom: none;
  }

  @media screen and (width > 768px) {
    .req-row {
      flex-direction: row;
      gap: 4em;
    }
  }

  .req-label {
    font-weight: 900;
    font-size: 0.8125em;
    color: var(--color-primary);
    width: 12em;
    flex-shrink: 0;
    letter-spacing: 0.1em;
    font-style: italic;
    text-transform: uppercase;
  }

  .req-content {
    font-size: 0.875em;
    font-weight: bold;
    line-height: 1.8;
    color: var(--text-main);
  }

  /* =========================================
  Access
  ========================================= */
  .access-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4em;
    align-items: start;
  }

  @media (min-width: 1024px) {
    .access-grid {
      grid-template-columns: 4fr 8fr;
    }
  }

  .access-info {
    text-align: left;
  }

  .access-header {
    margin-bottom: 2.5em;
  }

  .access-info h2 {
    font-size: 3em;
    font-weight: 900;
    font-style: italic;
  }

  .access-details {
    margin-bottom: 2em;
  }

  .access-info h4 {
    font-size: 1.25em;
    font-weight: 900;
    color: var(--text-main) !important;
    margin-bottom: 0.5em;
  }

  .address {
    font-style: normal;
    font-weight: 700;
  }

  .access-stations h4 {
    text-transform: uppercase;
    font-size: 0.875em;
    color: var(--color-primary) !important;
    margin-bottom: 0.5em;
  }

  .station-list {
    list-style: none;
    display: flex;
    flex-direction: column;
  }

  .station-item {
    display: flex;
    gap: 1em;
    font-size: 0.875em;
    font-weight: 700;
  }

  .station-item img {
    width: 2em;
    height: 2em;
    flex-shrink: 0;
  }

  .station-name {
    font-weight: 900;
    font-size: 1em;
  }

  .station-detail {
    font-size: 0.875em;
    color: var(--text-sub);
    font-weight: 500;
  }

  .map-frame {
    height: 450px;
    border-radius: 2em;
    overflow: hidden;
    border: 2px solid var(--card-border);
    box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
    filter: grayscale(0.2) contrast(1.1);
  }

  .map-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5em;
    margin-top: 2em;
    font-size: 0.75em;
    font-weight: 900;
    text-decoration: none;
    border-bottom: 2px solid #000;
    padding-bottom: 4px;
    color: #000;
    letter-spacing: 0.1em;
  }

  /* =========================================
  Contact & Process
  ========================================= */
  .contact-card {
    max-width: 60em;
    margin: 0 auto;
    padding: 2em 3em;
    background: #fff;
    text-align: left;
  }

  .contact-header {
    display: flex;
    align-items: center;
    gap: 1em;
    font-size: 1.5em;
    font-weight: 900;
    margin-bottom: 2em;
    line-height: 1.2;
  }

  .contact-header img {
    color: var(--color-primary);
    width: 1em;
  }

  .contact-card .lead {
    font-size: 1.125em;
    font-weight: 700;
    margin-bottom: 1.5em;
  }

  .contact-card .lead-small {
    font-weight: 700;
  }

  .email-link {
    color: var(--color-primary);
    text-decoration: none;
  }

  .doc-notice {
    background: #f8fafc;
    padding: 1.5em;
    border-radius: 1.5em;
    border: 1px solid #e2e8f0;
    margin: 2em 0 3em;
  }

  .doc-notice .title {
    font-size: 0.75em;
    font-weight: 900;
    color: #94a3b8;
    margin-bottom: 0.5em;
  }

  .doc-notice .text {
    font-size: 0.875em;
    font-weight: bold;
    font-style: italic;
    color: var(--text-main);
  }

  .recruiting-team {
    display: flex;
    flex-wrap: wrap;
    gap: 2em;
    justify-content: space-between;
    align-items: flex-end;
    border-top: 1px solid #f1f5f9;
    padding-top: 2.5em;
  }

  .recruiting-team .sub-title {
    font-size: 0.75em;
    font-weight: 900;
    font-style: italic;
    color: #94a3b8;
    text-transform: uppercase;
    margin-bottom: 0.5em;
  }

  .recruiting-team .department {
    font-size: 1.25em;
    font-weight: 900;
  }

  .recruiting-team .person {
    font-size: 1.125em;
    font-weight: 700;
  }

  .call-card {
    background: #f8fafc;
    padding: 1.5em 2.5em;
    border-radius: 2em;
    border: 2px solid rgba(30, 58, 138, 0.05);
  }

  .call-title {
    font-size: 0.75em;
    font-weight: 900;
    color: var(--color-primary);
    font-style: italic;
    margin-bottom: 0.25em;
    text-transform: uppercase;
    letter-spacing: 1.2px;
  }

  .call-number-pc {
    display: none;
  }

  @media screen and (width >=769px) {
    .call-number-pc {
      display: inline;
      font-size: 1.5em;
      font-weight: 900;
      line-height: 1;
      color: var(--color-primary);
    }

    .call-number-sp {
      display: none;
    }
  }

  .call-number-sp {
    font-size: 1.5em;
    font-weight: 900;
    line-height: 1;
    color: var(--color-primary);
    text-decoration: none;
  }

  .call-type {
    font-size: 0.875em;
    color: #94a3b8;
  }

  .process-grid {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 1.5em;
    max-width: 72em;
    margin: 0 auto;
  }

  @media screen and (width > 1024px) {
    .process-grid {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  .step-card {
    padding: 1.5em 2em;
    text-align: left;
  }

  .step-num {
    font-size: 0.8125em;
    font-weight: 900;
    color: var(--color-primary);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    border-bottom: 2px solid #e5e7eb;
    display: inline-block;
    margin-bottom: 1em;
  }

  .step-card h4 {
    font-size: 1.25em;
    color: var(--text-main) !important;
    font-weight: 900;
    margin-bottom: 0.5em;
  }

  .step-card p {
    font-weight: 700;
  }

  .step-card.final {
    background: var(--gradient-main);
    background-color: var(--color-primary);
    color: #fff;
    border: none;
    box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.25);
  }

  .step-card.final h4 {
    color: #fff !important;
  }

  .step-card.final .step-num {
    color: #fff;
    border-bottom-color: rgba(255, 255, 255, 0.4);
  }

  /* =========================================
  CTA
  ========================================= */
  .cta-section {
    background-color: #f8fafc;
  }

  .cta-section .container {
    padding: 0 1em;
  }

  .cta-title {
    font-size: 3em;
    font-weight: 900;
    letter-spacing: -2.4px;
    line-height: 1.2;
    margin-bottom: 1.5em;
  }

  .cta-btns {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2em;
    margin-left: auto;
    margin-right: auto;
  }

  @media screen and (width >=768px) {
    .cta-btns {
      flex-direction: row;
      max-width: 42em;
    }
  }

  .cta-btns .btn-main {
    width: 100%;
    max-width: 24em;
    text-decoration: none;
    color: #FFFFFF;
    padding: 1.5em 2em;
  }

  .cta-btns .btn-secondary {
    text-decoration: none;
    color: var(--text-main);
  }

  /* =========================================
  Utilities & Animations
  ========================================= */
  .animate-soft-bounce {
    animation: soft-bounce 4s infinite ease-in-out;
  }
}

@keyframes soft-bounce {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-8px);
  }
}

/* =========================================
  応募フォーム
========================================= */
.new-entry-form {
  /* Base Variables */
  --c-slate-50: #f8fafc;
  --c-slate-100: #f1f5f9;
  --c-slate-200: #e2e8f0;
  --c-slate-300: #cbd5e1;
  --c-slate-400: #94a3b8;
  --c-slate-500: #64748b;
  --c-slate-600: #475569;
  --c-slate-700: #334155;
  --c-slate-800: #1e293b;
  --c-slate-900: #0f172a;

  --c-blue-100: #dbeafe;
  --c-blue-200: #bfdbfe;
  --c-blue-600: #2563eb;
  --c-blue-700: #1d4ed8;

  --c-red-50: #fef2f2;
  --c-red-400: #f87171;
  --c-red-500: #ef4444;

  --c-green-100: #dcfce7;
  --c-green-600: #16a34a;

  --c-white: #ffffff;

  --font-sans: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  --shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);

  font-family: var(--font-sans);
  background-color: var(--c-slate-50);
  color: var(--c-slate-900);
  line-height: 1.5;
  min-height: 100vh;
  padding: 3em 1em;
  font-size: 16px;
  margin: 0;
}

/* 特定ページでの親テーマ上書き */
.page-id-20154 #footerSection #pagetop {
  background-color: #f8fafc;
}

.new-entry-form * {
  box-sizing: border-box;
  font-family: var(--font-sans);
  margin: 0;
  padding: 0;
}

.new-entry-form {

  /* Utility Helpers */
  .u-hidden {
    display: none !important;
  }

  .u-mt-1-5 {
    margin-top: 1.5em !important;
  }

  /* Animations */
  @keyframes fadeIn {
    from {
      opacity: 0;
      transform: scale(0.95);
    }

    to {
      opacity: 1;
      transform: scale(1);
    }
  }

  @keyframes spin {
    to {
      transform: rotate(360deg);
    }
  }

  .u-fade-in {
    animation: fadeIn 0.3s ease-out forwards;
  }

  /* =========================================
     Layout Components
  ========================================= */
  .wrapper {
    max-width: 48em;
    margin: 0 auto;
  }

  /* Header */
  .header {
    text-align: center;
    margin-bottom: 2.5em;
  }

  .header-title {
    font-size: 1.875em;
    font-weight: 800;
    color: var(--c-slate-900);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 0.27em;
  }

  @media (min-width: 640px) {
    .header-title {
      font-size: 2.25em;
    }
  }

  .header-subtitle {
    font-size: 1.125em;
    color: var(--c-slate-600);
    font-weight: 700;
  }

  /* Form Container */
  .form-card {
    background-color: var(--c-white);
    border-radius: 1em;
    overflow: hidden;
    box-shadow: 0 0 0 1px var(--c-slate-200), var(--shadow-sm);
  }

  .form-content {
    padding: 1.5em;
  }

  @media (min-width: 640px) {
    .form-content {
      padding: 2.5em;
    }
  }

  /* Form Sections */
  .form-section {
    margin-bottom: 2.5em;
  }

  .form-section:last-child {
    margin-bottom: 0;
  }

  /* Section Headings */
  .section-heading {
    display: flex;
    align-items: center;
    gap: 0.75em;
    padding-bottom: 0.5em;
    border-bottom: 1px solid var(--c-slate-100);
    margin-bottom: 1.5em;
  }

  .section-icon {
    color: var(--c-blue-600);
    width: 1.15em;
    height: 1.15em;
  }

  .section-title {
    font-size: 1.125em;
    font-weight: 700;
    color: var(--c-slate-800);
    background: none !important;
    -webkit-text-fill-color: initial;
    margin-top: 0;
    padding: 0;
  }

  .section-title:before,
  .section-title:after {
    display: none;
  }

  .section-subtitle {
    font-size: 0.777em;
    color: var(--c-slate-400);
    font-weight: 400;
    margin-left: 0.25em;
  }

  /* Grid Layouts (shared with #work-fields via ID override logic below) */
  .grid-row,
  #work-fields {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5em;
  }

  @media (min-width: 768px) {

    .grid-row,
    #work-fields {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  .grid-status {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1em;
  }

  @media (min-width: 640px) {
    .grid-status {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  /* Form Groups */
  .form-group {
    margin-bottom: 0;
  }

  .input-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.5em;
  }

  .label-text {
    font-size: 0.75em;
    font-weight: 700;
    color: var(--c-slate-700);
    display: block;
  }

  /* Badges */
  .badge-required,
  .badge-optional {
    display: inline-flex;
    align-items: center;
    padding: 0.2em 0.8em;
    border-radius: 0.25em;
    font-size: 0.625em;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
  }

  .badge-required {
    background-color: var(--c-red-500);
    color: var(--c-white);
  }

  .badge-optional {
    background-color: var(--c-slate-200);
    color: var(--c-slate-500);
  }

  /* Input Fields (Combined) */
  .input-wrapper {
    position: relative;
  }

  .input-icon {
    position: absolute;
    left: 0.75em;
    top: 50%;
    transform: translateY(-50%);
    color: var(--c-slate-400);
    pointer-events: none;
    width: 1.25em;
    height: 1.25em;
    z-index: 1;
  }

  .text-input,
  .textarea-input {
    width: 100%;
    padding: 0.71em 1.14em;
    border-radius: 0.5em;
    border: 1px solid var(--c-slate-300);
    font-size: 0.875em;
    transition: all 0.2s;
    outline: none;
    color: var(--c-slate-900);
    background-color: var(--c-white);
  }

  .text-input::placeholder,
  .textarea-input::placeholder {
    color: var(--c-slate-400);
  }

  .text-input.has-icon {
    padding-left: 2.85em;
  }

  .textarea-input {
    resize: none;
  }

  /* Focus States */
  .text-input:focus,
  .textarea-input:focus {
    border-color: var(--c-blue-600);
    box-shadow: 0 0 0 4px var(--c-blue-100);
  }

  /* Error States */
  .input-error-state {
    border-color: var(--c-red-400) !important;
    background-color: var(--c-red-50) !important;
  }

  .error-text {
    margin-top: 0.4em;
    font-size: 0.625em;
    color: var(--c-red-500);
    display: flex;
    align-items: center;
    gap: 0.4em;
  }

  .error-text[hidden] {
    display: none;
  }

  .error-icon {
    width: 1.2em;
    height: 1.2em;
  }

  .wpcf7-not-valid-tip {
    display: none;
  }

  /* Status Radio Buttons */
  .status-option {
    position: relative;
  }

  .status-input {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
  }

  .status-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 1em;
    border: 2px solid var(--c-slate-100);
    border-radius: 0.75em;
    cursor: pointer;
    transition: all 0.2s;
    background-color: var(--c-white);
  }

  .status-card:hover {
    background-color: var(--c-slate-50);
  }

  .status-icon {
    color: var(--c-slate-400);
    margin-bottom: 0.5em;
  }

  .status-label-text {
    font-size: 0.8125em;
    font-weight: 700;
    color: var(--c-slate-600);
  }

  /* Status Active State */
  .status-card.is-active {
    border-color: var(--c-blue-600);
    background-color: #eff6ff;
    box-shadow: 0 0 0 1px var(--c-blue-600);
  }

  .status-card.is-active .status-icon {
    color: var(--c-blue-600);
  }

  .status-card.is-active .status-label-text {
    color: var(--c-blue-700);
  }

  /* Privacy Policy */
  .policy-box {
    padding: 1.5em;
    margin-bottom: 3em;
    border-radius: 0.75em;
    border: 2px solid var(--c-slate-50);
    background-color: var(--c-slate-50);
  }

  .policy-content {
    display: flex;
    align-items: flex-start;
    gap: 1em;
  }

  .wpcf7-list-item label {
    display: flex;
    align-items: center;
    gap: 0.5em;
  }

  .checkbox-input {
    width: 1.3em;
    height: 1.3em;
    color: var(--c-blue-600);
    border: 1px solid var(--c-slate-300);
    border-radius: 0.25em;
    cursor: pointer;
  }

  .wpcf7-list-item-label {
    font-size: 0.75em;
    font-weight: 900;
    color: #334155;
  }

  .policy-text-area {
    flex: 1;
    font-size: 0.75em;
  }

  .policy-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 1.33em;
  }

  .policy-label-text {
    font-weight: 700;
    color: var(--c-slate-700);
    cursor: pointer;
  }

  .policy-link {
    color: var(--c-blue-600);
    text-decoration: none;
  }

  .policy-link:hover {
    text-decoration: underline;
  }

  .policy-description {
    font-size: 0.83em;
    color: var(--c-slate-400);
    line-height: 1.625;
    background-color: rgba(255, 255, 255, 0.5);
    padding: 0.5em;
    border-radius: 0.25em;
    border: 1px solid var(--c-slate-100);
  }

  /* Buttons (Submit & Back) Combined Styles */
  .btn-submit,
  .btn-back {
    width: 100%;
    border-radius: 0.75em;
    border: none;
    transition: all 0.2s;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 1em;
    color: var(--c-white);
    background-color: var(--c-blue-600) !important;
    background-image: none !important;
  }

  .btn-submit:hover,
  .btn-back:hover {
    background-color: var(--c-blue-700);
  }

  .btn-submit {
    padding: 1em 1.5em;
    font-weight: 700;
    box-shadow: 0 10px 15px -3px rgba(191, 219, 254, 0.5);
  }

  .btn-back {
    padding: 0.75em;
    font-weight: 600;
    text-decoration: none;
  }

  .btn-submit:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }

  /* Button Content */
  .btn-content {
    display: flex;
    align-items: center;
    gap: 0.5em;
  }

  /* Loading State & Spinner */
  .btn-submit.is-loading {
    opacity: 0.7;
    pointer-events: none;
    cursor: wait;
  }

  .spinner {
    display: inline-block;
    width: 1em;
    height: 1em;
    margin-right: 0.5em;
    border: 2px solid rgba(255, 255, 255, 0.3);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 1s linear infinite;
    vertical-align: middle;
  }

  /* quiz */
  .security-check-section {
    margin: 30px 0;
    padding: 20px;
    background-color: var(--c-slate-50);
    border-radius: 8px;
  }

  .security-check-section .form-label {
    font-weight: bold;
    font-size: 0.85em;
    color: #333;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
  }

  .security-check-section .badge-required {
    background-color: #ff4d4f;
    color: #fff;
    font-size: 0.75em;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 8px;
  }

  .security-check-section .description {
    font-size: 0.75em;
    color: #666;
    margin-bottom: 15px;
  }

  .security-check-section input[type="text"] {
    width: 3em;
    padding: 0.71em 1.14em;
    border-radius: 0.5em;
    border: 1px solid var(--c-slate-300);
    font-size: 0.875em;
    transition: all 0.2s;
    outline: none;
    color: var(--c-slate-900);
    background-color: var(--c-white);
  }

  .security-check-section input[type="text"]:focus {
    border-color: #8da8f0;
    outline: none;
    box-shadow: 0 0 0 3px rgba(141, 168, 240, 0.2);
  }

  #quiz-error {
    justify-content: center;
  }

  /* Success Message */
  .success-box {
    max-width: 28em;
    width: 100%;
    background-color: var(--c-white);
    border-radius: 1em;
    box-shadow: var(--shadow-lg);
    padding: 2em;
    text-align: center;
    margin: 0 auto;
    border: 1px solid var(--c-slate-100);
    animation: fadeIn 0.3s ease-out forwards;
  }

  .success-icon-wrap {
    width: 5em;
    height: 5em;
    background-color: var(--c-green-100);
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 1.5em auto;
  }

  .success-icon {
    width: 3em;
    height: 3em;
    color: var(--c-green-600);
  }

  .success-title {
    font-size: 1.5em;
    font-weight: 700;
    color: var(--c-slate-800);
    margin-bottom: 0.5em;
  }

  .success-text {
    color: var(--c-slate-600);
    margin-bottom: 2em;
    line-height: 1.625;
    font-size: 0.875em;
    text-align: left;
    padding: 0 1em;
  }

  /* =========================================
  ID Specific Overrides
  ========================================= */
  #additional-fields {
    margin-top: 1.5em;
  }

  #work-fields {
    /* Grid layout properties merged with .grid-row above */
    margin-top: 1.5em;
  }

  #policy-error {
    margin-top: 0.5em;
  }
}

/* =========================================
  先輩のこえページ
========================================= */
/* CSS Variables */
.new-voices {
  --font-inter: 'Inter', sans-serif;
  --font-noto: 'Noto Sans JP', sans-serif;
  --font-outfit: 'Outfit', sans-serif;
  --c-slate-50: #f8fafc;
  --c-slate-100: #f1f5f9;
  --c-slate-200: #e2e8f0;
  --c-slate-400: #94a3b8;
  --c-slate-500: #64748b;
  --c-slate-600: #475569;
  --c-slate-700: #334155;
  --c-slate-800: #1e293b;
  --c-slate-900: #0f172a;
  --c-white: #ffffff;
}

/* Base Styles */
.new-voices {
  font-family: var(--font-inter), var(--font-noto);
  background-color: var(--c-white);
  color: var(--c-slate-800);
  margin: 0;
  padding: 0;
  -webkit-font-smoothing: antialiased;

  h1,
  h2,
  h3 {
    font-family: var(--font-noto);
  }

  .text-gradient {
    color: transparent;
    background-clip: text;
    -webkit-background-clip: text;
    background-image: linear-gradient(to right, #2563eb, #4338ca, #5b21b6);
  }

  /* Hero Section */
  .hero-section {
    position: relative;
    padding-top: 8em;
    padding-bottom: 8em;
    padding-left: 1.5em;
    padding-right: 1.5em;
    overflow: hidden;
  }

  .hero-bg-1 {
    position: absolute;
    top: 5em;
    right: -10%;
    background-color: rgba(129, 140, 248, 0.1);
    width: 24em;
    height: 24em;
    filter: blur(120px);
    border-radius: 9999px;
    animation: pulse-soft 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  }

  .hero-bg-2 {
    position: absolute;
    bottom: 0;
    left: -5%;
    background-color: rgba(129, 140, 248, 0.1);
    width: 31.25em;
    height: 31.25em;
    filter: blur(150px);
    border-radius: 9999px;
  }

  @keyframes pulse-soft {

    0%,
    100% {
      opacity: 1;
    }

    50% {
      opacity: 0.5;
    }
  }

  .hero-content {
    max-width: 82em;
    margin: 0 auto;
    position: relative;
    z-index: 10;
    text-align: center;
  }

  .hero-subtitle-wrap {
    display: flex;
    flex-direction: column;
    gap: 2em;
    border-left: 4px solid rgba(96, 165, 250, 0.2);
    padding-left: 1.5em;
    padding-top: 0.5em;
    padding-bottom: 0.5em;
    margin-bottom: 3em;
    text-align: left;
  }

  .hero-subtitle {
    max-width: 48em;
    font-size: 1.285em;
    color: var(--c-slate-500);
    font-weight: 500;
    line-height: 1.625;
    margin: 0;
    text-align: center;
  }

  .hero-title {
    font-family: var(--font-outfit);
    font-size: 2.5em;
    font-weight: 900;
    line-height: 1.2;
    letter-spacing: -0.05em;
    color: var(--c-slate-900);
    margin: 0;
    text-align: center;
  }

  /* Interviews Main */
  .main-content {
    overflow: hidden;
  }

  .interview-wrapper {
    background-color: rgba(241, 245, 249, 0.6);
    padding-top: 5em;
    padding-bottom: 5em;
  }

  .interview-wrapper-alt {
    background-color: var(--c-white);
    border-top: 1px solid var(--c-slate-200);
    border-bottom: 1px solid var(--c-slate-200);
  }

  .interview-wrapper:last-child {
    border-bottom: none;
  }

  .interview-section {
    position: relative;
    max-width: 73em;
    margin: 0 auto;
    padding-left: 1.5em;
    padding-right: 1.5em;
    box-sizing: border-box;
    scroll-margin-top: 6.25em;
    text-align: left;
  }

  /* Badges */
  .badge-wrap {
    display: inline-flex;
    align-items: center;
    gap: 0.75em;
    margin-bottom: 2em;
    background-color: var(--c-white);
    padding: 0.5em 1.25em;
    border-radius: 9999px;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    border: 1px solid var(--c-slate-100);
  }

  .badge-dot {
    width: 0.5em;
    height: 0.5em;
    border-radius: 9999px;
    animation: pulse-dot 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
  }

  @keyframes pulse-dot {

    0%,
    100% {
      opacity: 1;
    }

    50% {
      opacity: 0.5;
    }
  }

  .dot-01 {
    background-color: #c084fc;
  }

  .dot-02 {
    background-color: #60a5fa;
  }

  .dot-03 {
    background-color: #34d399;
  }

  .dot-04 {
    background-color: #fdba74;
  }

  .dot-05 {
    background-color: #818cf8;
  }

  .badge-text {
    font-size: 0.85em;
    font-weight: 900;
    color: var(--c-slate-700);
    letter-spacing: 0.2em;
    text-transform: uppercase;
    font-family: var(--font-outfit);
  }

  /* Banners */
  .banner-wrap {
    border-radius: 2em;
    padding: 1.5em;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
    margin-bottom: 2em;
  }

  .banner-01 {
    background-image: linear-gradient(to right, #c084fc, #f9a8d4);
  }

  .banner-02 {
    background-image: linear-gradient(to right, #60a5fa, #67e8f9);
  }

  .banner-03 {
    background-image: linear-gradient(to right, #34d399, #5eead4);
  }

  .banner-04 {
    background-image: linear-gradient(to right, #fdba74, #fef08a);
  }

  .banner-05 {
    background-image: linear-gradient(to right, #818cf8, #a78bfa);
  }

  .banner-title {
    color: var(--c-white);
    font-size: 1.42em;
    font-weight: 900;
    letter-spacing: -0.05em;
    line-height: 1.25;
    margin: 0 0 0.625em 0;
    text-align: left;
  }

  .tags-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }

  .tag-item {
    background-color: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: var(--c-white);
    font-size: 0.52em;
    font-weight: 700;
    padding: 0.75em 1.5em;
    border-radius: 9999px;
    text-transform: uppercase;
    letter-spacing: 0.1em;
  }

  /* Cards */
  .cards-grid {
    display: grid;
    gap: 1em;
    grid-template-columns: 1fr;
  }

  .card-item {
    background-color: var(--c-white);
    padding: 1.5em;
    border-radius: 1.8em;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    border: 1px solid var(--c-slate-50);
    color: var(--c-slate-800);
    text-align: left;
    box-sizing: border-box;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  }

  .card-title {
    font-family: var(--font-outfit);
    font-weight: 900;
    font-size: 0.85em;
    letter-spacing: -0.025em;
    margin-top: 0;
    margin-bottom: 1em;
    line-height: 1.25;
  }

  .card-subtitle {
    display: block;
    font-weight: 700;
    color: var(--c-slate-400);
    margin-top: 0.25em;
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }

  .card-text {
    font-weight: 500;
    font-size: 1.071em;
    line-height: 1.625;
    letter-spacing: 0.025em;
    color: var(--c-slate-600);
    margin: 0;
  }

  /* Message Cards */
  .card-message {
    padding: 1.7em;
    border-radius: 1.8em;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    color: var(--c-white);
    text-align: left;
    box-sizing: border-box;
    box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  }

  .msg-01 {
    background-image: linear-gradient(to bottom right, #c084fc, #f9a8d4);
  }

  .msg-02 {
    background-image: linear-gradient(to bottom right, #60a5fa, #67e8f9);
  }

  .msg-03 {
    background-image: linear-gradient(to bottom right, #34d399, #5eead4);
  }

  .msg-04 {
    background-image: linear-gradient(to bottom right, #fdba74, #fef08a);
  }

  .msg-05 {
    background-image: linear-gradient(to bottom right, #818cf8, #a78bfa);
  }

  .card-title-white {
    color: var(--c-white);
  }

  .msg-subtitle {
    display: block;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.7);
    margin-top: 0.25em;
    font-size: 9px;
    letter-spacing: 0.1em;
    text-transform: uppercase;
  }

  .msg-text {
    font-weight: 500;
    font-size: 1.071em;
    line-height: 1.625;
    letter-spacing: 0.025em;
    font-style: italic;
    margin: 0;
  }

  /* Media Queries */
  @media (min-width: 768px) {
    .hero-subtitle-wrap {
      flex-direction: row;
      align-items: flex-end;
      justify-content: space-between;
    }

    .hero-subtitle {
      font-size: 1.25em;
      text-align: left;
    }

    .hero-title {
      font-size: 5em;
      text-align: left;
    }

    .interview-wrapper {
      padding-top: 8em;
      padding-bottom: 8em;
    }

    .badge-text {
      font-size: 0.875em;
    }

    .banner-wrap {
      padding: 2em 3em;
    }

    .banner-title {
      font-size: 2.5em;
    }

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

    .card-title {
      font-size: 1em;
    }
  }

  @media (min-width: 1024px) {
    .cards-grid {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
}