.company-hero{
  position: relative;
  width: 100%;
  height: 17vh;
  min-height: 150px;
  overflow: hidden;
  background: #f7f4eb;
}

.company-hero img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.company-hero::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.20) 100%);
}

.company-hero .page-hero-copy{
  position: absolute;
  top: 50%;
  left: 50%;
  bottom: auto;
  transform: translate(-50%, -50%);
  z-index: 2;
  width: min(760px, calc(100% - 48px));
  color: #fff;
  text-align: center;
}

.company-hero .section-en{
  color: #ead7a3;
  margin: 0 0 8px;
  font-size: 14px;
  letter-spacing: .14em;
  line-height: 1.6;
  text-align: center;
}

.company-hero h1{
  font-family: "Noto Serif JP", serif;
  font-size: 34px;
  line-height: 1.45;
  font-weight: 500;
  letter-spacing: .05em;
  margin: 0;
  text-align: center;
}

.company-page{
  max-width: 1240px;
  margin: 0 auto;
  padding: 40px 28px 96px;
}

.company-page .breadcrumbs{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 12px;
  color: #7d7d7d;
  margin-bottom: 32px;
}

.company-page .breadcrumbs span::after{
  content: "/";
  margin-left: 8px;
  color: #b0b0b0;
}

.company-page .breadcrumbs a{
  color: inherit;
  text-decoration: none;
}

.company-page .breadcrumbs strong{
  font-weight: 500;
  color: #333;
}

.company-table dt{
  font-size:13px;
  letter-spacing:.08em;
  color:var(--gold);
  font-weight:700;
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
}
.company-message-pc{
  display: block;
}

.company-message-sp{
  display: none;
}
@media (max-width: 640px){
  .company-hero{
    height: 19vh;
    min-height: 150px;
  }

  .company-hero .page-hero-copy{
    width: calc(100% - 32px);
  }

  .company-hero .section-en{
    font-size: 12px;
  }

  .company-hero h1{
    font-size: 24px;
  }
  .company-message-pc{
    display: none;
  }

  .company-message-sp{
    display: block;
  }
  .company-message .company-message-sp{
    text-align: left;
  }
}
.company-page{padding-bottom:110px;}
.company-intro,.company-card,.company-message,.page-next{width:min(860px,100%);margin-inline:auto;}
.company-intro{text-align:center;margin-bottom:56px;}
.company-intro h2{font-family:"Noto Serif JP",serif;font-size:40px;line-height:1.5;font-weight:500;margin:0 0 18px;}
.company-intro .lead{font-size:15px;line-height:2.2;color:#444;max-width:760px;margin:0 auto;}
.company-card{background:#faf8f2;border:1px solid var(--line);padding:28px 32px;margin-bottom:72px;}
.company-table .row{display:grid;grid-template-columns:190px 1fr;gap:20px;padding:16px 0;border-bottom:1px solid var(--line);}
.company-table .row:last-child{border-bottom:0;}
.company-table dt{font-size:13px;letter-spacing:.08em;color:var(--gold);font-weight:700;text-align: left;
    justify-content: flex-start;}
.company-table dd{margin:0;font-size:15px;line-height:2;color:#333;}
.interview-block{display:grid;grid-template-columns:44% 56%;gap:36px;align-items:center;max-width:1080px;margin:0 auto 72px;}
.interview-media img{display:block;width:100%;aspect-ratio:4/5;object-fit:cover;background:#f5f1e8;}
.interview-copy .section-en{margin-bottom:12px;}
.interview-copy h2{font-family:"Noto Serif JP",serif;font-size:34px;font-weight:500;margin:0 0 10px;}
.interview-copy h3{font-family:"Noto Serif JP",serif;font-size:28px;line-height:1.7;font-weight:500;margin:0 0 20px;white-space:pre-line;}
.interview-copy p{font-size:15px;line-height:2.2;color:#333;margin:0 0 16px;}
.company-message{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:34px 0;margin-bottom:56px;}
.company-message p{font-family:"Noto Serif JP",serif;font-size:30px;line-height:1.8;margin:0;text-align:center;}
.contact-link{
  color:#c9a227; /* ゴールド系 */
  text-decoration: underline;
  font-weight:500;
}

.contact-link:hover{
  opacity:0.7;
}
.interview-visual{
  width: 100%;
  margin: 80px auto 56px;
}

.interview-visual img{
  width: 100%;
  height: auto;
  display: block;
}

.interview-visual-pc{
  display: block !important;
}

.interview-visual-sp{
  display: none !important;
}


@media (max-width:860px){
  .company-intro h2{font-size:31px;}
  .company-table .row{grid-template-columns:1fr;gap:8px;}
  .interview-block{grid-template-columns:1fr;gap:24px;}
  .interview-copy h2{font-size:28px;}
  .interview-copy h3{font-size:22px;}
  .company-message p{font-size:20px;}
  .company-card{padding:22px 18px;}
  .interview-visual{
    width: min(860px, 100%);
    margin: 40px auto 32px;
  }

  .interview-visual-pc{
    display: none !important;
  }

  .interview-visual-sp{
    display: block !important;
  }
}
