@charset "UTF-8";
:root {
  /* ========================================
     Primary Colors
     ======================================== */
  --color-primary-blue: #165EA3;
  --color-light-blue: #4a9fff;
  --color-dark-blue: #003d7a;
  /* ========================================
     Neutral Colors
     ======================================== */
  --color-white: #ffffff;
  --color-light-gray: #f5f5f5;
  --color-gray: #cccccc;
  --color-dark-gray: #666666;
  --color-black: #333333;
  /* ========================================
     Accent Colors
     ======================================== */
  --color-accent-blue: #00a0e9;
  /* ========================================
     Font Family - Google Fonts
     ======================================== */
  --font-family-base: 'Noto Sans JP', sans-serif;
  --font-family-serif: 'Noto Serif JP', serif;
  --font-family-en: 'Barlow Condensed', sans-serif;
  /* ========================================
     Font Sizes
     ======================================== */
  --font-size-h1: 48px;
  --font-size-h2: 36px;
  --font-size-h3: 24px;
  --font-size-body: 16px;
  --font-size-small: 14px;
  /* ========================================
     Line Heights
     ======================================== */
  --line-height-heading: 1.4;
  --line-height-body: 1.8;
  /* ========================================
     Font Weights
     ======================================== */
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-bold: 700;
  /* ========================================
     Spacing
     ======================================== */
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 24px;
  --spacing-lg: 40px;
  --spacing-xl: 64px;
  --spacing-xxl: 96px;
  /* ========================================
     Breakpoints
     ======================================== */
  --breakpoint-mobile: 768px;
  --breakpoint-tablet: 1024px;
  --breakpoint-desktop: 1440px;
  /* ========================================
     Layout
     ======================================== */
  --max-width-container: 1200px;
  --header-height: 80px;
  /* ========================================
     Shadows
     ======================================== */
  --shadow-default: 0 4px 12px rgba(0, 0, 0, 0.1);
  --shadow-hover: 0 8px 24px rgba(0, 0, 0, 0.15);
  /* ========================================
     Transitions
     ======================================== */
  --transition-fast: 0.2s ease;
  --transition-base: 0.3s ease;
  --transition-slow: 0.5s ease;
  /* ========================================
     Border Radius
     ======================================== */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 16px;
  --radius-circle: 50%;
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: none;
}

body {
  font-family: var(--font-family-base);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-regular);
  line-height: var(--line-height-body);
  color: var(--color-black);
  overflow-x: hidden;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transition-base);
}
a:hover {
  color: var(--color-primary-blue);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

ul,
ol {
  list-style: none;
}

button {
  font-family: inherit;
  font-size: inherit;
  border: none;
  background: none;
  cursor: pointer;
  padding: 0;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-heading);
}

h1 {
  font-size: var(--font-size-h1);
}

h2 {
  font-size: var(--font-size-h2);
}

h3 {
  font-size: var(--font-size-h3);
}

.main {
  position: relative;
}

.main section {
  position: relative;
  z-index: 1;
}

.page-container {
  position: relative;
  padding-bottom: 400px;
}
@media screen and (max-width: 640px) {
  .page-container {
    padding-bottom: 20vw;
  }
}
.page-container::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 38vw;
  background-image: url("../images/common/ribon-footer.png");
  background-size: 100% auto;
  background-position: center top;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 0;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height);
  background-color: var(--color-white);
  z-index: 1000;
  transition: transform var(--transition-base);
}
.header.hidden {
  transform: translateY(-100%);
}
.header__container {
  padding: 0 var(--spacing-md);
  height: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 767px) {
  .header__container {
    padding: 0 var(--spacing-sm);
  }
}
.header__logo {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  height: 42px;
}
.header__logo img {
  height: 100%;
  width: auto;
}
.header__logo .header__side-logo-text {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-primary-blue);
  line-height: 1.2;
  margin: 0;
}
@media (max-width: 767px) {
  .header__logo {
    height: auto;
    width: 60vw;
  }
  .header__logo img {
    width: 100%;
    height: auto;
  }
}
.header__nav {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  position: fixed;
  top: 0;
  right: 0;
  width: 90%;
  max-width: 360px;
  height: 100vh;
  height: 100dvh;
  background-color: var(--color-white);
  padding: var(--header-height) var(--spacing-lg) var(--spacing-xl);
  transform: translateX(100%);
  transition: transform 0.3s ease-out;
  z-index: 1001;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.header__nav.open {
  transform: translateX(0);
}
.header__nav-close {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: var(--spacing-md);
  right: var(--spacing-md);
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1;
}
.header__nav-close span {
  position: absolute;
  width: 24px;
  height: 2px;
  background-color: var(--color-black);
  border-radius: 1px;
}
.header__nav-close span:first-child {
  transform: rotate(45deg);
}
.header__nav-close span:last-child {
  transform: rotate(-45deg);
}
.header__nav-footer {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  margin-top: auto;
  padding-top: 1.5em;
}
.header__nav-footer-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--color-gray-dark, #666);
  font-size: min(14px, 3vw);
  text-decoration: none;
  padding: 0.5em 0;
  transition: color var(--transition-base);
}
.header__nav-footer-link::after {
  content: "→";
  font-size: 12px;
}
.header__nav-footer-link:hover {
  color: var(--color-primary-blue);
}
.header__overlay {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  height: 100dvh;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease-out, visibility 0.3s ease-out;
  z-index: 999;
}
.header__overlay.open {
  opacity: 1;
  visibility: visible;
}
.header .header__nav--career {
  display: flex;
  align-items: center;
  gap: var(--spacing-lg);
}
.header__nav-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  list-style: none;
}
.header__nav-item {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  border-bottom: 1px solid var(--color-gray-light, #e0e0e0);
}
.header__nav-item:first-child {
  border-top: 1px solid var(--color-gray-light, #e0e0e0);
}
.header__nav-link {
  display: block;
  color: var(--color-black);
  text-decoration: none;
  transition: color var(--transition-base), background-color var(--transition-base);
  position: relative;
  padding: 1em 1em;
  font-size: 15px;
  font-weight: 500;
}
.header__nav-link:hover, .header__nav-link.active {
  color: var(--color-primary-blue);
  background-color: rgba(0, 0, 0, 0.03);
}
@media (max-width: 767px) {
  .header__nav-link {
    font-size: min(15px, 3vw);
  }
}
.header__jr-logo {
  height: 40px;
  margin-left: var(--spacing-md);
}
.header__jr-logo img {
  height: 100%;
  width: auto;
}
@media (max-width: 767px) {
  .header__jr-logo {
    margin-left: 0;
    margin-top: var(--spacing-lg);
  }
}
.header__banners {
  display: flex;
  align-items: center;
  gap: var(--spacing-md);
  margin-left: auto;
  margin-right: var(--spacing-lg);
}
@media (max-width: 767px) {
  .header__banners {
    display: none;
  }
}
.header__banner-link {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 6px 12px;
  border: 1px solid var(--color-gray-light, #27a9ff);
  transition: opacity var(--transition-base), box-shadow var(--transition-base);
}
.header__banner-link:hover {
  opacity: 0.8;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.header__banner-link img {
  height: 100%;
  width: auto;
  max-width: 140px;
  object-fit: contain;
}
.header__hamburger {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 28px;
  height: 20px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1001;
}
.header__hamburger span {
  display: block;
  width: 100%;
  height: 3px;
  background-color: var(--color-black);
  border-radius: 2px;
  transition: all var(--transition-base);
}
.header__hamburger.open span:nth-child(1) {
  transform: translateY(10.5px) rotate(45deg);
}
.header__hamburger.open span:nth-child(2) {
  opacity: 0;
}
.header__hamburger.open span:nth-child(3) {
  transform: translateY(-10.5px) rotate(-45deg);
}

body.menu-open {
  overflow: hidden;
}

.header--career .header__hamburger--mobile-only {
  display: none;
}
@media (max-width: 767px) {
  .header--career .header__hamburger--mobile-only {
    display: flex;
  }
}

.header__nav-inline {
  display: flex;
  align-items: center;
}
@media (max-width: 767px) {
  .header__nav-inline {
    display: none;
  }
}

.header__nav-inline--career .header__nav-inline-list {
  display: flex;
  align-items: center;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
}
.header__nav-inline--career .header__nav-inline-item {
  position: relative;
}
.header__nav-inline--career .header__nav-inline-item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 40px;
  background-color: #f5ff00;
}
.header__nav-inline--career .header__nav-inline-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: var(--spacing-xs) var(--spacing-lg);
  text-decoration: none;
  transition: opacity var(--transition-base);
}
.header__nav-inline--career .header__nav-inline-link:hover {
  opacity: 0.7;
}
.header__nav-inline--career .header__nav-inline-link-en {
  font-family: "Barlow Condensed", sans-serif;
  font-style: italic;
  font-size: 25px;
  font-weight: 500;
  color: #4bb3cc;
  letter-spacing: 0.05em;
  line-height: 1.2;
}
.header__nav-inline--career .header__nav-inline-link-ja {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-black);
  line-height: 1.4;
  margin-top: 2px;
}

.header__nav-footer-link--active {
  color: var(--color-primary-blue);
  font-weight: 700;
}

.footer {
  color: #333;
  padding: 60px 0 40px;
}
.footer__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
  padding: 0 var(--spacing-md);
}
@media (max-width: 767px) {
  .footer__container {
    padding: 0 var(--spacing-sm);
  }
}
.footer__main {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--spacing-xl);
  position: relative;
}
.footer__main::before, .footer__main::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  background: #f5ff00;
}
.footer__main::before {
  left: 50%;
}
.footer__main::after {
  left: 80%;
}
@media (max-width: 1023px) {
  .footer__main {
    flex-wrap: wrap;
  }
  .footer__main::before, .footer__main::after {
    display: none;
  }
}
@media (max-width: 767px) {
  .footer__main {
    flex-direction: column;
    gap: var(--spacing-lg);
  }
}
.footer__logo {
  flex-shrink: 0;
}
@media screen and (max-width: 640px) {
  .footer__logo {
    margin: 0 auto;
  }
}
.footer__logo a {
  display: block;
}
.footer__logo img {
  max-width: 200px;
  height: auto;
}
.footer__logo-text {
  display: block;
  font-size: 20px;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  font-style: italic;
  margin-top: var(--spacing-xs);
  letter-spacing: 0.05em;
}
@media screen and (max-width: 640px) {
  .footer__section {
    display: none;
  }
}
.footer__section-title-link {
  font-size: 16px;
  color: #333;
  text-decoration: none;
  transition: color var(--transition-base);
}
.footer__section-title-link:hover {
  color: var(--color-primary);
}
.footer__section-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.footer__section-link {
  color: #333;
  text-decoration: none;
  font-size: 14px;
  transition: color var(--transition-base);
}
.footer__section-link:hover {
  color: var(--color-primary);
}
.footer__section--right {
  text-align: left;
}
.footer__section--right .footer__section-list {
  align-items: flex-start;
}
@media (max-width: 767px) {
  .footer__section--right {
    text-align: left;
  }
  .footer__section--right .footer__section-list {
    align-items: flex-start;
  }
}
.footer__bottom {
  margin-top: var(--spacing-xl);
  text-align: right;
}
@media (max-width: 767px) {
  .footer__bottom {
    text-align: center;
  }
}
.footer__copyright {
  font-size: 12px;
  color: #666;
}

.btn {
  display: inline-block;
  padding: var(--spacing-sm) var(--spacing-lg);
  font-family: var(--font-family-base);
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-medium);
  text-align: center;
  border-radius: var(--radius-md);
  transition: all var(--transition-base);
  cursor: pointer;
  border: none;
  text-decoration: none;
}
.btn:focus-visible {
  outline: 2px solid var(--color-primary-blue);
  outline-offset: 2px;
}
.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn--primary {
  background-color: var(--color-primary-blue);
  color: var(--color-white);
}
.btn--primary:hover:not(:disabled) {
  background-color: var(--color-dark-blue);
  transform: translateY(-2px);
  box-shadow: var(--shadow-default);
}
.btn--secondary {
  background-color: transparent;
  color: var(--color-primary-blue);
  border: 2px solid var(--color-primary-blue);
}
.btn--secondary:hover:not(:disabled) {
  background-color: var(--color-primary-blue);
  color: var(--color-white);
}
.btn--light {
  color: var(--color-primary-blue);
}
.btn--light:hover:not(:disabled) {
  background-color: var(--color-light-gray);
}
.btn--large {
  padding: var(--spacing-md) var(--spacing-xl);
  font-size: 18px;
}
.btn--small {
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-small);
}

.card {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-default);
  transition: all var(--transition-base);
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}
.card__image {
  width: 100%;
  height: auto;
  display: block;
}
.card__image-wrapper {
  aspect-ratio: 16/9;
  overflow: hidden;
}
.card__image-wrapper > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.card__content {
  padding: var(--spacing-md);
}
.card__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-sm);
  color: var(--color-black);
}
.card__description {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  color: var(--color-dark-gray);
  margin-bottom: var(--spacing-md);
}
.card__meta {
  display: flex;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
  font-size: var(--font-size-small);
  color: var(--color-gray);
}
.card--numbered .card__number {
  position: absolute;
  top: var(--spacing-md);
  left: var(--spacing-md);
  width: 48px;
  height: 48px;
  background-color: var(--color-primary-blue);
  color: var(--color-white);
  font-family: var(--font-family-en);
  font-size: 24px;
  font-weight: var(--font-weight-bold);
  border-radius: var(--radius-circle);
  display: flex;
  justify-content: center;
  align-items: center;
}
.card--numbered .card__image-wrapper {
  position: relative;
}
.card--horizontal {
  display: flex;
  flex-direction: row;
}
.card--horizontal .card__image-wrapper {
  flex: 0 0 40%;
}
.card--horizontal .card__content {
  flex: 1;
}
@media (max-width: 767px) {
  .card--horizontal {
    flex-direction: column;
  }
  .card--horizontal .card__image-wrapper {
    flex: 1;
  }
}

.hero {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}
.hero-swiper {
  width: 100%;
  height: 100%;
}
.hero .swiper-slide {
  width: 100%;
  height: 100%;
  position: relative;
}
.hero .swiper-slide::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.2);
  z-index: 1;
}
.hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-text-overlay {
  position: absolute;
  top: 50%;
  left: 10%;
  transform: translateY(-50%);
  z-index: 2;
  color: var(--color-white);
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}
.hero-title {
  font-family: var(--font-family-en);
  font-size: 8rem;
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: 0.05em;
  margin-bottom: var(--spacing-sm);
}
.hero-title .block {
  display: block;
}
@media (max-width: 767px) {
  .hero-title {
    font-size: 4rem;
  }
}
.hero-catchcopy {
  font-family: var(--font-family-serif);
  font-size: 2rem;
  color: #ccff00;
  font-weight: 700;
  transform: rotate(-5deg);
  margin-top: -20px;
  margin-left: 100px;
}
@media (max-width: 767px) {
  .hero-catchcopy {
    font-size: 1.5rem;
    margin-left: 20px;
  }
}

.scroll-down {
  position: absolute;
  bottom: 30px;
  right: 50px;
  z-index: 10;
  color: var(--color-white);
  font-family: var(--font-family-en);
  letter-spacing: 0.1em;
}
.scroll-down::after {
  content: "";
  display: block;
  width: 1px;
  height: 60px;
  background: var(--color-white);
  margin: 10px auto 0;
}

/* ====================================
   Sub Page Header - サブページ共通ヘッダー
   2階層ページ共通コンポーネント
   ==================================== */
.sub-page-header {
  position: relative;
  width: 100%;
  padding: 80px 20px;
  margin-top: var(--header-height);
  z-index: 1;
}
.sub-page-header::before {
  content: "";
  position: absolute;
  top: -50%;
  left: 0;
  right: 0;
  height: 100vw;
  background: url("../images/common/ribon-header.png") no-repeat right top/100%;
  z-index: 0;
  pointer-events: none;
}

.sub-page-header__content {
  position: relative;
  z-index: 2;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.sub-page-header__title {
  font-family: var(--font-family-base);
  font-size: 36px;
  font-weight: 400;
  color: #000000;
  margin: 0;
  line-height: normal;
}

.sub-page-header__subtitle {
  font-family: var(--font-family-en);
  font-size: 22px;
  font-weight: 400;
  color: #000000;
  margin: 0;
  line-height: normal;
}

.sub-page-header__line {
  display: block;
  width: 60px;
  height: 2px;
  background-color: #EEFF00;
  margin-top: 10px;
}

/* ====================================
   Page Key Visual - キービジュアル
   ==================================== */
.page-key-visual {
  position: relative;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
  z-index: 1;
}
.page-key-visual img {
  display: block;
  width: 100%;
  height: auto;
}
.page-key-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../images/common/page-header-filter.png") no-repeat center bottom/100% auto;
  pointer-events: none;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 768px) {
  .sub-page-header {
    padding: 60px 20px;
    margin-top: 80px;
  }
  .sub-page-header__title {
    font-size: 28px;
  }
  .sub-page-header__subtitle {
    font-size: 16px;
  }
}
@media (max-width: 640px) {
  .sub-page-header::before {
    top: 0;
  }
}
@media (max-width: 480px) {
  .sub-page-header {
    padding: 50px 20px;
  }
  .sub-page-header__title {
    font-size: 24px;
  }
  .sub-page-header__subtitle {
    font-size: 14px;
  }
}
body {
  animation: page-fade-in 0.4s ease both;
}

body.is-leaving {
  animation: page-fade-out 0.3s ease both;
  pointer-events: none;
}

@keyframes page-fade-in {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes page-fade-out {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
/* Gateway Page Styles - 採用サイト扉ページ */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --gateway-color-primary-blue: #0066CC;
  --gateway-color-text-dark: #333;
  --gateway-color-bg: #F5F7FA;
}

/* ====================================
   Gateway Page - 採用サイト扉ページ
   ==================================== */
.page-gateway {
  position: relative;
  min-height: 100vh;
  width: 100%;
  background: url("../images/index/bg_gateway.png") no-repeat center center/100%;
}
.page-gateway::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
  width: 30vw;
  aspect-ratio: 675/388;
  height: auto;
  background: url("../images/index/deco01.png") no-repeat center center/100%;
}
.page-gateway::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 33vw;
  aspect-ratio: 1067/502;
  height: auto;
  background: url("../images/index/deco02.png") no-repeat center center/100%;
}

.gateway-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
}

.gateway-header__container {
  position: relative;
  padding: 1rem 1rem;
}

.gateway-header__logo {
  width: 80%;
  max-width: 462px;
}

.gateway {
  width: 100%;
  min-height: calc(100vh - 100px); /* ヘッダー分を引く */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
}

.gateway__container {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

.gateway__banners {
  display: flex;
  justify-content: center;
  gap: 10px;
  max-width: 900px;
  margin: 0 auto;
}
@media (max-width: 1024px) {
  .gateway__banners {
    gap: 8px;
  }
}
@media (max-width: 640px) {
  .gateway__banners {
    align-items: center;
    gap: 4vw;
  }
}
.gateway__banners:has(.gateway-banner:hover) .gateway-banner:not(:hover) .gateway-banner__card img {
  filter: brightness(0.5);
}

.gateway-banner {
  display: block;
  text-decoration: none;
}
.gateway-banner .gateway-banner__card img {
  transition: transform 0.5s, filter 0.3s ease;
}
@media (max-width: 1024px) {
  .gateway-banner {
    width: calc(50% - 4px);
  }
}
@media (max-width: 640px) {
  .gateway-banner {
    width: 100%;
  }
}

.gateway-banner__card {
  position: relative;
  aspect-ratio: 800/780;
  overflow: hidden;
  display: block;
  cursor: pointer;
  max-width: 400px;
}
.gateway-banner__card img {
  width: 100%;
  height: auto;
}
.gateway-banner__card:hover img {
  transform: scale(1.05);
}
@media (max-width: 1024px) {
  .gateway-banner__card {
    max-width: 100%;
    width: 100%;
  }
}
@media (max-width: 640px) {
  .gateway-banner__card {
    max-width: 100%;
    width: 100%;
  }
}

.gateway-banner__overlay {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  background: black;
  color: #fff;
  transition: background-color 0.3s;
  padding: 24px;
}
@media (max-width: 640px) {
  .gateway-banner__overlay {
    padding: 3vw;
  }
}

.gateway-banner__title-en {
  margin: 0;
  text-align: center;
}

.gateway-banner__title-en-img {
  height: 2rem;
  width: auto;
}
@media (max-width: 1024px) {
  .gateway-banner__title-en-img {
    height: 1.6rem;
  }
}
@media (max-width: 768px) {
  .gateway-banner__title-en-img {
    height: 2.5vw;
  }
}
@media (max-width: 640px) {
  .gateway-banner__title-en-img {
    height: 4vw;
  }
}

.gateway-banner__title-ja {
  font-size: 1rem;
  margin: 0.5em 0 0;
  opacity: 0.9;
  line-height: 1;
}
@media (max-width: 1024px) {
  .gateway-banner__title-ja {
    font-size: 0.875rem;
  }
}
@media (max-width: 768px) {
  .gateway-banner__title-ja {
    font-size: 1.8vw;
  }
}
@media (max-width: 640px) {
  .gateway-banner__title-ja {
    font-size: 2.8vw;
  }
}

.gateway-footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 1rem 1rem;
}

.copyright {
  text-align: center;
  font-size: 0.8rem;
  color: #165EA3;
}

/* Business Page Styles - 事業領域を知る */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --business-color-primary-blue: #24a4db;
  --business-color-accent-yellow: #eeff00;
  --business-color-text-dark: #000000;
  --business-color-text-body: #000000;
}

/* ====================================
   Page Header - ページヘッダー
   ==================================== */
.business-page-header {
  position: relative;
  width: 100%;
  height: 411px;
  margin-top: var(--header-height);
  overflow: hidden;
}

.business-page-header__image {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.business-page-header__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.business-page-header__image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(36, 164, 219, 0) 0%, rgba(22, 149, 163, 0) 100%);
  backdrop-filter: blur(2px);
}

.business-page-header__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.business-page-header__title {
  font-family: var(--font-family-base);
  font-size: 36px;
  font-weight: 400;
  color: var(--business-color-text-dark);
  margin: 0;
  line-height: normal;
}

.business-page-header__subtitle {
  font-family: var(--font-family-en);
  font-size: 22px;
  font-weight: 400;
  color: var(--business-color-text-dark);
  margin: 0;
  line-height: normal;
}

.business-page-header__line {
  display: block;
  width: 60px;
  height: 2px;
  background-color: var(--business-color-accent-yellow);
  margin-top: 10px;
}

/* ====================================
   Main Message - メインメッセージ
   ==================================== */
.business-main {
  padding: 30px 20px 40px;
  position: relative;
}

.business-main__container {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 0;
}

.business-main__catchcopy {
  font-family: var(--font-family-serif);
  font-size: 70px;
  font-weight: 400;
  color: var(--business-color-text-dark);
  line-height: 90px;
  margin: 0;
}
.business-main__catchcopy span {
  display: block;
}

/* ====================================
   Intro Section - 事業紹介
   ==================================== */
.business-intro {
  padding: 40px 20px 80px;
}

.business-intro__container {
  max-width: 1200px;
  margin: 0 auto;
}

.business-intro__lead {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--business-color-primary-blue);
  line-height: 40px;
  margin: 0 0 20px 0;
}

.business-intro__body {
  max-width: 1200px;
}
.business-intro__body p {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--business-color-text-body);
  line-height: 34px;
  margin: 0;
}

/* ====================================
   Business Areas - 4つの事業領域
   ==================================== */
.business-areas {
  padding: 60px 20px 80px;
}

.business-areas__container {
  max-width: 1200px;
  margin: 0 auto;
}

.business-areas__figure {
  width: 100%;
  display: flex;
  justify-content: center;
}
.business-areas__figure img {
  max-width: 100%;
  height: auto;
}

/* ====================================
   Works Section - 代表的な施工事例
   ==================================== */
.business-works {
  padding: 80px 20px;
}

.business-works__container {
  max-width: 1200px;
  margin: 0 auto;
}

.business-works__heading {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--business-color-primary-blue);
  line-height: 40px;
  margin: 0 0 40px 0;
}

.business-works__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 58px;
  margin-bottom: 40px;
}
.business-works__grid:last-child {
  margin-bottom: 0;
}

.business-works__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.business-works__image {
  width: 100%;
  height: 240px;
  overflow: hidden;
  border-radius: 0;
}
.business-works__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.business-works__caption {
  font-family: var(--font-family-base);
  font-size: 15px;
  font-weight: 400;
  color: var(--business-color-text-body);
  line-height: 20px;
  margin: 0;
}

/* ====================================
   Map Section - エリアマップ
   ==================================== */
.business-map {
  padding: 80px 20px 120px;
  position: relative;
}

.business-map__container {
  max-width: 1200px;
  margin: 0 auto;
}

.business-map__lead {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--business-color-primary-blue);
  line-height: 34px;
  margin: 0 0 40px 0;
}

.business-map__image {
  width: 100%;
  height: 600px;
  overflow: hidden;
  border-radius: 0;
  margin-bottom: 20px;
}
.business-map__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.business-map__note {
  font-family: var(--font-family-base);
  font-size: 14px;
  font-weight: 400;
  color: var(--business-color-text-body);
  line-height: 34px;
  margin: 0;
  text-align: right;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .business-works__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
  }
  .business-main__catchcopy {
    font-size: 56px;
    line-height: 72px;
  }
  .business-map__image {
    height: 450px;
  }
}
@media (max-width: 768px) {
  .business-page-header {
    height: 300px;
    margin-top: 80px;
  }
  .business-page-header__title {
    font-size: 28px;
  }
  .business-page-header__subtitle {
    font-size: 16px;
  }
  .business-main {
    padding: 60px 20px 30px;
  }
  .business-main__catchcopy {
    font-size: 36px;
    line-height: 52px;
  }
  .business-intro {
    padding: 30px 20px 60px;
  }
  .business-intro__lead {
    font-size: 20px;
    line-height: 32px;
  }
  .business-intro__lead br {
    display: none;
  }
  .business-intro__body p {
    font-size: 15px;
    line-height: 28px;
  }
  .business-areas {
    padding: 40px 20px 60px;
  }
  .business-works {
    padding: 60px 20px;
  }
  .business-works__heading {
    font-size: 20px;
    line-height: 32px;
    margin-bottom: 30px;
  }
  .business-works__grid {
    grid-template-columns: 1fr;
    gap: 30px;
    margin-bottom: 30px;
  }
  .business-works__image {
    height: auto;
  }
  .business-works__caption {
    font-size: 14px;
    line-height: 22px;
  }
  .business-map {
    padding: 60px 20px 80px;
  }
  .business-map__lead {
    font-size: 18px;
    line-height: 28px;
    margin-bottom: 30px;
  }
  .business-map__image {
    height: 300px;
    margin-bottom: 16px;
  }
  .business-map__note {
    font-size: 12px;
    line-height: 20px;
  }
}
@media (max-width: 480px) {
  .business-page-header {
    height: 250px;
  }
  .business-page-header__title {
    font-size: 24px;
  }
  .business-page-header__subtitle {
    font-size: 14px;
  }
  .business-main__catchcopy {
    font-size: 28px;
    line-height: 42px;
  }
  .business-intro__lead {
    font-size: 18px;
    line-height: 28px;
  }
  .business-works__heading {
    font-size: 18px;
    line-height: 28px;
  }
  .business-map__lead {
    font-size: 16px;
    line-height: 26px;
  }
  .business-map__image {
    height: 220px;
  }
}
/* Interview Page Styles - はたらく人を知る */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --interview-color-primary-blue: #24A4DB;
  --interview-color-cn-blue: #165EA3;
  --interview-color-accent-yellow: #EEFF00;
  --interview-color-text-dark: #000000;
  --interview-color-text-body: #000000;
  --interview-color-border-yellow: #F3FE01;
  --interview-color-info-bg: rgba(29, 142, 223, 0.65);
}

/* ====================================
   Main Section - メインセクション
   ==================================== */
.interview-main {
  position: relative;
  padding: 60px 20px 120px;
  overflow: hidden;
}

.interview-main__container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* 背景装飾（曲線） */
.interview-main__decoration {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}

/* ====================================
   Header - ヘッダー部分
   ==================================== */
.interview-main__header {
  text-align: left;
  margin-bottom: 40px;
}

.interview-main__title {
  font-family: var(--font-family-en);
  font-size: 106px;
  font-weight: 400;
  font-style: italic;
  color: var(--interview-color-text-dark);
  line-height: 1;
  margin: 0;
  letter-spacing: 0.02em;
}

/* ====================================
   Filter Section - フィルターセクション
   ==================================== */
.interview-filter {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-bottom: 60px;
}

.interview-filter__group {
  display: flex;
  align-items: center;
  gap: 20px;
}

.interview-filter__label {
  font-family: var(--font-family-base);
  font-size: 20px;
  font-weight: 700;
  color: var(--interview-color-text-dark);
  margin: 0;
  min-width: 60px;
  line-height: 40px;
  position: relative;
}
.interview-filter__label::after {
  content: "";
  position: absolute;
  right: -42px;
  top: 50%;
  transform: translateY(-50%) rotate(90deg);
  width: 25px;
  height: 2px;
  background-color: var(--interview-color-accent-yellow);
}

.interview-filter__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
  margin-left: 60px;
}

.interview-filter__button {
  font-family: var(--font-family-base);
  font-size: 18px;
  font-weight: 500;
  padding: 0 30px;
  height: 40px;
  line-height: 40px;
  border: none;
  background-color: var(--interview-color-cn-blue);
  color: var(--color-white);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.3s ease;
  white-space: nowrap;
}
.interview-filter__button:hover {
  opacity: 0.85;
  transform: translateY(-2px);
}
.interview-filter__button.is-active {
  background-color: var(--interview-color-cn-blue);
}

/* ====================================
   Interview Grid - インタビューグリッド
   ==================================== */
.interview-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2vw;
}

/* ====================================
   Interview Card - インタビューカード
   ==================================== */
.interview-card {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  cursor: pointer;
  /* フィルターアニメーション用のトランジション（滑らかなcubic-bezier） */
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform, opacity;
  backface-visibility: hidden;
  /* ホバーエフェクト（フィルターアニメーション中は無効） */
}
.interview-card:hover:not(.is-hiding):not(.is-showing) {
  transform: translateY(-8px);
}
.interview-card:hover:not(.is-hiding):not(.is-showing) .interview-card__photo-inner img {
  transform: scale(1.05);
}

.interview-card__photo {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
}

.interview-card__photo-inner {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.interview-card__photo-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.interview-card__info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background-color: var(--interview-color-info-bg);
  padding: 13px 21px;
  z-index: 2;
}

.interview-card__department {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--color-white);
  line-height: 32px;
  margin: 0;
}

.interview-card__year {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--color-white);
  line-height: 32px;
  margin: 0;
}

/* Filter Animation - フィルターアニメーション */
.interview-card.is-hiding {
  opacity: 0 !important;
  transform: scale(0.92) translateY(10px) !important;
  pointer-events: none;
}

.interview-card.is-hidden {
  display: none !important;
}

.interview-card.is-showing {
  opacity: 0 !important;
  transform: scale(0.95) translateY(15px) !important;
}

.interview-card.is-fade-in {
  opacity: 1 !important;
  transform: scale(1) translateY(0) !important;
}

/* ====================================
   No Results - 該当なし
   ==================================== */
.interview-no-results {
  text-align: center;
  padding: 80px 20px;
  transition: opacity 0.4s cubic-bezier(0.4, 0, 0.2, 1), transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translateY(0);
}
.interview-no-results.is-showing {
  opacity: 0;
  transform: translateY(20px);
}
.interview-no-results p {
  font-family: var(--font-family-base);
  font-size: 18px;
  color: var(--interview-color-text-dark);
  line-height: 1.8;
  margin: 0 0 10px 0;
}
.interview-no-results p:last-child {
  margin-bottom: 0;
}

/* ====================================
   Modal - モーダル（Figmaデザイン準拠）
   ==================================== */
.interview-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s ease;
}
.interview-modal.is-open {
  opacity: 1;
  visibility: visible;
}
.interview-modal.is-open .interview-modal__container {
  transform: translateY(0);
}

.interview-modal__overlay {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.6);
  cursor: pointer;
}

.interview-modal__container {
  position: relative;
  width: 90%;
  max-width: 1000px;
  max-height: 96vh;
  z-index: 1;
  transform: translateY(30px);
  transition: transform 0.4s ease;
  overflow: hidden;
  background-color: #FFFFFF;
}

.interview-modal__deco {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 180px;
  height: 120px;
  background-image: url("../images/interview/modal-deco.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom left;
  pointer-events: none;
}

.interview-modal__content {
  max-height: 90vh;
  overflow-y: auto;
}

/* ヘッダー: 写真 + プロフィール情報 */
.interview-modal__header {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 40px;
  padding: 50px 50px 30px;
}

.interview-modal__photo {
  flex-shrink: 0;
  width: 350px;
  height: auto;
  aspect-ratio: 1;
  overflow: hidden;
}
.interview-modal__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* プロフィール情報 */
.interview-modal__profile {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: 120px;
}

.interview-modal__department {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--interview-color-text-dark);
  line-height: 1.5;
  margin: 0 0 8px 0;
}

.interview-modal__year {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--interview-color-text-dark);
  line-height: 1.5;
  margin: 0;
}

/* Q&Aセクション */
.interview-modal__body {
  padding: 0 50px 50px;
}

.interview-modal__qa {
  display: flex;
  flex-direction: column;
  gap: 40px;
  margin-bottom: 60px;
}

.interview-modal__qa-question {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--interview-color-primary-blue);
  line-height: 40px;
  margin: 0 0 16px 0;
  padding-bottom: 0;
  border-bottom: none;
}

.interview-modal__qa-answer {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--interview-color-text-dark);
  line-height: 34px;
  margin: 0;
}

/* Life Outside of Work セクション */
.interview-modal__life {
  background-color: #24A4DB;
  margin: 0 -50px;
  padding: 40px 50px;
}

.interview-modal__life-title {
  font-family: var(--font-family-en);
  font-size: 40px;
  font-weight: 400;
  color: var(--color-white);
  margin: 0 0 24px 0;
  letter-spacing: 0;
}

.interview-modal__life-content {
  display: flex;
  gap: 30px;
  align-items: flex-start;
}

.interview-modal__life-photo {
  flex-shrink: 0;
  width: 300px;
  height: 200px;
  overflow: hidden;
}
.interview-modal__life-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.interview-modal__life-text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--color-white);
  line-height: 34px;
  margin: 0;
}

/* フッター: CLOSEボタン */
.interview-modal__footer {
  padding: 30px 50px;
  text-align: center;
}

.interview-modal__close-btn {
  font-family: var(--font-family-base);
  font-size: 15px;
  font-weight: 400;
  color: var(--interview-color-text-dark);
  background: none;
  border: 1px solid var(--interview-color-text-dark);
  width: 100%;
  max-width: 980px;
  height: 80px;
  cursor: pointer;
  transition: all 0.3s ease;
  letter-spacing: 0;
}
.interview-modal__close-btn:hover {
  background-color: var(--interview-color-text-dark);
  color: var(--color-white);
}

/* ====================================
   Utility Classes
   ==================================== */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (min-width: 1201px) {
  .interview-grid {
    gap: 75px;
  }
}
@media (max-width: 1200px) {
  .interview-main__title {
    font-size: 80px;
  }
}
@media (max-width: 1024px) {
  .interview-filter__label {
    font-size: 20px;
    min-width: 50px;
  }
  .interview-filter__label::after {
    width: 40px;
  }
  .interview-filter__buttons {
    gap: 15px;
    margin-left: 40px;
  }
  .interview-filter__button {
    font-size: 16px;
    padding: 0 20px;
    height: 36px;
    line-height: 36px;
  }
}
@media (max-width: 768px) {
  .interview-main {
    padding: 40px 20px 80px;
  }
  .interview-main__title {
    font-size: 56px;
  }
  .interview-filter {
    gap: 20px;
    margin-bottom: 40px;
  }
  .interview-filter__group {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  .interview-filter__label {
    font-size: 18px;
  }
  .interview-filter__label::after {
    display: none;
  }
  .interview-filter__buttons {
    margin-left: 0;
    gap: 10px;
  }
  .interview-filter__button {
    font-size: 14px;
    padding: 0 16px;
    height: 32px;
    line-height: 32px;
  }
  .interview-modal__container {
    width: 95%;
    max-height: 95vh;
  }
  .interview-modal__container::before {
    width: 120px;
  }
  .interview-modal__header {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 30px 20px 20px;
  }
  .interview-modal__photo {
    width: 280px;
  }
  .interview-modal__profile {
    padding-top: 0;
    text-align: center;
  }
  .interview-modal__body {
    padding: 0 20px 30px;
  }
  .interview-modal__department {
    font-size: 20px;
    line-height: 34px;
  }
  .interview-modal__year {
    font-size: 14px;
    line-height: 30px;
  }
  .interview-modal__qa {
    gap: 30px;
    margin-bottom: 40px;
  }
  .interview-modal__qa-question {
    font-size: 18px;
    line-height: 32px;
  }
  .interview-modal__qa-answer {
    font-size: 15px;
    line-height: 28px;
  }
  .interview-modal__life {
    margin: 0 -20px;
    padding: 30px 20px;
  }
  .interview-modal__life-title {
    font-size: 28px;
  }
  .interview-modal__life-content {
    flex-direction: column;
    gap: 20px;
  }
  .interview-modal__life-photo {
    width: 100%;
    height: 200px;
  }
  .interview-modal__life-text {
    font-size: 15px;
    line-height: 28px;
  }
  .interview-modal__footer {
    padding: 20px;
  }
  .interview-modal__close-btn {
    height: 60px;
    font-size: 14px;
  }
}
@media (max-width: 840px) {
  .interview-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6vw 3vw;
  }
  .interview-card__photo {
    max-width: 100%;
  }
  .interview-card__info {
    max-width: 100%;
    padding: 10px 15px;
  }
  .interview-card__department,
  .interview-card__year {
    font-size: 14px;
    line-height: 26px;
  }
}
@media (max-width: 480px) {
  .interview-main__title {
    font-size: 42px;
  }
  .interview-grid {
    gap: 4vw 2vw;
  }
  .interview-card {
    width: 100%;
    height: auto;
  }
  .interview-card__photo {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  .interview-card__info {
    max-width: 100%;
    padding: 8px 10px;
  }
  .interview-card__department,
  .interview-card__year {
    font-size: 2.5vw;
    line-height: 1.6;
  }
  .interview-filter__button {
    font-size: 13px;
    padding: 0 14px;
    height: 30px;
    line-height: 30px;
    border-radius: 8px;
  }
  .interview-modal__container::before {
    width: 80px;
  }
  .interview-modal__header {
    padding: 20px 15px 15px;
    gap: 15px;
  }
  .interview-modal__photo {
    width: 200px;
  }
  .interview-modal__department {
    font-size: 16px;
    line-height: 28px;
  }
  .interview-modal__year {
    font-size: 13px;
    line-height: 24px;
  }
  .interview-modal__body {
    padding: 0 15px 20px;
  }
  .interview-modal__qa {
    gap: 24px;
    margin-bottom: 30px;
  }
  .interview-modal__qa-question {
    font-size: 16px;
    line-height: 28px;
    margin-bottom: 10px;
  }
  .interview-modal__qa-answer {
    font-size: 14px;
    line-height: 26px;
  }
  .interview-modal__life {
    margin: 0 -15px;
    padding: 25px 15px;
  }
  .interview-modal__life-title {
    font-size: 22px;
    margin-bottom: 16px;
  }
  .interview-modal__life-photo {
    height: 160px;
  }
  .interview-modal__life-text {
    font-size: 14px;
    line-height: 26px;
  }
  .interview-modal__footer {
    padding: 15px;
  }
  .interview-modal__close-btn {
    height: 50px;
    font-size: 13px;
  }
}
/* ====================================
   GSAP Animation Classes
   ==================================== */
.interview-card.is-animated {
  opacity: 0;
  transform: translateY(30px);
}
.interview-card.is-animated.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.interview-filter__button.is-animated {
  opacity: 0;
  transform: translateY(10px);
}
.interview-filter__button.is-animated.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Message Page Styles - 採用メッセージ */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --message-color-primary-blue: #24A4DB;
  --message-color-accent-yellow: #EEFF00;
  --message-color-text-dark: #000000;
  --message-color-text-body: #000000;
}

/* ====================================
   Main Message - メインメッセージ
   ==================================== */
.message-main {
  padding: 20px 20px 40px;
  position: relative;
}

.message-main__container {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 0;
}

.message-main__catchcopy {
  font-family: var(--font-family-serif);
  font-size: 70px;
  font-weight: 400;
  color: var(--message-color-text-dark);
  line-height: 90px;
  margin: 0 0 30px 0;
}
.message-main__catchcopy span {
  display: block;
}

.message-main__author {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--message-color-text-dark);
  line-height: 34px;
  margin: 0;
}

/* ====================================
   Message Content - メッセージコンテンツ
   ==================================== */
.message-content {
  position: relative;
  padding: 30px 20px;
  overflow: hidden;
}

.message-content__container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* ====================================
   Message Section - メッセージセクション
   ==================================== */
.message-section {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 60px;
  margin-bottom: 50px;
  align-items: start;
}
.message-section:last-of-type {
  margin-bottom: 0;
}

.message-section__heading {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.message-section__line {
  display: block;
  width: 2px;
  height: 112px;
  background-color: var(--message-color-primary-blue);
  flex-shrink: 0;
  margin-top: 8px;
}

.message-section__title {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--message-color-text-dark);
  line-height: 40px;
  margin: 0;
}
.message-section__title span {
  display: block;
}

.message-section__body {
  max-width: 800px;
}
.message-section__body p {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--message-color-text-body);
  line-height: 34px;
  letter-spacing: -0.48px;
  margin: 0 0 1em 0;
}
.message-section__body p:last-child {
  margin-bottom: 0;
}

/* ====================================
   Message Image - 画像
   ==================================== */
.message-image {
  margin: 50px 0;
  position: relative;
}
.message-image--right {
  margin-left: auto;
  width: fit-content;
  padding-right: 0;
}
.message-image img {
  display: block;
  width: 800px;
  height: 400px;
  object-fit: cover;
  border-radius: 0;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .message-section {
    grid-template-columns: 280px 1fr;
    gap: 40px;
  }
  .message-main__catchcopy {
    font-size: 56px;
    line-height: 72px;
  }
  .message-image img {
    width: 100%;
    max-width: 800px;
    height: auto;
    aspect-ratio: 2/1;
  }
}
@media (max-width: 768px) {
  .message-main {
    padding: 30px 20px 30px;
  }
  .message-main__catchcopy {
    font-size: 36px;
    line-height: 52px;
  }
  .message-main__author {
    font-size: 14px;
    line-height: 28px;
  }
  .message-content {
    padding: 40px 20px 80px;
  }
  .message-section {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 30px;
  }
  .message-section__heading {
    gap: 12px;
    align-items: stretch;
  }
  .message-section__line {
    height: auto;
    margin-top: 0;
  }
  .message-section__title {
    font-size: 20px;
    line-height: 32px;
  }
  .message-section__title span {
    display: inline;
  }
  .message-section__body p {
    font-size: 15px;
    line-height: 28px;
    letter-spacing: 0;
  }
  .message-image {
    margin: 40px 0 30px;
  }
  .message-image--right {
    margin-left: 0;
    width: 100%;
  }
  .message-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 2/1;
  }
}
@media (max-width: 480px) {
  .message-main__catchcopy {
    font-size: 28px;
    line-height: 42px;
  }
  .message-section__title {
    font-size: 18px;
    line-height: 28px;
  }
  .message-section__title span {
    display: inline;
  }
  .message-section__body p {
    font-size: 14px;
    line-height: 26px;
  }
}
/* Recruit Page Styles - 新卒募集要項 */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --recruit-color-primary-blue: #24A4DB;
  --recruit-color-accent-yellow: #EEFF00;
  --recruit-color-text-dark: #000000;
  --recruit-color-text-body: #000000;
  --recruit-color-border: #E0E0E0;
}

/* ====================================
   Table Section - 募集要項テーブル
   ==================================== */
.recruit-table {
  padding: 60px 20px 80px;
}

.recruit-table__container {
  max-width: 1200px;
  margin: 0 auto;
}

.recruit-table__list {
  margin: 0;
}

.recruit-table__row {
  display: grid;
  grid-template-columns: 230px 1fr;
  gap: 40px;
  padding: 20px 0;
  border-top: 1px solid var(--recruit-color-border);
}
.recruit-table__row:last-child {
  border-bottom: 1px solid var(--recruit-color-border);
}

.recruit-table__label {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--recruit-color-primary-blue);
  line-height: 40px;
}

.recruit-table__value {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--recruit-color-text-body);
  line-height: 34px;
  margin: 0;
}

/* ====================================
   Entry Section - エントリーボタン
   ==================================== */
.recruit-entry {
  padding: 60px 20px;
}

.recruit-entry__container {
  max-width: 1200px;
  margin: 0 auto;
}

.recruit-entry__buttons {
  display: flex;
  gap: 30px;
  justify-content: flex-start;
}

.recruit-entry__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 50px;
  border: 1px solid var(--recruit-color-primary-blue);
  border-radius: 0;
  text-decoration: none;
  transition: opacity 0.3s ease;
}
.recruit-entry__button:hover {
  opacity: 0.8;
}
.recruit-entry__button img {
  max-width: 190px;
  max-height: 47px;
  object-fit: contain;
}

/* ====================================
   Entry Sheet Section - エントリーシート
   ==================================== */
.recruit-sheet {
  padding: 60px 20px;
}

.recruit-sheet__container {
  max-width: 1200px;
  margin: 0 auto;
}

.recruit-sheet__heading {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--recruit-color-primary-blue);
  line-height: 40px;
  margin: 0 0 20px 0;
}

.recruit-sheet__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border: 1px solid var(--recruit-color-text-dark);
  border-radius: 0;
  font-family: var(--font-family-base);
  font-size: 13px;
  font-weight: 400;
  color: var(--recruit-color-text-dark);
  text-decoration: none;
  line-height: 40px;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.recruit-sheet__button:hover {
  background-color: var(--recruit-color-text-dark);
  color: var(--color-white);
}

/* ====================================
   LINE Section - LINE QRコード
   ==================================== */
.recruit-line {
  padding: 60px 20px 120px;
}

.recruit-line__container {
  max-width: 1200px;
  margin: 0 auto;
}

.recruit-line__heading {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--recruit-color-primary-blue);
  line-height: 40px;
  margin: 0 0 20px 0;
}

.recruit-line__qr {
  width: 146px;
  height: 145px;
}
.recruit-line__qr img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 768px) {
  .recruit-table {
    padding: 40px 20px 60px;
  }
  .recruit-table__row {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 16px 0;
  }
  .recruit-table__label {
    line-height: 28px;
  }
  .recruit-table__value {
    font-size: 15px;
    line-height: 28px;
  }
  .recruit-entry {
    padding: 40px 20px;
  }
  .recruit-entry__buttons {
    flex-direction: column;
    gap: 16px;
  }
  .recruit-entry__button {
    width: 100%;
    max-width: 200px;
  }
  .recruit-sheet {
    padding: 40px 20px;
  }
  .recruit-sheet__heading {
    font-size: 14px;
    line-height: 32px;
  }
  .recruit-sheet__button {
    font-size: 12px;
    padding: 10px 20px;
    line-height: 32px;
  }
  .recruit-line {
    padding: 40px 20px 80px;
  }
  .recruit-line__heading {
    font-size: 14px;
    line-height: 32px;
  }
  .recruit-line__qr {
    width: 120px;
    height: 120px;
  }
}
@media (max-width: 480px) {
  .recruit-table__label {
    font-size: 14px;
  }
  .recruit-table__value {
    font-size: 14px;
    line-height: 26px;
  }
}
/* Career Page Styles - キャリア採用ページ */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --career-color-primary-blue: #26a1e1;
  --career-color-dark-blue: #165ea3;
  --career-color-accent-blue: #2672ff;
  --career-color-accent-yellow: #f5ff00;
  --career-color-gray-bg: #f1f1f1;
}

/* ====================================
   Hero Section - メインビジュアル
   ==================================== */
.career-hero {
  position: relative;
  width: 100%;
  height: 900px;
  margin-top: var(--header-height);
  overflow: hidden;
}

.career-hero__background {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.career-hero__background-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.career-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.2) 27.603%, rgba(0, 0, 0, 0.05) 89.366%);
  z-index: 2;
}

.career-hero__content {
  display: grid;
  place-items: center;
  position: absolute;
  top: 140px;
  left: 80px;
  z-index: 3;
  text-align: left;
}

.career-hero__graphic {
  width: 710.336px;
  height: 355.767px;
  margin-bottom: 20px;
}

.career-hero__title {
  font-family: "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: 500;
  color: var(--color-white);
  line-height: 1.2;
  margin: 0;
}

.career-hero__scroll-button {
  position: absolute;
  bottom: 60px;
  right: 60px;
  width: 60px;
  height: 60px;
  background-color: var(--career-color-accent-yellow);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 3;
  transition: transform 0.3s ease;
}
.career-hero__scroll-button:hover {
  transform: scale(1.1);
}
.career-hero__scroll-button svg {
  width: 54px;
  height: 3px;
}

/* ====================================
   Sub Visual Section - サブビジュアル
   ==================================== */
.career-sub-visual {
  position: relative;
  width: 100%;
  height: 800px;
  margin-top: -200px;
  z-index: 1;
}

.career-sub-visual__decorations {
  position: absolute;
  top: 300px;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}
.career-sub-visual__decorations img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

.career-sub-visual__decoration {
  position: absolute;
}
.career-sub-visual__decoration--1 {
  right: 100px;
  bottom: -100px;
  width: 263px;
  height: 214px;
}
.career-sub-visual__decoration--2 {
  left: 50%;
  top: -200px;
  transform: translateX(-50%);
  width: 263px;
  height: 214px;
}

.career-sub-visual__images {
  position: relative;
  height: 100%;
  z-index: 2;
  /* 全体を右にずらす */
  margin-left: 300px;
}

.career-sub-visual__image {
  position: absolute;
  overflow: hidden;
  /* 400x600 の枠、アスペクト比 2:3 */
  width: 400px;
  height: 600px;
}
.career-sub-visual__image img {
  width: 100%;
  /* パララックス用に画像を大きめにして移動可能にする */
  height: 140%;
  object-fit: cover;
  will-change: transform;
}
.career-sub-visual__image--left {
  /* 左の画像: 下に配置 */
  left: 50%;
  top: 100px;
  transform: translateX(-390px);
  z-index: 2;
}
.career-sub-visual__image--right {
  /* 右の画像: 上に配置 */
  left: 50%;
  top: 0;
  transform: translateX(50px);
  z-index: 1;
}

/* ====================================
   Catchphrase Section - キャッチコピー
   ==================================== */
.career-section-headline {
  position: relative;
  width: fit-content;
}
.career-section-headline::before {
  content: "";
  position: absolute;
  bottom: -10px;
  right: -124px;
  display: block;
  width: 263px;
  height: 214px;
  background: url("../images/career/headline-decoration.svg") no-repeat center center;
  z-index: 0;
}
.career-section-headline .career-interviews__headline {
  position: relative;
  z-index: 1;
}

.career-catchphrase {
  position: relative;
  padding: 40px 20px;
  margin-left: 200px;
  margin-top: var(--header-height);
}

.career-catchphrase__text {
  font-family: "Noto Serif JP", serif;
  font-size: 65px;
  font-weight: 500;
  color: var(--color-white);
  line-height: 90px;
  margin: 0;
}
.career-catchphrase__text span {
  display: block;
  padding: 0 0.2em;
  background-color: var(--color-text-black);
  margin-bottom: 0.35em;
  white-space: nowrap;
  background: #000;
  width: fit-content;
  line-height: 1.2;
}
.career-catchphrase__text span:last-child {
  margin-bottom: 0;
}

/* ====================================
   Message Section - メッセージ
   ==================================== */
.career-message {
  position: relative;
  padding: 120px 200px 180px;
  z-index: 1;
}
.career-message::before {
  content: "";
  position: absolute;
  top: 25%;
  left: 0;
  width: 100%;
  height: 50%;
  background-color: #f5ff00;
  clip-path: polygon(0 12vw, 100% 0, 100% calc(100% - 12vw), 0 100%);
  z-index: 0;
}

.career-message__decorations {
  position: absolute;
  bottom: 0;
  right: 0;
  pointer-events: none;
  transform: rotate(180deg);
}
.career-message__decorations img {
  width: 70%;
  height: auto;
  object-fit: cover;
}

.career-message__heading {
  position: absolute;
  top: 40px;
  left: 1000px;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 23px;
  font-weight: 500;
  color: var(--color-text-black);
  line-height: 1.5;
  margin-bottom: 40px;
}
@media screen and (min-width: 641px) and (max-width: 1520px) {
  .career-message__heading {
    top: -60px;
    right: 12%;
    left: auto;
  }
}

.career-message__headline {
  position: relative;
  z-index: 1;
}

.career-message__content {
  max-width: 1000px;
  margin: 50px 0 0;
  position: relative;
  z-index: 1;
}
.career-message__content p {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.9;
  margin-bottom: 16px;
}

.career-message__images {
  position: relative;
  height: 700px;
  margin-top: 60px;
  z-index: 2;
}
@media screen and (min-width: 641px) and (max-width: 1520px) {
  .career-message__images {
    height: 500px;
  }
}

.career-message__image {
  position: absolute;
  overflow: hidden;
  /* 400x600 の枠、アスペクト比 2:3 */
  width: 400px;
  height: 600px;
}
.career-message__image img {
  width: 100%;
  /* パララックス用に画像を大きめにして移動可能にする */
  height: 140%;
  object-fit: cover;
  will-change: transform;
}
.career-message__image--left {
  /* 左の画像: 上に配置 */
  left: 0;
  top: 0;
  z-index: 2;
}
.career-message__image--right {
  /* 右の画像: 下に配置、重ねる */
  left: 450px;
  top: 100px;
  z-index: 1;
}

/* ====================================
   Photo Section - 写真セクション
   ==================================== */
.career-photo-section {
  position: relative;
  width: 100%;
  height: 700px;
  margin-top: 50px;
}

.career-photo-section__decoration {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 1600px;
  height: 876.4px;
  z-index: 1;
}

.career-photo-section__images {
  position: relative;
  z-index: 2;
}

.career-photo-section__image {
  position: absolute;
  overflow: hidden;
}
.career-photo-section__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.career-photo-section__image--1 {
  left: 200px;
  top: -100px;
  width: 618px;
  height: 736px;
}
.career-photo-section__image--2 {
  left: 650px;
  top: 0;
  width: 559px;
  height: 649px;
}

/* ====================================
   Interviews Section - インタビュー
   ==================================== */
.career-section-title {
  text-align: center;
  color: var(--career-color-primary-blue);
  margin-bottom: 1em;
  font-weight: 500;
  font-size: 45px;
}

.career-interviews {
  background-color: var(--career-color-gray-bg);
  padding: 100px 200px;
  position: relative;
}

.career-interviews__decorations {
  position: absolute;
  pointer-events: none;
}

.career-interviews__decoration {
  position: absolute;
}
.career-interviews__decoration--1 {
  left: 50%;
  top: -250px;
  transform: translateX(-50%);
  width: 263px;
  height: 214px;
}
.career-interviews__decoration--2 {
  left: 200px;
  top: -220px;
  width: 560.24px;
  height: 179.045px;
}

.career-interviews__heading {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 23px;
  font-weight: 500;
  color: var(--color-text-black);
  margin-bottom: 60px;
  text-align: center;
}

.career-interview-card {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 50px;
  margin-bottom: 80px;
  position: relative;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}
.career-interview-card--2 {
  grid-template-columns: 1fr 210px;
}
.career-interview-card--2 .career-interview-card__content {
  order: 1;
}
.career-interview-card--2 .career-interview-card__figure {
  order: 2;
}

.career-interview-card__figure {
  margin: 0;
  display: grid;
  place-items: center;
  place-content: center;
  gap: 0.5em;
}

.career-interview-card__image-wrapper {
  position: relative;
  width: 210px;
  height: 280px;
  overflow: hidden;
}

.career-interview-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
}

.career-interview-card__caption {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.8em;
  font-weight: 500;
  line-height: 1.6;
}

.career-interview-card__content {
  padding: 20px 0;
}

.career-interview-card__question {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--career-color-primary-blue);
  line-height: 1.6;
  margin-bottom: 15px;
  padding-left: 20px;
  border-left: 5px solid var(--career-color-accent-yellow);
}

.career-interview-card__answer {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  line-height: 1.8;
  margin-bottom: 30px;
  padding-left: 20px;
  color: #333;
}

/* ====================================
   Requirements & Alumni - 募集要項・アルムナイ
   ==================================== */
.career-requirements,
.career-alumni {
  padding: 120px 200px;
}

.career-alumni__description {
  max-width: 1200px;
  margin: 0 auto 80px;
}
.career-alumni__description p {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 33px;
  margin-bottom: 10px;
}

.career-requirements-table,
.career-alumni-table {
  max-width: 1200px;
  margin: 0 auto;
}

.career-requirements-table__row,
.career-alumni-table__row {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 40px;
  padding: 20px 0;
  border-bottom: 1px solid #d0d0d0;
}

.career-requirements-table__label,
.career-alumni-table__label {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  color: var(--career-color-primary-blue);
  font-weight: normal;
  line-height: 33px;
}

.career-requirements-table__value,
.career-alumni-table__value {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  line-height: 33px;
}

/* ====================================
   INSIDE CN Section
   ==================================== */
.career-inside-cn {
  padding: 100px 200px 100px;
  text-align: center;
}

.career-inside-cn__title {
  text-align: center;
  position: relative;
  margin-bottom: 1rem;
}
.career-inside-cn__title img {
  display: block;
  margin: 0 auto;
}

.career-inside-cn__subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 500;
  color: var(--career-color-primary-blue);
  line-height: 1.8;
  margin: 0;
  text-align: center;
}

/* ====================================
   3 Column Cards Section - 3カラムカード
   ==================================== */
.career-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background-color: #fff;
  margin-bottom: 100px;
}

.career-card {
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.career-card:hover {
  opacity: 0.85;
}

.career-card__thumbnail {
  position: relative;
  width: 100%;
  height: 320px;
  overflow: hidden;
}
.career-card__thumbnail::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  pointer-events: none;
}

.career-card__thumbnail-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.career-card:hover .career-card__thumbnail-image {
  transform: scale(1.05);
}

.career-card__title-area {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0 0 80px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 1;
}

.career-card__title-svg {
  height: 80px;
  width: 100%;
  object-fit: contain;
  display: block;
  max-width: none;
}

.career-card__content {
  padding: 25px 30px 35px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.career-card__description {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: #333;
  margin: 0 0 25px 0;
  text-align: left;
}

.career-card__arrow {
  margin-top: auto;
  text-align: center;
}
.career-card__arrow svg {
  width: 39px;
  height: 14px;
}

/* ====================================
   Talk Contents Section - トークコンテンツ
   ==================================== */
.career-talk-contents {
  position: relative;
  padding: 0 0 100px;
  margin-bottom: 150px;
  overflow: hidden;
}

.career-talk-contents__clip-defs {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.career-talk-contents__background {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  clip-path: url(#career-talk-clip-desktop);
}

.career-talk-contents__background-image {
  width: 100%;
  height: 120%;
  object-fit: cover;
  object-position: center top;
  will-change: transform;
}

.career-talk-contents__wave {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.career-talk-contents__wave--mobile {
  display: none;
}

.career-talk-contents__header {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: 180px 40px 80px;
}

.career-talk-contents__title {
  margin: 0 0 20px;
}

.career-talk-contents__title-svg {
  max-width: 590px;
  height: auto;
  margin-inline: auto;
}

.career-talk-contents__subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
}

.career-talk-contents__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5px;
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}

.career-talk-contents__card {
  display: flex;
  flex-direction: column;
  background: white;
  cursor: pointer;
}
.career-talk-contents__card:hover .career-talk-contents__card-image img {
  transform: scale(1.05);
}

.career-talk-contents__card-image {
  width: 100%;
  aspect-ratio: 120/56;
  overflow: hidden;
}
.career-talk-contents__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.career-talk-contents__card-content {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%);
  padding: 30px 40px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: -5em;
  position: relative;
  z-index: 2;
}

.career-talk-contents__card-title {
  height: 48px;
  width: 100%;
  object-fit: contain;
  display: block;
  max-width: none;
  margin-bottom: 15px;
}

.career-talk-contents__card-subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: #333;
  margin: 0 0 20px;
}

.career-talk-contents__card-arrow svg {
  width: 39px;
  height: 14px;
}

/* ====================================
   Scroll to Top Button - ページトップへ戻るボタン
   ==================================== */
.back-top {
  position: fixed;
  bottom: 0;
  right: 0;
  width: 60px;
  height: 60px;
  background: #26a1e1;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(200px);
  opacity: 0;
  transition: 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 50;
}
@media (max-width: 767px) {
  .back-top {
    bottom: 3vh;
    right: 3vw;
    width: 10.2vw;
    height: 10.2vw;
  }
}
.back-top.active {
  transform: translateY(0);
  opacity: 0.75;
}
.back-top:hover {
  cursor: pointer;
  opacity: 0.85;
  box-shadow: 0 3px 5px rgba(120, 120, 120, 0.5);
}
.back-top:hover .back-top__arrow {
  animation: ArrowUp 0.75s linear 0s infinite normal none running;
}
.back-top__arrow {
  display: block;
  background: url("../images/common/backtop.png") center/contain no-repeat;
  width: 50%;
  height: 50%;
}

@keyframes ArrowUp {
  0% {
    transform: translateY(10px);
    opacity: 0;
  }
  50% {
    transform: translateY(0);
    opacity: 1;
  }
  100% {
    transform: translateY(-10px);
    opacity: 0;
  }
}
/* ====================================
   Responsive Design - タブレット (1024px)
   ==================================== */
@media (max-width: 1024px) {
  /* Hero */
  .career-hero {
    height: 70vw;
    max-height: 700px;
  }
  .career-hero__content {
    top: 10vw;
    left: 5vw;
  }
  .career-hero__graphic {
    width: 55vw;
    height: auto;
  }
  .career-hero__title {
    font-size: 2.8vw;
  }
  /* Sub Visual */
  .career-sub-visual {
    height: 60vw;
    margin-top: -15vw;
  }
  .career-sub-visual__decorations {
    top: 20vw;
  }
  .career-sub-visual__images {
    margin-left: 15vw;
  }
  .career-sub-visual__image {
    width: 30vw;
    height: 45vw;
  }
  .career-sub-visual__image--left {
    transform: translateX(-28vw);
    top: 8vw;
  }
  .career-sub-visual__image--right {
    transform: translateX(4vw);
  }
  /* Catchphrase */
  .career-catchphrase {
    margin-left: 10vw;
  }
  .career-catchphrase__text {
    font-size: 5vw;
    line-height: 1.3;
  }
  /* Message */
  .career-message {
    padding: 80px 8vw 120px;
  }
  .career-message__heading {
    top: -40px;
    right: 8%;
    left: auto;
  }
  .career-message__content p {
    font-size: 15px;
  }
  .career-message__images {
    height: 45vw;
  }
  .career-message__image {
    width: 30vw;
    height: 45vw;
  }
  .career-message__image--right {
    left: 35vw;
    top: 8vw;
  }
  /* Interviews */
  .career-interviews {
    padding: 80px 8vw;
  }
  .career-interview-card {
    gap: 30px;
  }
  /* Requirements & Alumni */
  .career-requirements,
  .career-alumni {
    padding: 80px 8vw;
  }
  /* Inside CN (newgrads- prefixed sections used on career page) */
  .page-career .newgrads-inside-cn {
    padding: 80px 8vw;
  }
  .page-career .newgrads-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  /* Talk Contents */
  .career-talk-contents__header {
    padding: 140px 30px 60px;
  }
  .career-talk-contents__cards {
    max-width: 90%;
  }
  .career-talk-contents {
    margin-bottom: 100px;
  }
  /* Section Title */
  .career-section-title {
    font-size: 6vw;
  }
}
/* ====================================
   Responsive Design - タブレット/モバイル境界 (768px)
   ==================================== */
@media (max-width: 768px) {
  /* Header - hide side logo text on mobile */
  .page-career .header__side-logo-text {
    display: none;
  }
  /* Hero */
  .career-hero {
    height: auto;
    min-height: 100vw;
    aspect-ratio: auto;
  }
  .career-hero__content {
    top: 12vw;
    left: 5vw;
    right: 5vw;
  }
  .career-hero__graphic {
    width: 75vw;
    height: auto;
    margin-bottom: 3vw;
  }
  .career-hero__title {
    font-size: min(20px, 4.5vw);
  }
  .career-hero__scroll-button {
    bottom: 5vw;
    right: 5vw;
    width: 10vw;
    height: 10vw;
  }
  /* Sub Visual */
  .career-sub-visual {
    height: 80vw;
    margin-top: -10vw;
  }
  .career-sub-visual__decorations {
    top: 25vw;
  }
  .career-sub-visual__images {
    margin-left: 5vw;
  }
  .career-sub-visual__image {
    width: 40vw;
    height: 55vw;
  }
  .career-sub-visual__image--left {
    transform: translateX(-5vw);
    top: 10vw;
  }
  .career-sub-visual__image--right {
    transform: translateX(35vw);
    top: 0;
  }
  /* Catchphrase */
  .career-catchphrase {
    margin-left: 5vw;
    padding: 20px 5vw;
  }
  .career-catchphrase__text {
    font-size: min(32px, 6.5vw);
    line-height: 1.3;
  }
  /* Message */
  .career-message {
    padding: 60px 5vw 100px;
  }
  .career-message__heading {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    margin-bottom: 30px;
    text-align: center;
  }
  .career-message__heading img {
    max-width: 70vw;
    height: auto;
  }
  .career-message__content {
    margin-top: 30px;
  }
  .career-message__content p {
    font-size: min(16px, 3.8vw);
    line-height: 1.8;
  }
  .career-message__images {
    height: 70vw;
    margin-top: 40px;
  }
  .career-message__image {
    width: 42vw;
    height: 58vw;
  }
  .career-message__image--left {
    left: 0;
    top: 0;
  }
  .career-message__image--right {
    left: auto;
    right: 0;
    top: 12vw;
  }
  /* Section Headline decoration */
  .career-section-headline::before {
    width: 180px;
    height: 146px;
    right: -80px;
    bottom: -5px;
    background-size: contain;
  }
  /* Interviews */
  .career-interviews {
    padding: 60px 5vw;
  }
  .career-interviews__heading {
    margin-bottom: 40px;
  }
  .career-interviews__heading img {
    max-width: 80vw;
    height: auto;
  }
  .career-interview-card {
    grid-template-columns: 1fr;
    gap: 5vw;
    margin-bottom: 12vw;
  }
  .career-interview-card--2 {
    grid-template-columns: 1fr;
  }
  .career-interview-card--2 .career-interview-card__content {
    order: 2;
  }
  .career-interview-card--2 .career-interview-card__figure {
    order: 1;
  }
  .career-interview-card__figure {
    justify-items: center;
  }
  .career-interview-card__image-wrapper {
    width: 45vw;
    height: 60vw;
    max-width: 210px;
    max-height: 280px;
  }
  .career-interview-card__caption {
    text-align: center;
    font-size: min(14px, 3.2vw);
  }
  .career-interview-card__content {
    padding: 0;
  }
  .career-interview-card__question {
    font-size: min(18px, 4vw);
    padding-left: 4vw;
    border-left-width: 3px;
    margin-bottom: 3vw;
  }
  .career-interview-card__answer {
    font-size: min(15px, 3.6vw);
    padding-left: 4vw;
    margin-bottom: 6vw;
    line-height: 1.8;
  }
  /* Section Title */
  .career-section-title {
    font-size: min(36px, 7vw);
  }
  /* Requirements & Alumni */
  .career-requirements,
  .career-alumni {
    padding: 60px 5vw;
  }
  .career-alumni__description {
    margin-bottom: 40px;
  }
  .career-alumni__description p {
    font-size: min(15px, 3.6vw);
    line-height: 1.8;
  }
  .career-requirements-table__row,
  .career-alumni-table__row {
    grid-template-columns: 1fr;
    gap: 2vw;
    padding: 4vw 0;
  }
  .career-requirements-table__label,
  .career-alumni-table__label {
    font-size: min(15px, 3.6vw);
    font-weight: 500;
    line-height: 1.6;
  }
  .career-requirements-table__value,
  .career-alumni-table__value {
    font-size: min(15px, 3.6vw);
    line-height: 1.8;
  }
  /* Inside CN (newgrads- prefixed sections used on career page) */
  .page-career .newgrads-inside-cn {
    padding: 60px 5vw;
  }
  .page-career .newgrads-inside-cn__title {
    font-size: min(36px, 7vw);
  }
  .page-career .newgrads-inside-cn__subtitle {
    font-size: min(15px, 3.6vw);
  }
  .page-career .newgrads-cards {
    grid-template-columns: 1fr;
    gap: 4vw;
    margin-bottom: 12vw;
  }
  .page-career .newgrads-card__thumbnail {
    height: auto;
    aspect-ratio: 16/9;
  }
  .page-career .newgrads-card__title-area {
    padding: 0 0 8vw;
  }
  .page-career .newgrads-card__title-svg {
    height: 14vw;
    max-height: 80px;
  }
  .page-career .newgrads-card__content {
    padding: 4vw 5vw;
  }
  .page-career .newgrads-card__description {
    display: block;
    font-size: min(14px, 3.4vw);
  }
  /* Talk Contents */
  .career-talk-contents {
    padding: 0 5vw 12vw;
    margin-bottom: 12vw;
  }
  .career-talk-contents__background {
    clip-path: url(#career-talk-clip-mobile);
  }
  .career-talk-contents__wave--desktop {
    display: none;
  }
  .career-talk-contents__wave--mobile {
    display: block;
  }
  .career-talk-contents__header {
    padding: 25vw 5vw 10vw;
  }
  .career-talk-contents__title-svg {
    max-width: 80vw;
  }
  .career-talk-contents__subtitle {
    font-size: min(15px, 3.6vw);
  }
  .career-talk-contents__cards {
    grid-template-columns: 1fr;
    gap: 4vw;
    max-width: 90vw;
  }
  .career-talk-contents__card-content {
    padding: 5vw 5vw 4vw;
    margin-top: -8vw;
  }
  .career-talk-contents__card-title {
    height: 10vw;
    max-height: 48px;
    margin-bottom: 2vw;
  }
  .career-talk-contents__card-subtitle {
    font-size: min(15px, 3.6vw);
    margin-bottom: 3vw;
  }
}
/* ====================================
   Responsive Design - 小型モバイル (640px)
   ==================================== */
@media (max-width: 640px) {
  /* Hero - さらに小さい画面 */
  .career-hero {
    min-height: 80vw;
  }
  .career-hero__content {
    top: 15vw;
  }
  .career-hero__graphic {
    width: 85vw;
  }
  .career-hero__title {
    font-size: min(18px, 5vw);
  }
  /* Sub Visual - 横並びを維持（パララックス対応） */
  .career-sub-visual {
    height: 65vw;
    margin-top: -8vw;
  }
  .career-sub-visual__images {
    margin-left: 0;
  }
  .career-sub-visual__image {
    width: 43vw;
    height: 58vw;
    left: 0;
  }
  .career-sub-visual__image img {
    height: 110%;
  }
  .career-sub-visual__image--left {
    left: 4vw;
    transform: translateX(0);
    top: 3vw;
  }
  .career-sub-visual__image--right {
    left: 50vw;
    transform: translateX(0);
    top: 0;
  }
  /* Catchphrase */
  .career-catchphrase {
    margin-left: 0;
    padding: 20px 5vw;
  }
  .career-catchphrase__text {
    font-size: min(28px, 7.5vw);
  }
  .career-catchphrase__text span {
    white-space: normal;
  }
  /* Message */
  .career-message {
    padding: 40px 5vw 60px;
  }
  .career-message__content p {
    font-size: min(15px, 4vw);
  }
  /* Message images - 横並びを維持（パララックス対応） */
  .career-message__images {
    height: 65vw;
    margin-top: 30px;
  }
  .career-message__image {
    width: 44vw;
    height: 60vw;
  }
  .career-message__image img {
    height: 110%;
  }
  .career-message__image--left {
    left: 0;
    top: 3vw;
  }
  .career-message__image--right {
    left: auto;
    right: 0;
    top: 0;
  }
  /* Interview */
  .career-interview-card {
    margin-bottom: 15vw;
  }
  .career-interview-card__image-wrapper {
    width: 55vw;
    height: 73vw;
    max-width: 210px;
    max-height: 280px;
  }
  .career-interview-card__caption {
    font-size: min(13px, 3.5vw);
  }
  .career-interview-card__question {
    font-size: min(16px, 4.2vw);
  }
  .career-interview-card__answer {
    font-size: min(14px, 3.8vw);
  }
  /* Section Title */
  .career-section-title {
    font-size: min(30px, 8vw);
  }
  /* Section Headline decoration */
  .career-section-headline {
    overflow: visible;
  }
  .career-section-headline::before {
    width: 80px;
    height: 65px;
    right: 0;
    bottom: -5px;
    background-size: contain;
  }
  /* Requirements & Alumni */
  .career-requirements,
  .career-alumni {
    padding: 40px 5vw;
  }
  .career-requirements-table__label,
  .career-alumni-table__label {
    font-size: min(14px, 3.8vw);
  }
  .career-requirements-table__value,
  .career-alumni-table__value {
    font-size: min(14px, 3.8vw);
  }
  .career-alumni__description p {
    font-size: min(14px, 3.8vw);
  }
  /* Talk Contents */
  .career-talk-contents {
    padding: 0 3vw 40vw;
    margin-bottom: 10vw;
  }
  .career-talk-contents__header {
    padding: 30vw 5vw 8vw;
  }
  .career-talk-contents__card-content {
    padding: 6vw 5vw 5vw;
    margin-top: -10vw;
  }
  /* Inside CN */
  .page-career .newgrads-inside-cn {
    padding: 40px 5vw;
  }
  .page-career .newgrads-inside-cn__title {
    font-size: min(28px, 7vw);
  }
  .page-career .newgrads-inside-cn__subtitle {
    font-size: min(14px, 3.8vw);
  }
}
/* New Graduates Page Styles - 新卒採用TOPページ */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --newgrads-color-primary-blue: #165ea3;
  --newgrads-color-light-blue: #4a9fff;
  --newgrads-color-sky-blue: #e8f4fc;
  --newgrads-color-dark-blue: #003d7a;
  --newgrads-color-text-dark: #333;
  --newgrads-color-text-gray: #666;
  --newgrads-color-bg-light: #f8f9fa;
  --newgrads-color-bg-wave: #e6f3fa;
}

/* ====================================
リボン
   ==================================== */
.newgrads-ribbons {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  z-index: 0;
  overflow: hidden;
  filter: blur(5px);
}
.newgrads-ribbons .newgrads-ribbons__ribbon__01 {
  position: absolute;
  display: block;
  width: 100vw;
  height: auto;
  top: 0;
  left: 0;
  z-index: 0;
  opacity: 0.5;
  animation: newgrads-ribbons-animation 10s linear infinite;
}

.newgrads-ribbons02 {
  position: absolute;
  top: calc(100vh + 200px);
  left: 0;
  right: 0;
  width: 100%;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.newgrads-ribbons02 .newgrads-ribbons__ribbon__02 {
  position: absolute;
  width: 100vw;
  height: auto;
  top: 0;
  left: 0;
  aspect-ratio: 1601/2076;
  object-fit: contain;
  object-position: center;
}

/* ====================================
   Hero Section - ヒーローセクション
   ==================================== */
.newgrads-hero {
  position: relative;
  width: 100%;
  overflow: hidden;
  margin-top: var(--header-height);
  padding-top: 60px;
  aspect-ratio: 1280/720;
  max-height: 765px;
}

/* 背景スライダー（フェード） */
.newgrads-hero__bg-swiper {
  position: absolute;
  inset: 0;
  z-index: 1;
  max-width: 1280px;
}
.newgrads-hero__bg-swiper .swiper-slide {
  opacity: 0 !important;
  transition: opacity 1s ease;
}
.newgrads-hero__bg-swiper .swiper-slide-active {
  opacity: 1 !important;
}

.newgrads-hero__background-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 人物スライダー */
.newgrads-hero__person-container {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100vw;
  z-index: 7 !important;
}

.newgrads-hero__person-swiper {
  height: auto;
}
.newgrads-hero__person-swiper .swiper-wrapper {
  align-items: flex-end;
}
.newgrads-hero__person-swiper .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  opacity: 0;
  transition: opacity 0.6s ease;
}
.newgrads-hero__person-swiper .swiper-slide.swiper-slide-active {
  opacity: 1;
}

.newgrads-hero__person-image {
  width: clamp(300px, 45vw, 680px);
  max-height: 765px;
  height: auto;
  object-fit: contain;
  object-position: bottom center;
  margin-right: 50%;
}

/* リボンスライダー（人物スライダーと連動） */
.newgrads-hero__ribbon-swiper {
  position: absolute !important;
  top: 72%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  z-index: 6 !important;
  pointer-events: none;
  overflow: visible;
}
.newgrads-hero__ribbon-swiper .swiper-wrapper {
  transition-timing-function: cubic-bezier(0.25, 1, 0.5, 1) !important;
}
.newgrads-hero__ribbon-swiper .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
}

.newgrads-hero__ribbon-image {
  display: block;
  width: 100vw;
  height: auto;
  object-fit: cover;
  object-position: center;
}

/* コピー画像 */
.newgrads-hero__copy {
  pointer-events: none;
}

.newgrads-hero__copy-svg {
  position: absolute;
  top: 5%;
  left: 5%;
  display: block;
  width: 90%;
  max-width: 1280px;
  height: auto;
  margin: 0 auto 20px;
  opacity: 0;
  transition: opacity 0.8s ease;
  z-index: 5 !important;
}

.newgrads-hero__copy-text {
  position: absolute;
  right: 15%;
  bottom: 20%;
  display: block;
  width: 85%;
  max-width: 650px;
  height: auto;
  margin: 0 auto;
  opacity: 0;
  transition: opacity 0.8s ease 0.2s;
  z-index: 10;
}

.newgrads-hero__copy.is-visible .newgrads-hero__copy-svg,
.newgrads-hero__copy.is-visible .newgrads-hero__copy-text {
  opacity: 1;
}

.newgrads-hero__title {
  position: absolute;
  bottom: 120px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  margin: 0;
  text-align: center;
}

.newgrads-hero__title-handwritten {
  display: block;
  font-family: "Noto Serif JP", serif;
  font-size: 28px;
  font-weight: 400;
  color: var(--newgrads-color-text-dark);
  letter-spacing: 0.1em;
}

.newgrads-hero__scroll-indicator {
  position: absolute;
  bottom: 40px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  width: 24px;
  height: 40px;
  border: 2px solid var(--newgrads-color-primary-blue);
  border-radius: 12px;
}
.newgrads-hero__scroll-indicator span {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 8px;
  background: var(--newgrads-color-primary-blue);
  border-radius: 2px;
  animation: scroll-indicator 1.5s ease-in-out infinite;
}

@keyframes scroll-indicator {
  0% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) translateY(16px);
  }
}
/* ====================================
   Lead Section - リードセクション
   ==================================== */
.newgrads-lead {
  position: relative;
  z-index: 2;
  padding: 120px 20px 200px;
  background-image: url("../images/newgrads/line_art_illustration_01.jpg");
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: 60%;
  mix-blend-mode: multiply;
}

.newgrads-lead__container {
  max-width: 1200px;
  margin: 0 auto;
}

.newgrads-lead__title {
  font-family: "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: 500;
  color: var(--newgrads-color-text-dark);
  line-height: 1.6;
  margin-bottom: 50px;
}
.newgrads-lead__title span {
  display: block;
}

.newgrads-lead__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  line-height: 2.2;
  color: var(--newgrads-color-text-dark);
}
.newgrads-lead__text p {
  margin-bottom: 24px;
}
.newgrads-lead__text p:last-child {
  margin-bottom: 0;
}

.newgrads-lead__emphasis {
  font-weight: 500;
  margin-top: 30px;
}

/* ====================================
   Vision Section - ビジョンセクション
   ==================================== */
.newgrads-vision {
  position: relative;
  padding: 0;
  overflow: hidden;
}

.newgrads-vision__container {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
}

.newgrads-vision__card {
  position: relative;
  display: block;
  text-decoration: none;
  padding: 60px 60px 0;
  min-height: 600px;
}
.newgrads-vision__card:hover .newgrads-vision__image {
  transform: scale(1.03);
}

.newgrads-vision__card:nth-child(2) {
  margin-top: 100px;
}
@media screen and (max-width: 640px) {
  .newgrads-vision__card:nth-child(2) {
    margin-top: 0;
  }
}

.newgrads-vision__title {
  position: relative;
  font-family: "Noto Serif JP", serif;
  font-size: 42px;
  font-weight: 500;
  color: var(--newgrads-color-text-dark);
  line-height: 1.5;
  margin-bottom: -30px;
  margin-left: -30px;
  z-index: 1;
}
.newgrads-vision__title span {
  display: block;
}

.newgrads-vision__image-wrapper {
  position: relative;
  overflow: hidden;
}

.newgrads-vision__image {
  width: 100%;
  height: auto;
  display: block;
  transition: transform 0.4s ease;
}

.newgrads-vision__button {
  position: absolute;
  top: 400px;
  left: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 16px 40px;
  width: 280px;
  background-color: rgb(0, 0, 0);
  color: var(--color-white);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}
.newgrads-vision__button:hover {
  background-color: var(--newgrads-color-primary-blue);
  color: var(--color-white);
}
.newgrads-vision__button:active {
  color: var(--color-white);
}

/* ====================================
   INSIDE CN Section
   ==================================== */
.newgrads-inside-cn {
  padding: 100px 200px 100px;
  text-align: center;
}

.newgrads-inside-cn__title {
  text-align: center;
  position: relative;
  margin-bottom: 1rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 55px;
}
@media screen and (max-width: 640px) {
  .newgrads-inside-cn__title {
    font-size: 6vw;
  }
}
.newgrads-inside-cn__title img {
  display: block;
  margin: 0 auto;
}

.newgrads-inside-cn__subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: var(--newgrads-color-text-dark);
  line-height: 1.8;
  margin: 0;
  text-align: center;
}

/* ====================================
   3 Column Cards Section - 3カラムカード
   ==================================== */
.newgrads-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  background-color: #fff;
  margin-bottom: 100px;
}

.newgrads-card {
  display: flex;
  flex-direction: column;
  background: white;
  cursor: pointer;
  transition: opacity 0.3s ease;
}
.newgrads-card:hover {
  opacity: 0.85;
}

.newgrads-card__thumbnail {
  position: relative;
  width: 100%;
  height: 320px;
  overflow: hidden;
}
.newgrads-card__thumbnail::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  pointer-events: none;
}

.newgrads-card__thumbnail-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.newgrads-card:hover .newgrads-card__thumbnail-image {
  transform: scale(1.05);
}

.newgrads-card__title-area {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 0 0 80px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 1;
}

.newgrads-card__title-svg {
  height: 80px;
  width: 100%;
  object-fit: contain;
  display: block;
  max-width: none;
}

.newgrads-card__content {
  padding: 25px 30px 35px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.newgrads-card__description {
  display: none;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  line-height: 1.5;
  color: #333;
  margin: 0 0 25px 0;
  text-align: left;
}

.newgrads-card__arrow {
  margin-top: auto;
  text-align: center;
}
.newgrads-card__arrow svg {
  width: 39px;
  height: 14px;
}

/* ====================================
   Workstyle Section - はたらき方を知る (Legacy - kept for reference)
   ==================================== */
.newgrads-workstyle {
  padding: 100px 20px;
  background: linear-gradient(180deg, var(--newgrads-color-sky-blue) 0%, var(--color-white) 100%);
}

.newgrads-workstyle__container {
  max-width: 1200px;
  margin: 0 auto;
}

.newgrads-workstyle__title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--newgrads-color-text-dark);
  text-align: center;
  margin-bottom: 20px;
}

.newgrads-workstyle__lead {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  color: var(--newgrads-color-text-gray);
  text-align: center;
  margin-bottom: 60px;
}

.newgrads-workstyle__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}

.newgrads-workstyle__card {
  background: var(--color-white);
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.newgrads-workstyle__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
}

.newgrads-workstyle__card-image {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.newgrads-workstyle__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}
.newgrads-workstyle__card:hover .newgrads-workstyle__card-image img {
  transform: scale(1.05);
}

.newgrads-workstyle__card-content {
  padding: 24px;
}

.newgrads-workstyle__card-title {
  font-family: "Barlow Condensed", sans-serif;
  font-size: 24px;
  font-weight: 600;
  color: var(--newgrads-color-primary-blue);
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}

.newgrads-workstyle__card-subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  color: var(--newgrads-color-text-gray);
  margin-bottom: 16px;
}

.newgrads-workstyle__card-text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  line-height: 1.8;
  color: var(--newgrads-color-text-dark);
  margin: 0;
}

/* ====================================
   Talk Contents Section - トークコンテンツ
   ==================================== */
.newgrads-talk-contents {
  position: relative;
  padding: 0 0 100px;
  overflow: hidden;
}

.newgrads-talk-contents__clip-defs {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.newgrads-talk-contents__background {
  position: absolute;
  inset: 0;
  z-index: 1;
  clip-path: url(#talk-bg-clip-desktop);
}

.newgrads-talk-contents__background-image {
  width: 100%;
  height: 120%;
  object-fit: cover;
  object-position: center top;
  transform: translateY(0);
  will-change: transform;
}

.newgrads-talk-contents__wave {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  pointer-events: none;
}

.newgrads-talk-contents__wave--mobile {
  display: none;
}

.newgrads-talk-contents__header {
  position: relative;
  z-index: 3;
  text-align: center;
  padding: 180px 40px 80px;
}

.newgrads-talk-contents__title {
  margin: 0 0 20px;
}

.newgrads-talk-contents__title-svg {
  max-width: 590px;
  height: auto;
  margin-inline: auto;
}

.newgrads-talk-contents__subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  color: var(--color-white);
  margin: 0;
}

.newgrads-talk-contents__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5px;
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}

.newgrads-talk-contents__card {
  display: flex;
  flex-direction: column;
  background: white;
  cursor: pointer;
}
.newgrads-talk-contents__card:hover .newgrads-talk-contents__card-image img {
  transform: scale(1.05);
}

.newgrads-talk-contents__card-image {
  width: 100%;
  aspect-ratio: 120/56;
  overflow: hidden;
}
.newgrads-talk-contents__card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.newgrads-talk-contents__card-content {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 10%, rgb(255, 255, 255) 100%);
  padding: 30px 40px 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-top: -5em;
  position: relative;
  z-index: 2;
}

.newgrads-talk-contents__card-title {
  height: 48px;
  width: 100%;
  object-fit: contain;
  display: block;
  max-width: none;
  margin-bottom: 15px;
}

.newgrads-talk-contents__card-subtitle {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
  color: #333;
  margin: 0 0 20px;
}

.newgrads-talk-contents__card-arrow svg {
  width: 39px;
  height: 14px;
}

section.newgrads-talk-contents {
  margin-bottom: 120px;
}

/* ====================================
   Recruit CTA Section - 新卒募集要項
   ==================================== */
.newgrads-recruit-cta {
  position: relative;
  z-index: 0;
  padding: 80px 20px;
}

.newgrads-recruit-cta__container {
  position: relative;
  z-index: 1;
  max-width: 1000px;
  margin: 0 auto 50px;
  text-align: center;
}

.newgrads-recruit-cta__button {
  display: grid;
  align-items: center;
  justify-content: center;
  gap: 16px;
  width: 100%;
  padding: 24px 40px;
  border: 1px solid #333;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}
.newgrads-recruit-cta__button:hover {
  background-color: var(--newgrads-color-primary-blue);
  color: var(--color-white);
}

.newgrads-wave-bg-container {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 361px;
  z-index: 1;
}

.newgrads-recruit-cta__arrow {
  width: 20px;
  height: 20px;
  transition: transform 0.3s ease;
}
.newgrads-recruit-cta__button:hover .newgrads-recruit-cta__arrow {
  transform: translateX(4px);
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .newgrads-vision__container {
    grid-template-columns: 1fr;
    gap: 2px;
  }
  .newgrads-vision__card {
    padding: 40px 40px 0;
    min-height: 500px;
  }
  .newgrads-vision__title {
    font-size: 32px;
  }
  .newgrads-workstyle__cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .newgrads-inside-cn {
    padding: 80px 40px;
  }
  .newgrads-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .newgrads-hero {
    aspect-ratio: auto;
    height: auto;
    min-height: 100vw;
  }
  /* 背景スライダー：正方形100vw x 100vw、左右トリミング */
  .newgrads-hero__bg-swiper {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: 100vw;
    max-width: none;
    overflow: hidden;
  }
  .newgrads-hero__background-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
  }
  /* 人物サイズ：vwベース可変、少し上にはみ出す（120%拡大） */
  .newgrads-hero__person-image {
    width: clamp(288px, 84vw, 600px);
    max-height: 120%;
    margin-right: 0;
  }
  .newgrads-hero__person-container {
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: 100%;
    display: flex;
    justify-content: center;
  }
  .newgrads-hero__person-swiper {
    width: 100%;
  }
  .newgrads-hero__person-swiper .swiper-slide {
    justify-content: center;
  }
  .newgrads-hero__copy-svg {
    max-width: 90%;
  }
  .newgrads-hero__copy-text {
    max-width: 80%;
  }
  .newgrads-hero__title {
    bottom: 100px;
  }
  .newgrads-hero__title-handwritten {
    font-size: 20px;
  }
  .newgrads-lead {
    padding: 80px 20px;
  }
  .newgrads-lead__title {
    font-size: 26px;
  }
  .newgrads-lead__text {
    font-size: 14px;
    text-align: left;
  }
  .newgrads-vision__card {
    padding: 30px 20px 0;
    min-height: 400px;
  }
  .newgrads-vision__title {
    font-size: 5vw;
    margin-bottom: 1em;
    margin-left: 0;
  }
  .newgrads-vision__button {
    top: auto;
    bottom: 2.5em;
    padding: 0.75em 1em;
    font-size: 3vw;
  }
  .newgrads-workstyle {
    padding: 80px 20px;
  }
  .newgrads-workstyle__title {
    font-size: 26px;
  }
  .newgrads-workstyle__cards {
    grid-template-columns: 1fr;
  }
  .newgrads-inside-cn {
    padding: 60px 20px;
  }
  .newgrads-cards {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-bottom: 60px;
  }
  .newgrads-card__thumbnail {
    height: auto;
  }
  .newgrads-card__title-area {
    padding: 0 0 40px;
  }
  .newgrads-card__title-svg {
    height: 60px;
  }
  .newgrads-card__content {
    padding: 20px;
  }
  .newgrads-talk-contents {
    padding: 0 20px 60px;
  }
  .newgrads-talk-contents__background {
    clip-path: url(#talk-bg-clip-mobile);
  }
  .newgrads-talk-contents__wave--desktop {
    display: none;
  }
  .newgrads-talk-contents__wave--mobile {
    display: block;
  }
  .newgrads-talk-contents__header {
    padding: 120px 20px 60px;
  }
  .newgrads-talk-contents__title-svg {
    max-width: 80%;
  }
  .newgrads-talk-contents__cards {
    grid-template-columns: 1fr;
    gap: 20px;
    max-width: 500px;
  }
  .newgrads-talk-contents__card-content {
    padding: 30px 40px 20px;
    margin-top: -5em;
  }
  .newgrads-recruit-cta {
    padding: 60px 20px;
  }
  .newgrads-recruit-cta__button {
    font-size: 16px;
    padding: 20px 30px;
  }
}
.page-project-story .project-hero {
  position: relative;
  height: 70vh;
  min-height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.page-project-story .project-hero__background {
  position: absolute;
  inset: 0;
  z-index: 1;
}
.page-project-story .project-hero__background-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-project-story .project-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.5));
  z-index: 2;
}
.page-project-story .project-hero__content {
  position: relative;
  z-index: 3;
  text-align: center;
  color: var(--color-white);
  padding: 0 var(--spacing-md);
}
.page-project-story .project-hero__label {
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  letter-spacing: 0.2em;
  margin-bottom: var(--spacing-sm);
}
.page-project-story .project-hero__title {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-xs);
}
.page-project-story .project-hero__title-ja {
  font-family: var(--font-family-serif);
  font-size: clamp(28px, 5vw, 48px);
  font-weight: var(--font-weight-bold);
}
.page-project-story .project-hero__title-sub {
  font-size: var(--font-size-body);
  font-weight: var(--font-weight-regular);
}
.page-project-story .project-lead {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-white);
}
.page-project-story .project-lead__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
  text-align: center;
}
.page-project-story .project-lead__title {
  font-family: var(--font-family-serif);
  font-size: clamp(24px, 4vw, 36px);
  line-height: var(--line-height-heading);
  margin-bottom: var(--spacing-lg);
}
.page-project-story .project-lead__title span {
  display: block;
}
.page-project-story .project-lead__text {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  color: var(--color-dark-gray);
  max-width: 800px;
  margin: 0 auto;
}
.page-project-story .project-overview {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-light-gray);
}
.page-project-story .project-overview__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
}
.page-project-story .project-overview__heading {
  text-align: center;
  margin-bottom: var(--spacing-xl);
}
.page-project-story .project-overview__heading-en {
  display: block;
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  color: var(--color-primary-blue);
  letter-spacing: 0.2em;
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-overview__heading-ja {
  display: block;
  font-family: var(--font-family-serif);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
}
.page-project-story .project-overview__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-xl);
  align-items: start;
}
@media (max-width: 768px) {
  .page-project-story .project-overview__content {
    grid-template-columns: 1fr;
  }
}
.page-project-story .project-overview__image img {
  width: 100%;
  border-radius: var(--radius-md);
}
.page-project-story .project-overview__list {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md);
}
.page-project-story .project-overview__item {
  display: flex;
  border-bottom: 1px solid var(--color-gray);
  padding-bottom: var(--spacing-sm);
}
.page-project-story .project-overview__item dt {
  font-weight: var(--font-weight-bold);
  min-width: 120px;
  color: var(--color-primary-blue);
}
.page-project-story .project-overview__item dd {
  color: var(--color-black);
}
.page-project-story .project-challenge {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-white);
}
.page-project-story .project-challenge__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
}
.page-project-story .project-challenge__heading {
  text-align: center;
  margin-bottom: var(--spacing-xl);
}
.page-project-story .project-challenge__heading-en {
  display: block;
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  color: var(--color-primary-blue);
  letter-spacing: 0.2em;
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-challenge__heading-ja {
  display: block;
  font-family: var(--font-family-serif);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
}
.page-project-story .project-challenge__content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-xl);
  align-items: center;
}
@media (max-width: 768px) {
  .page-project-story .project-challenge__content {
    grid-template-columns: 1fr;
  }
}
.page-project-story .project-challenge__text p {
  margin-bottom: var(--spacing-md);
  line-height: var(--line-height-body);
}
.page-project-story .project-challenge__list {
  list-style: none;
  padding: 0;
}
.page-project-story .project-challenge__list li {
  position: relative;
  padding-left: var(--spacing-md);
  margin-bottom: var(--spacing-sm);
}
.page-project-story .project-challenge__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  background: var(--color-primary-blue);
  border-radius: var(--radius-circle);
}
.page-project-story .project-challenge__image img {
  width: 100%;
  border-radius: var(--radius-md);
}
.page-project-story .project-solution {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-primary-blue);
  color: var(--color-white);
}
.page-project-story .project-solution__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
}
.page-project-story .project-solution__heading {
  text-align: center;
  margin-bottom: var(--spacing-xl);
}
.page-project-story .project-solution__heading-en {
  display: block;
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  letter-spacing: 0.2em;
  opacity: 0.8;
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-solution__heading-ja {
  display: block;
  font-family: var(--font-family-serif);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
}
.page-project-story .project-solution__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-lg);
}
@media (max-width: 768px) {
  .page-project-story .project-solution__cards {
    grid-template-columns: 1fr;
  }
}
.page-project-story .project-solution-card {
  background: rgba(255, 255, 255, 0.1);
  padding: var(--spacing-lg);
  border-radius: var(--radius-md);
}
.page-project-story .project-solution-card__number {
  font-family: var(--font-family-en);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  opacity: 0.5;
  margin-bottom: var(--spacing-sm);
}
.page-project-story .project-solution-card__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-sm);
}
.page-project-story .project-solution-card__desc {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  opacity: 0.9;
}
.page-project-story .project-team {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-light-gray);
}
.page-project-story .project-team__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
}
.page-project-story .project-team__heading {
  text-align: center;
  margin-bottom: var(--spacing-xl);
}
.page-project-story .project-team__heading-en {
  display: block;
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  color: var(--color-primary-blue);
  letter-spacing: 0.2em;
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-team__heading-ja {
  display: block;
  font-family: var(--font-family-serif);
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
}
.page-project-story .project-team__members {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--spacing-xl);
}
@media (max-width: 768px) {
  .page-project-story .project-team__members {
    grid-template-columns: 1fr;
  }
}
.page-project-story .project-team-member {
  display: flex;
  gap: var(--spacing-md);
  background: var(--color-white);
  padding: var(--spacing-lg);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-default);
}
.page-project-story .project-team-member__image {
  flex-shrink: 0;
  width: 120px;
  height: 120px;
  border-radius: var(--radius-circle);
  overflow: hidden;
}
.page-project-story .project-team-member__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.page-project-story .project-team-member__content {
  flex: 1;
}
.page-project-story .project-team-member__position {
  font-size: var(--font-size-small);
  color: var(--color-primary-blue);
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-team-member__name {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-sm);
}
.page-project-story .project-team-member__comment {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  color: var(--color-dark-gray);
}
.page-project-story .project-cta {
  padding: var(--spacing-xxl) var(--spacing-md);
  background: var(--color-white);
}
.page-project-story .project-cta__container {
  max-width: var(--max-width-container);
  margin: 0 auto;
}
.page-project-story .project-cta__heading {
  text-align: center;
  font-family: var(--font-family-serif);
  font-size: var(--font-size-h2);
  margin-bottom: var(--spacing-xl);
}
.page-project-story .project-cta__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-lg);
}
@media (max-width: 768px) {
  .page-project-story .project-cta__grid {
    grid-template-columns: 1fr;
  }
}
.page-project-story .project-cta-card {
  display: block;
  padding: var(--spacing-lg);
  background: var(--color-light-gray);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-black);
  transition: var(--transition-base);
}
.page-project-story .project-cta-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
}
.page-project-story .project-cta-card--highlight {
  background: var(--color-primary-blue);
  color: var(--color-white);
}
.page-project-story .project-cta-card__label {
  font-family: var(--font-family-en);
  font-size: var(--font-size-small);
  letter-spacing: 0.1em;
  opacity: 0.7;
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-cta-card__title {
  font-size: var(--font-size-h3);
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--spacing-xs);
}
.page-project-story .project-cta-card__icon {
  font-size: 24px;
  margin-top: var(--spacing-sm);
}

/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --psi-color-primary-blue: #24a4db;
  --psi-color-dark-blue: #165ea3;
  --psi-color-accent-yellow: #f3fe01;
  --psi-color-text-dark: #000;
  --psi-color-text-gray: #333;
  --psi-color-bg-white: #fff;
}

/* ====================================
   Main Section - メインキャッチコピー
   ==================================== */
.psi-main {
  padding: 20px 20px 60px;
  background-color: var(--psi-color-bg-white);
}

.psi-main__container {
  max-width: 1200px;
  margin: 0 auto;
}

.psi-main__catchcopy {
  font-family: "Noto Serif JP", serif;
  font-size: 70px;
  font-weight: 400;
  color: var(--psi-color-text-dark);
  line-height: 1.29;
  margin: 0;
}
.psi-main__catchcopy span {
  display: block;
}

/* ====================================
   Lead Section - リード文
   ==================================== */
.psi-lead {
  padding: 0 20px 60px;
  background-color: var(--psi-color-bg-white);
}

.psi-lead__container {
  max-width: 1200px;
  margin: 0 auto;
}

.psi-lead__text {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: var(--psi-color-text-dark);
  line-height: 2.125;
  margin: 0;
}

.psi-lead__br--pc {
  display: block;
}

/* ====================================
   Projects Section - プロジェクト一覧
   ==================================== */
.psi-projects {
  padding: 0 20px 100px;
}

.psi-projects__container {
  max-width: 1200px;
  margin: 0 auto;
}

.psi-projects__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px;
}

/* ====================================
   Project Card - プロジェクトカード
   ==================================== */
.psi-project-card {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s ease;
}
.psi-project-card:hover {
  transform: translateY(-8px);
}
.psi-project-card:hover .psi-project-card__image img {
  transform: scale(1.05);
}

.psi-project-card__thumbnail {
  position: relative;
  aspect-ratio: 571/411;
  overflow: visible;
  margin-bottom: 120px;
}

.psi-project-card__image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.psi-project-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.psi-project-card__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}
.psi-project-card__overlay img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.psi-project-card__number {
  position: absolute;
  bottom: -100px;
  left: 20px;
  z-index: 2;
}
@media (max-width: 768px) {
  .psi-project-card__number {
    bottom: -10vw;
  }
}

.psi-project-card__number-text {
  display: grid;
  font-family: "Barlow Condensed", sans-serif;
  font-size: 180px;
  font-weight: 400;
  width: 160px;
  place-items: center;
  place-content: center;
  color: var(--psi-color-text-dark);
  line-height: 1;
  background-color: var(--psi-color-bg-white);
}

.psi-project-card__number-line {
  display: block;
  width: 100%;
  height: 4px;
  background-color: var(--psi-color-accent-yellow);
}

.psi-project-card__content {
  padding-left: 15px;
}

.psi-project-card__title {
  font-family: "Noto Serif JP", serif;
  font-size: 41px;
  font-weight: 500;
  color: var(--psi-color-text-dark);
  line-height: 1.46;
  margin: 0 0 8px;
}
.psi-project-card__title span {
  display: block;
}

.psi-project-card__subtitle {
  font-family: "Noto Serif JP", serif;
  font-size: 18px;
  font-weight: 500;
  color: var(--psi-color-text-dark);
  line-height: 1.5;
  margin: 0;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .psi-main__catchcopy {
    font-size: 56px;
  }
  .psi-project-card__number-text {
    font-size: 140px;
  }
  .psi-project-card__title {
    font-size: 32px;
  }
  .psi-projects__grid {
    gap: 40px;
  }
}
@media (max-width: 768px) {
  .psi-main {
    padding: 60px 20px;
  }
  .psi-main__catchcopy {
    font-size: 42px;
    text-align: center;
  }
  .psi-lead {
    padding: 0 20px 60px;
  }
  .psi-lead__text {
    font-size: 15px;
    line-height: 2;
    text-align: left;
  }
  .psi-lead__br--pc {
    display: none;
  }
  .psi-projects {
    padding: 0 20px 80px;
  }
  .psi-projects__grid {
    grid-template-columns: 1fr;
    gap: 60px;
  }
  .psi-project-card__thumbnail {
    margin-bottom: 80px;
  }
  .psi-project-card__number-text {
    font-size: 100px;
    padding: 0 15px 15px 0;
  }
  .psi-project-card__number-line {
    width: 80px;
    height: 3px;
    margin-left: 15px;
  }
  .psi-project-card__title {
    font-size: 28px;
  }
  .psi-project-card__subtitle {
    font-size: 14px;
  }
}
@media (max-width: 480px) {
  .psi-project-card__thumbnail {
    margin-bottom: 60px;
  }
  .psi-main {
    padding: 10vw 0;
  }
  .psi-main__catchcopy {
    font-size: 6vw;
  }
  .psi-project-card__number-text {
    font-size: 20vw;
    width: 22vw;
  }
  .psi-project-card__number-line {
    width: 60px;
  }
  .psi-project-card__title {
    font-size: 24px;
  }
  .psi-project-card__subtitle {
    font-size: 13px;
  }
}
/* Keywords Page Styles - はたらく環境を知る */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --keywords-color-primary-blue: #24A4DB;
  --keywords-color-cn-blue: #165EA3;
  --keywords-color-accent-yellow: #EEFF00;
  --keywords-color-text-dark: #000000;
  --keywords-color-text-body: #000000;
  --keywords-color-border-yellow: #F3FE01;
}

/* ====================================
   Page Header - ページヘッダー
   ==================================== */
.keywords-page-header {
  position: relative;
  width: 100%;
  padding: 150px 20px 60px;
  margin-top: var(--header-height);
  text-align: center;
}
.keywords-page-header::before {
  content: "";
  position: absolute;
  top: -50%;
  left: 0;
  right: 0;
  height: 100vw;
  background: url("../images/common/ribon-header.png") no-repeat right top/100%;
  z-index: 0;
  pointer-events: none;
}
@media screen and (max-width: 640px) {
  .keywords-page-header::before {
    top: 0;
  }
}

.keywords-page-header__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.keywords-page-header__title {
  font-family: var(--font-family-base);
  font-size: 36.351px;
  font-weight: 400;
  color: var(--keywords-color-text-dark);
  margin: 0;
  line-height: normal;
}

.keywords-page-header__subtitle {
  font-family: var(--font-family-en);
  font-size: 21.745px;
  font-weight: 400;
  color: var(--keywords-color-text-dark);
  margin: 0;
  line-height: normal;
}

.keywords-page-header__line {
  display: block;
  width: 60px;
  height: 2px;
  background-color: var(--keywords-color-accent-yellow);
  margin-top: 10px;
}

/* ====================================
   Main Section - メインセクション
   ==================================== */
.keywords-main {
  position: relative;
  padding: 60px 20px 120px;
  overflow: hidden;
}

.keywords-main__container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* ====================================
   Header - ヘッダー部分
   ==================================== */
.keywords-main__header {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: start;
  margin-bottom: 60px;
}

.keywords-main__header-left {
  min-width: 0;
}

.keywords-main__title {
  margin: 0 0 40px;
}
.keywords-main__title img {
  display: block;
  width: 100%;
  max-width: 709px;
  height: auto;
}

.keywords-main__intro {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--keywords-color-text-body);
  line-height: 34px;
  margin: 0;
}

.keywords-main__visual {
  flex-shrink: 0;
}
.keywords-main__visual img {
  width: 340px;
  height: auto;
}

/* ====================================
   Keywords Cards - キーワードカード
   ==================================== */
.keywords-cards {
  display: flex;
  flex-direction: column;
  gap: 35px;
  margin-bottom: 80px;
}

.keywords-cards__row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px;
}

.keywords-card {
  border: 2px solid var(--keywords-color-border-yellow);
  padding: 40px 30px;
  min-height: 440px;
  display: flex;
  flex-direction: column;
}

.keywords-card__title {
  font-family: var(--font-family-base);
  font-size: 30px;
  font-weight: 700;
  color: var(--keywords-color-cn-blue);
  line-height: 40px;
  margin: 0 0 24px 0;
  text-align: center;
  min-height: 80px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.keywords-card__title--two-line span {
  display: block;
}
.keywords-card__title--large {
  font-size: 60px;
  letter-spacing: -6.4px;
  line-height: 1;
  gap: 4px;
}

.keywords-card__subtitle {
  font-size: 20px;
  font-weight: 400;
  letter-spacing: normal;
  line-height: 1;
}

.keywords-card__text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--keywords-color-text-body);
  line-height: 32px;
  margin: 0;
  flex: 1;
}

.keywords-card__note {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--keywords-color-text-body);
  line-height: 32px;
  margin: 16px 0 0 0;
}

.keywords-card--chart .keywords-card__chart {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.keywords-card--chart .keywords-card__chart img {
  max-width: 100%;
  height: auto;
}

/* ====================================
   Message Box - メッセージボックス
   ==================================== */
.keywords-message {
  display: flex;
  align-items: center;
  gap: 0;
}

.keywords-message__image {
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}
.keywords-message__image img {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
}

.keywords-message__bubble {
  position: relative;
  flex: 1;
  border: 2px solid var(--keywords-color-primary-blue);
  border-radius: 15px;
  padding: 40px 50px 40px 60px;
  margin-left: 30px;
  background: #fff;
}
.keywords-message__bubble::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translate(-100%, -50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 14px 18px 14px 0;
  border-color: transparent var(--keywords-color-primary-blue) transparent transparent;
}
.keywords-message__bubble::after {
  content: "";
  position: absolute;
  left: 2px;
  top: 50%;
  transform: translate(-100%, -50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 16px 12px 0;
  border-color: transparent #fff transparent transparent;
}

.keywords-message__content p {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--keywords-color-text-body);
  line-height: 34px;
  margin: 0;
}
.keywords-message__content p + p {
  margin-top: 0;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .keywords-main__header {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .keywords-main__visual {
    display: flex;
    justify-content: center;
  }
  .keywords-main__visual img {
    width: 280px;
  }
  .keywords-cards__row {
    grid-template-columns: repeat(2, 1fr);
  }
  .keywords-card {
    min-height: 380px;
    padding: 32px 24px;
  }
  .keywords-card__title {
    font-size: 28px;
    min-height: 72px;
  }
  .keywords-card__title--large {
    font-size: 64px;
  }
  .keywords-card__subtitle {
    font-size: 18px;
  }
  .keywords-message {
    flex-direction: column;
    align-items: center;
    gap: 0;
  }
  .keywords-message__image img {
    width: 140px;
    height: 140px;
  }
  .keywords-message__bubble {
    margin-left: 0;
    margin-top: -30px;
    padding: 50px 30px 30px;
  }
  .keywords-message__bubble::before, .keywords-message__bubble::after {
    display: none;
  }
}
@media (max-width: 768px) {
  .keywords-page-header {
    padding: 120px 20px 40px;
    margin-top: 80px;
  }
  .keywords-page-header__title {
    font-size: 28px;
  }
  .keywords-page-header__subtitle {
    font-size: 16px;
  }
  .keywords-main {
    padding: 40px 20px 80px;
  }
  .keywords-main__title img {
    width: 100%;
    max-width: 400px;
  }
  .keywords-main__intro {
    font-size: 15px;
    line-height: 28px;
  }
  .keywords-cards {
    gap: 24px;
  }
  .keywords-cards__row {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .keywords-card {
    min-height: auto;
    padding: 28px 20px;
  }
  .keywords-card__title {
    font-size: 24px;
    line-height: 32px;
    margin-bottom: 16px;
    min-height: 64px;
  }
  .keywords-card__title--large {
    font-size: 56px;
  }
  .keywords-card__subtitle {
    font-size: 16px;
  }
  .keywords-card__text {
    font-size: 15px;
    line-height: 28px;
  }
  .keywords-message__bubble {
    padding: 30px 20px 20px;
    border-radius: 10px;
  }
  .keywords-message__content p {
    font-size: 15px;
    line-height: 28px;
  }
  .keywords-message__image img {
    width: 100px;
    height: 100px;
  }
}
@media (max-width: 480px) {
  .keywords-page-header {
    padding: 100px 20px 30px;
  }
  .keywords-page-header__title {
    font-size: 24px;
  }
  .keywords-page-header__subtitle {
    font-size: 14px;
  }
  .keywords-main__title img {
    max-width: 280px;
  }
  .keywords-main__visual img {
    width: 200px;
  }
  .keywords-card__title {
    font-size: 20px;
    line-height: 28px;
    min-height: 56px;
  }
  .keywords-card__title--large {
    font-size: 48px;
  }
  .keywords-card__subtitle {
    font-size: 14px;
  }
  .keywords-card__text {
    font-size: 14px;
    line-height: 26px;
  }
  .keywords-message__content p {
    font-size: 14px;
    line-height: 26px;
  }
}
/* Cross Talk Page Styles - 先輩後輩クロストーク */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --crosstalk-color-primary-blue: #24a4db;
  --crosstalk-color-accent-yellow: #eeff00;
  --crosstalk-color-text-dark: #000000;
  --crosstalk-color-text-body: #000000;
}

/* ====================================
   Main Visual - CROSS TALK
   ==================================== */
.crosstalk-page-header + .page-key-visual::after {
  content: none;
}
.crosstalk-page-header + .page-key-visual img {
  border-radius: 0;
}

.crosstalk-main {
  padding: 30px 20px 80px;
}

.crosstalk-main__container {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.crosstalk-main__intro {
  text-align: left;
  margin-bottom: 80px;
}

.crosstalk-main__title {
  font-family: var(--font-family-en);
  font-size: 106px;
  font-weight: 400;
  color: var(--crosstalk-color-text-dark);
  line-height: normal;
  margin: 0 0 60px 0;
  letter-spacing: 0.02em;
}

.crosstalk-main__profiles {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 60px;
}

.crosstalk-main__profile {
  text-align: center;
  flex: 1;
}

.crosstalk-main__profile-image {
  width: 250px;
  height: 250px;
  overflow: hidden;
  margin: 0 auto 20px;
}
.crosstalk-main__profile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.crosstalk-main__profile-dept {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--crosstalk-color-text-dark);
  line-height: 40px;
  margin: 0;
}

.crosstalk-main__profile-name {
  font-family: var(--font-family-base);
  font-size: 23px;
  font-weight: 700;
  color: var(--crosstalk-color-primary-blue);
  line-height: 40px;
  margin: 0;
}

.crosstalk-main__profile-year {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--crosstalk-color-text-dark);
  line-height: 28px;
  margin: 0;
}

.crosstalk-main__cross {
  --crosstalk-cross-size: 100px;
  --crosstalk-cross-stroke: 2px;
  width: var(--crosstalk-cross-size);
  height: var(--crosstalk-cross-size);
  position: relative;
  flex-shrink: 0;
  margin-top: calc((250px - var(--crosstalk-cross-size)) / 2);
}
.crosstalk-main__cross::before, .crosstalk-main__cross::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: var(--crosstalk-cross-stroke);
  background-color: var(--crosstalk-color-primary-blue);
  border-radius: calc(var(--crosstalk-cross-stroke) / 2);
  transform-origin: center;
}
.crosstalk-main__cross::before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.crosstalk-main__cross::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

/* ====================================
   Intro Section - イントロダクション
   ==================================== */
.crosstalk-intro {
  padding: 0 20px 80px;
}

.crosstalk-intro__container {
  max-width: 1180px;
  margin: 0 auto;
}

.crosstalk-intro__text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--crosstalk-color-text-body);
  line-height: 34px;
  margin: 0;
}

/* ====================================
   Content Section - 対談コンテンツ
   ==================================== */
.crosstalk-content {
  position: relative;
  padding: 60px 20px 120px;
  overflow: hidden;
}

.crosstalk-content__container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* ====================================
   Section - 対談セクション
   ==================================== */
.crosstalk-section {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 60px;
  margin-bottom: 80px;
  align-items: start;
}
.crosstalk-section:last-of-type {
  margin-bottom: 0;
}

.crosstalk-section__heading {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.crosstalk-section__line {
  display: block;
  width: 2px;
  height: 112px;
  background-color: var(--crosstalk-color-primary-blue);
  flex-shrink: 0;
  margin-top: 8px;
}

.crosstalk-section__title {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--crosstalk-color-text-dark);
  line-height: 40px;
  margin: 0;
}
.crosstalk-section__title span {
  display: block;
}

.crosstalk-section__body {
  max-width: 800px;
}

.crosstalk-section__question {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--crosstalk-color-primary-blue);
  line-height: 40px;
  margin: 0 0 20px 0;
}

/* ====================================
   Message - 発言
   ==================================== */
.crosstalk-message {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 50px;
}
.crosstalk-message:last-child {
  margin-bottom: 0;
}

.crosstalk-message__speaker {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 64px;
}

.crosstalk-message__icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
}
.crosstalk-message__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.crosstalk-message__name {
  font-family: var(--font-family-base);
  font-size: 14px;
  font-weight: 700;
  color: var(--crosstalk-color-primary-blue);
  line-height: 1.4;
  margin: 8px 0 0 0;
  text-align: center;
  white-space: nowrap;
}

.crosstalk-message__text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--crosstalk-color-text-body);
  line-height: 34px;
  margin: 0;
  flex: 1;
}

/* ====================================
   Image - 画像
   ==================================== */
.crosstalk-image {
  margin: 60px 0 100px;
  position: relative;
}
.crosstalk-image--right {
  margin-left: auto;
  width: fit-content;
  padding-right: 0;
}
.crosstalk-image--full {
  width: 100%;
  margin: 60px 0 0;
}
.crosstalk-image img {
  display: block;
  width: 800px;
  height: 400px;
  object-fit: cover;
  border-radius: 0;
}
.crosstalk-image--full img {
  width: 100%;
  height: 411px;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .crosstalk-section {
    grid-template-columns: 280px 1fr;
    gap: 40px;
  }
  .crosstalk-main__title {
    font-size: 72px;
  }
  .crosstalk-main__profiles {
    gap: 40px;
  }
  .crosstalk-main__profile-image {
    width: 200px;
    height: 200px;
  }
  .crosstalk-main__cross {
    --crosstalk-cross-size: 60px;
    --crosstalk-cross-stroke: 5px;
    margin-top: calc((200px - var(--crosstalk-cross-size)) / 2);
  }
  .crosstalk-image img {
    width: 100%;
    max-width: 800px;
    height: auto;
    aspect-ratio: 2/1;
  }
}
@media (max-width: 768px) {
  .crosstalk-main {
    padding: 40px 20px 60px;
  }
  .crosstalk-main__title {
    font-size: 48px;
    margin-bottom: 40px;
  }
  .crosstalk-main__profiles {
    gap: 0;
  }
  .crosstalk-main__profile-image {
    width: 22vw;
    height: 22vw;
    margin-bottom: 2vw;
  }
  .crosstalk-main__profile-dept {
    font-size: 3vw;
    line-height: 1.6;
  }
  .crosstalk-main__profile-name {
    font-size: 4vw;
    line-height: 1.4;
  }
  .crosstalk-main__profile-year {
    font-size: 3vw;
    line-height: 1.4;
  }
  .crosstalk-main__cross {
    --crosstalk-cross-size: 8vw;
    --crosstalk-cross-stroke: 2px;
    margin-top: calc((22vw - var(--crosstalk-cross-size)) / 2);
  }
  .crosstalk-intro {
    padding: 0 20px 60px;
  }
  .crosstalk-intro__text {
    font-size: 15px;
    line-height: 28px;
  }
  .crosstalk-intro__text br {
    display: none;
  }
  .crosstalk-content {
    padding: 40px 20px 80px;
  }
  .crosstalk-section {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 60px;
  }
  .crosstalk-section__heading {
    gap: 12px;
  }
  .crosstalk-section__line {
    height: 80px;
  }
  .crosstalk-section__title {
    font-size: 20px;
    line-height: 32px;
  }
  .crosstalk-section__question {
    font-size: 14px;
    line-height: 32px;
    margin-bottom: 16px;
  }
  .crosstalk-message {
    gap: 12px;
    margin-bottom: 24px;
  }
  .crosstalk-message__speaker {
    width: 48px;
  }
  .crosstalk-message__icon {
    width: 48px;
    height: 48px;
  }
  .crosstalk-message__name {
    font-size: 12px;
    margin-top: 6px;
  }
  .crosstalk-message__text {
    font-size: 15px;
    line-height: 28px;
  }
  .crosstalk-image {
    margin: 40px 0 60px;
  }
  .crosstalk-image--right {
    margin-left: 0;
    width: 100%;
  }
  .crosstalk-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 2/1;
  }
  .crosstalk-image--full img {
    height: auto;
    aspect-ratio: 3/1;
  }
}
@media (max-width: 480px) {
  .crosstalk-main__title {
    font-size: 36px;
    margin-bottom: 30px;
  }
  .crosstalk-section__title {
    font-size: 18px;
    line-height: 28px;
  }
  .crosstalk-message__speaker {
    width: 40px;
  }
  .crosstalk-message__icon {
    width: 40px;
    height: 40px;
  }
  .crosstalk-message__name {
    font-size: 11px;
    margin-top: 4px;
  }
  .crosstalk-message__text {
    font-size: 14px;
    line-height: 26px;
  }
}
/* Discussion Page Styles - はたらく環境ディスカッション */
/* ====================================
   Variables - 変数
   ==================================== */
:root {
  --discussion-color-primary-blue: #24a4db;
  --discussion-color-accent-yellow: #eeff00;
  --discussion-color-text-dark: #000000;
  --discussion-color-text-body: #000000;
}

/* ====================================
   Page Header - ページヘッダー
   ==================================== */
.discussion-page-header + .page-key-visual::after {
  content: none;
}
.discussion-page-header + .page-key-visual img {
  border-radius: 0;
}

/* ====================================
   Main Visual - DISCUSSION
   ==================================== */
.discussion-main {
  padding: 30px 20px 80px;
}

.discussion-main__container {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.discussion-main__intro {
  text-align: left;
  margin-bottom: 80px;
}

.discussion-main__title {
  font-family: var(--font-family-en);
  font-size: 106px;
  font-weight: 400;
  color: var(--discussion-color-text-dark);
  line-height: normal;
  margin: 0 0 60px 0;
  letter-spacing: 0.02em;
}

.discussion-main__profiles {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 80px;
}

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

.discussion-main__profile-image {
  width: 250px;
  height: 250px;
  overflow: hidden;
  margin: 0 auto 20px;
}
.discussion-main__profile-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.discussion-main__profile-dept {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--discussion-color-text-dark);
  line-height: 40px;
  margin: 0;
}

.discussion-main__profile-name {
  font-family: var(--font-family-base);
  font-size: 23px;
  font-weight: 700;
  color: var(--discussion-color-primary-blue);
  line-height: 40px;
  margin: 0;
}

.discussion-main__profile-year {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--discussion-color-text-dark);
  line-height: 28px;
  margin: 0;
}

/* ====================================
   Intro Section - イントロダクション
   ==================================== */
.discussion-intro {
  padding: 0 20px 80px;
}

.discussion-intro__container {
  max-width: 1180px;
  margin: 0 auto;
}

.discussion-intro__text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--discussion-color-text-body);
  line-height: 34px;
  margin: 0;
}

/* ====================================
   Content Section - 対談コンテンツ
   ==================================== */
.discussion-content {
  position: relative;
  padding: 60px 20px 120px;
  overflow: hidden;
}

.discussion-content__container {
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

/* 背景装飾（曲線） */
.discussion-content__decoration {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}
.discussion-content__decoration--top {
  top: -328px;
  left: -70%;
  right: -48%;
  height: 1664px;
  background: linear-gradient(135deg, rgba(36, 164, 219, 0.05) 0%, rgba(22, 149, 163, 0.03) 100%);
  transform: rotate(-19deg);
}
.discussion-content__decoration--bottom {
  bottom: -200px;
  left: -7%;
  right: -12%;
  height: 836px;
  background: linear-gradient(135deg, rgba(36, 164, 219, 0.05) 0%, rgba(22, 149, 163, 0.03) 100%);
  transform: rotate(-10deg);
}

/* ====================================
   Section - 対談セクション
   ==================================== */
.discussion-section {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 60px;
  margin-bottom: 80px;
  align-items: start;
}
.discussion-section:last-of-type {
  margin-bottom: 0;
}
.discussion-section--message .discussion-section__heading {
  display: none;
}
.discussion-section--message {
  grid-template-columns: 340px 1fr;
}
.discussion-section--message .discussion-section__body {
  grid-column: 2;
}

.discussion-section__heading {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.discussion-section__line {
  display: block;
  width: 2px;
  height: 112px;
  background-color: var(--discussion-color-primary-blue);
  flex-shrink: 0;
  margin-top: 8px;
}
.discussion-section__line--short {
  height: 40px;
}

.discussion-section__title {
  font-family: var(--font-family-base);
  font-size: 24px;
  font-weight: 700;
  color: var(--discussion-color-text-dark);
  line-height: 40px;
  margin: 0;
}
.discussion-section__title span {
  display: block;
}
.discussion-section__title--single {
  display: none;
}

.discussion-section__body {
  max-width: 800px;
}

.discussion-section__question {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 700;
  color: var(--discussion-color-primary-blue);
  line-height: 40px;
  margin: 0 0 20px 0;
}

/* ====================================
   Message - 発言
   ==================================== */
.discussion-message {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 50px;
}
.discussion-message:last-child {
  margin-bottom: 0;
}

.discussion-message__speaker {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 64px;
}

.discussion-message__icon {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  overflow: hidden;
}
.discussion-message__icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.discussion-message__name {
  font-family: var(--font-family-base);
  font-size: 14px;
  font-weight: 700;
  color: var(--discussion-color-primary-blue);
  line-height: 1.4;
  margin: 8px 0 0 0;
  text-align: center;
  white-space: nowrap;
}

.discussion-message__text {
  font-family: var(--font-family-base);
  font-size: 16px;
  font-weight: 400;
  color: var(--discussion-color-text-body);
  line-height: 34px;
  margin: 0;
  flex: 1;
}

/* ====================================
   Image - 画像
   ==================================== */
.discussion-image {
  margin: 60px 0 100px;
  position: relative;
}
.discussion-image--right {
  margin-left: auto;
  width: fit-content;
  padding-right: 0;
}
.discussion-image--full {
  width: 100%;
  margin: 60px 0 0;
}
.discussion-image img {
  display: block;
  width: 800px;
  height: 400px;
  object-fit: cover;
  border-radius: 0;
}
.discussion-image--full img {
  width: 100%;
  height: 411px;
}

/* ====================================
   Responsive Design
   ==================================== */
@media (max-width: 1024px) {
  .discussion-section {
    grid-template-columns: 280px 1fr;
    gap: 40px;
  }
  .discussion-main__title {
    font-size: 72px;
  }
  .discussion-main__profiles {
    gap: 40px;
  }
  .discussion-main__profile-image {
    width: 200px;
    height: 200px;
  }
  .discussion-image img {
    width: 100%;
    max-width: 800px;
    height: auto;
    aspect-ratio: 2/1;
  }
}
@media (max-width: 768px) {
  .discussion-main {
    padding: 40px 20px 60px;
  }
  .discussion-main__title {
    font-size: 48px;
    margin-bottom: 40px;
  }
  .discussion-main__profiles {
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
  .discussion-main__profile-image {
    width: 160px;
    height: 160px;
  }
  .discussion-main__profile-dept {
    font-size: 14px;
    line-height: 32px;
  }
  .discussion-main__profile-name {
    font-size: 20px;
    line-height: 32px;
  }
  .discussion-main__profile-year {
    font-size: 14px;
    line-height: 24px;
  }
  .discussion-intro {
    padding: 0 20px 60px;
  }
  .discussion-intro__text {
    font-size: 15px;
    line-height: 28px;
  }
  .discussion-intro__text br {
    display: none;
  }
  .discussion-content {
    padding: 40px 20px 80px;
  }
  .discussion-section {
    grid-template-columns: 1fr;
    gap: 24px;
    margin-bottom: 60px;
  }
  .discussion-section--message {
    grid-template-columns: 1fr;
  }
  .discussion-section--message .discussion-section__body {
    grid-column: 1;
  }
  .discussion-section__heading {
    gap: 12px;
  }
  .discussion-section__line {
    height: 80px;
  }
  .discussion-section__title {
    font-size: 20px;
    line-height: 32px;
  }
  .discussion-section__question {
    font-size: 14px;
    line-height: 32px;
    margin-bottom: 16px;
  }
  .discussion-message {
    gap: 12px;
    margin-bottom: 24px;
  }
  .discussion-message__speaker {
    width: 48px;
  }
  .discussion-message__icon {
    width: 48px;
    height: 48px;
  }
  .discussion-message__name {
    font-size: 12px;
    margin-top: 6px;
  }
  .discussion-message__text {
    font-size: 15px;
    line-height: 28px;
  }
  .discussion-image {
    margin: 40px 0 60px;
  }
  .discussion-image--right {
    margin-left: 0;
    width: 100%;
  }
  .discussion-image img {
    width: 100%;
    height: auto;
    aspect-ratio: 2/1;
  }
  .discussion-image--full img {
    height: auto;
    aspect-ratio: 3/1;
  }
}
@media (max-width: 480px) {
  .discussion-main__title {
    font-size: 36px;
    margin-bottom: 30px;
  }
  .discussion-main__profile-image {
    width: 150px;
    height: 150px;
    border-radius: 30px;
  }
  .discussion-section__title {
    font-size: 18px;
    line-height: 28px;
  }
  .discussion-message__speaker {
    width: 40px;
  }
  .discussion-message__icon {
    width: 40px;
    height: 40px;
  }
  .discussion-message__name {
    font-size: 11px;
    margin-top: 4px;
  }
  .discussion-message__text {
    font-size: 14px;
    line-height: 26px;
  }
}/**
 * Swiper 12.0.3
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2025 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: October 21, 2025
 */

:root {
  --swiper-theme-color: #007aff;
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  */
}
:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}
.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block;
}
.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}
.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}
.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}
.swiper-horizontal {
  touch-action: pan-y;
}
.swiper-vertical {
  touch-action: pan-x;
}
.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
}
.swiper-slide-invisible-blank {
  visibility: hidden;
}
/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}
.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}
.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden;
}
/* 3D Effects */
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}
.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}
.swiper-3d {
  perspective: 1200px;
  .swiper-slide,
  .swiper-cube-shadow {
    transform-style: preserve-3d;
  }
}

/* CSS Mode */
.swiper-css-mode {
  > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none; /* For Firefox */
    -ms-overflow-style: none; /* For Internet Explorer and Edge */
    &::-webkit-scrollbar {
      display: none;
    }
  }
  > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start;
  }
  &.swiper-horizontal {
    > .swiper-wrapper {
      scroll-snap-type: x mandatory;
    }
  }
  &.swiper-vertical {
    > .swiper-wrapper {
      scroll-snap-type: y mandatory;
    }
  }
  &.swiper-free-mode {
    > .swiper-wrapper {
      scroll-snap-type: none;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: none;
    }
  }
  &.swiper-centered {
    > .swiper-wrapper::before {
      content: '';
      flex-shrink: 0;
      order: 9999;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: center center;
      scroll-snap-stop: always;
    }
  }
  &.swiper-centered.swiper-horizontal {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper::before {
      height: 100%;
      min-height: 1px;
      width: var(--swiper-centered-offset-after);
    }
  }
  &.swiper-centered.swiper-vertical {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper::before {
      width: 100%;
      min-width: 1px;
      height: var(--swiper-centered-offset-after);
    }
  }
}

/* Slide styles start */
/* 3D Shadows */
.swiper-3d {
  .swiper-slide-shadow,
  .swiper-slide-shadow-left,
  .swiper-slide-shadow-right,
  .swiper-slide-shadow-top,
  .swiper-slide-shadow-bottom,
  .swiper-slide-shadow,
  .swiper-slide-shadow-left,
  .swiper-slide-shadow-right,
  .swiper-slide-shadow-top,
  .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10;
  }
  .swiper-slide-shadow {
    background: rgba(0, 0, 0, 0.15);
  }
  .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
}
.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}
.swiper:not(.swiper-watch-progress),
.swiper-watch-progress .swiper-slide-visible {
  .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear;
  }
}
.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}
.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}
@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Slide styles end */
.swiper-fade {
  &.swiper-free-mode {
    .swiper-slide {
      transition-timing-function: ease-out;
    }
  }
  .swiper-slide {
    pointer-events: none;
    transition-property: opacity;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    pointer-events: auto;
    & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}
