/* ==========================================================================
   Company Profiel (会社概要) Page
   prefix: cpf-
   ========================================================================== */

.p-company-profile-page {
  background: #fb9516;
}

.cpf-profile {
  overflow: hidden;
}

.cpf-inner {
  width: min(1440px, 100%);
  margin: 0 auto;
}

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

/* --------------------------------------------------------------------------
   Section Title — dual text with shadow offset
   -------------------------------------------------------------------------- */
.cpf-section-title {
  position: relative;
  display: inline-block;
  margin: 0;
  line-height: 1.1;
}

.cpf-section-title__main {
  display: block;
  position: relative;
  z-index: 2;
  font-size: clamp(40px, 4.8vw, 69px);
  font-weight: 700;
  color: #fb9516;
  font-family: "Hiragino Sans", "ヒラギノ角ゴシック", "Hiragino Kaku Gothic ProN", sans-serif;
}

.cpf-section-title__shadow {
  display: block;
  position: absolute;
  top: 7.5px;
  left: 7.8px;
  z-index: 1;
  font-size: clamp(40px, 4.8vw, 69px);
  font-weight: 700;
  color: transparent;
  -webkit-text-stroke: 1px rgba(251, 149, 22, 0.25);
  font-family: "Hiragino Sans", "ヒラギノ角ゴシック", "Hiragino Kaku Gothic ProN", sans-serif;
  white-space: nowrap;
}

.cpf-section-title--center {
  display: block;
  text-align: center;
}

.cpf-section-title--center .cpf-section-title__main,
.cpf-section-title--center .cpf-section-title__shadow {
  display: inline;
}

.cpf-section-title--center .cpf-section-title__shadow {
  position: relative;
  top: auto;
  left: auto;
  display: block;
  margin-top: -0.85em;
  margin-left: 15.3px;
}

.cpf-section-title--right {
  display: block;
  text-align: right;
}

.cpf-section-title--right .cpf-section-title__shadow {
  left: auto;
  right: -16px;
}

.cpf-section-title--white .cpf-section-title__main {
  color: #ffffff;
}

.cpf-section-title--white .cpf-section-title__shadow {
  color: rgba(255, 255, 255, 0.22);
  -webkit-text-stroke: 0;
}

/* --------------------------------------------------------------------------
   Hero: Orange header + white arch + island + title
   -------------------------------------------------------------------------- */
.cpf-hero {
  position: relative;
  z-index: 3;
  background: #fb9516;
  padding-top: 86px;
}

.cpf-hero__arch {
  width: 100%;
  min-height: clamp(400px, 42vw, 580px);
  padding: clamp(70px, 7.1vw, 102px) clamp(30px, 12vw, 172px) 53px;
  background: #ffffff;
  border-top-left-radius: 50% clamp(300px, 40vw, 580px);
  border-top-right-radius: 50% clamp(300px, 40vw, 580px);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.cpf-hero__visual {
  width: clamp(180px, 21vw, 302px);
  margin: 0 auto clamp(16px, 2vw, 28px);
}

.cpf-hero__title-wrap {
  text-align: center;
}

.cpf-hero__title {
  margin: 0;
}

.cpf-hero__title img {
  width: clamp(240px, 23.8vw, 343px);
  height: auto;
  display: block;
}

.cpf-hero__subtitle {
  margin: 8px 0 82px;
  font-size: clamp(24px, 2.5vw, 36px);
  font-weight: 700;
  color: #fbb03b;
}

/* --------------------------------------------------------------------------
   COMPANY INFO
   -------------------------------------------------------------------------- */
.cpf-info {
  background: #ffffff;
  margin-top: -2px;
  padding: clamp(60px, 8vw, 120px) clamp(30px, 7vw, 103px) clamp(60px, 8vw, 100px);
}

.cpf-info .cpf-section-title__shadow {
  top: 12.8px;
  left: 16.4px;
}

.cpf-info__grid {
  margin-top: clamp(20px, 3vw, 40px);
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 650px) 1fr;
  gap: 0 clamp(20px, 2vw, 40px);
  align-items: start;
}

.cpf-info__table dl {
  margin: 0;
}

.cpf-info__table div {
  display: grid;
  grid-template-columns: clamp(140px, 14vw, 200px) minmax(500px, 1fr);
  gap: 0;
  position: relative;
}

.cpf-info__table div::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: min(660px, 100%);
  height: 1px;
  background: rgba(251, 149, 22, 0.3);
}

.cpf-info__table div:first-child::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: min(660px, 100%);
  height: 1px;
  background: rgba(251, 149, 22, 0.3);
}

.cpf-info__table dt,
.cpf-info__table dd {
  margin: 0;
  padding: clamp(10px, 1vw, 15px) clamp(14px, 1.6vw, 24px);
}

.cpf-info__table dt {
  color: #fb9516;
  font-size: clamp(15px, 1.6vw, 22.9px);
  font-weight: 400;
  border-right: 2px solid #fb9516;
  white-space: nowrap;
}

.cpf-info__table dd {
  color: #333333;
  font-size: clamp(15px, 1.6vw, 22.9px);
  font-weight: 200;
  line-height: 1.6;
}

.cpf-info__table dd a {
  color: inherit;
  text-decoration: none;
}

.cpf-info__table dd a:hover {
  text-decoration: underline;
}

.cpf-info__ext-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.cpf-info__ext-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  vertical-align: middle;
}

.cpf-info__illust {
  margin: -400px 0 0;
  width: 100%;
  max-width: 682px;
  pointer-events: none;
  align-self: center;
}

/* --------------------------------------------------------------------------
   BOARD MEMBERS
   -------------------------------------------------------------------------- */
.cpf-board {
  background: #ffffff;
  padding: 7px clamp(30px, 7vw, 103px) clamp(60px, 8vw, 120px);
}

.cpf-board__grid {
  margin-top: clamp(28px, 4vw, 50px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 37px clamp(20px, 3.3vw, 48px);
}

.cpf-board .cpf-section-title .cpf-section-title__main {
  font-size: clamp(40px, 4.9vw, 71px);
}

.cpf-board .cpf-section-title .cpf-section-title__shadow {
  font-size: clamp(40px, 4.9vw, 71px);
  top: 10.4px;
  left: 11px;
}

/* Member card (shared between board & advisors)
   Design: 2-panel layout — orange info (195px) + cream career (380px) */
.cpf-member {
  display: grid;
  grid-template-columns: clamp(120px, 13.3vw, 191px) 1fr;
  gap: 0;
  align-items: stretch;
}

.cpf-member__info {
  display: flex;
  flex-direction: column;
  background: #fb9516;
  border-radius: 4px 0 0 4px;
  padding: clamp(8px, 0.85vw, 12px) clamp(12px, 1.15vw, 17px) clamp(20px, 2.6vw, 38px);
}

.cpf-member__role {
  margin: 0;
  color: #ffffff;
  font-size: clamp(14px, 1.24vw, 17.9px);
  font-weight: 700;
}

.cpf-member__name {
  margin: clamp(16px, 1.6vw, 24px) 0 0;
  color: #ffffff;
  font-size: clamp(18px, 1.55vw, 22.3px);
  font-weight: 600;
  line-height: 1.3;
}

.cpf-member__name-en {
  margin: 2px 0 0;
  color: #ffffff;
  font-size: clamp(12px, 1.1vw, 15.8px);
  font-weight: 700;
}

.cpf-member__career-wrap {
  background: #fbe8ce;
  border-radius: 0 4px 4px 0;
  padding: clamp(8px, 0.85vw, 12px) clamp(12px, 1.5vw, 22px) clamp(20px, 2.6vw, 38px);
}

.cpf-member__career-label {
  margin: 0;
  color: #fb9516;
  font-size: clamp(14px, 1.24vw, 17.9px);
  font-weight: 700;
}

.cpf-member__career {
  margin: 8px 0 0;
  color: #333333;
  font-size: clamp(10px, 0.76vw, 11px);
  font-weight: 700;
  line-height: 1.4;
}

/* --------------------------------------------------------------------------
   ADVISORS
   -------------------------------------------------------------------------- */
.cpf-advisors {
  background: #ffffff;
  padding: 182px clamp(30px, 7vw, 103px) clamp(60px, 8vw, 120px);
}

.cpf-advisors .cpf-section-title .cpf-section-title__main {
  font-size: clamp(44px, 5.4vw, 78px);
}

.cpf-advisors .cpf-section-title .cpf-section-title__shadow {
  font-size: clamp(44px, 5.4vw, 78px);
  top: 12.4px;
  left: 18.7px;
}

.cpf-advisors__grid {
  margin-top: clamp(28px, 4vw, 50px);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px clamp(20px, 3.3vw, 48px);
}

/* --------------------------------------------------------------------------
   ASSOCIATED COMPANY
   -------------------------------------------------------------------------- */
.cpf-assoc {
  background: #ffffff;
  padding: clamp(90px, 12vw, 180px) clamp(30px, 7vw, 103px);
}

.cpf-assoc .cpf-section-title .cpf-section-title__main {
  font-size: clamp(36px, 5.3vw, 76.7px);
}

.cpf-assoc .cpf-section-title .cpf-section-title__shadow {
  font-size: clamp(36px, 5.3vw, 76.7px);
}

.cpf-assoc__card {
  margin: clamp(30px, 4vw, 56px) auto 0;
  width: fit-content;
}

.cpf-assoc__link {
  display: block;
  text-decoration: none;
}

.cpf-assoc__link:hover {
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
  transform: translateY(-2px);
}

.cpf-assoc__logo {
  width: clamp(280px, 35vw, 500px);
  filter: drop-shadow(0 8px 20px rgba(0, 0, 0, 0.15));
}

.cpf-assoc__external-icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.cpf-assoc__name {
  font-family: Copperplate, serif;
  font-weight: bold;
  font-size: clamp(18px, 1.5vw, 22px);
  color: #000000;
}

/* --------------------------------------------------------------------------
   ACCESS — title on orange, D-shape cream container for map+text
   -------------------------------------------------------------------------- */
.cpf-access {
  background: #ffffff;
  margin-top: 0;
  padding: 0 clamp(30px, 7vw, 103px) 0;
}

.cpf-access__container > .cpf-section-title--right {
  padding-right: 0;
  width: 100%;
}

.cpf-access .cpf-section-title--right .cpf-section-title__main {
  font-size: clamp(44px, 5.6vw, 81.1px);
}

.cpf-access .cpf-section-title--right .cpf-section-title__shadow {
  font-size: clamp(44px, 5.6vw, 81.1px);
  top: 12.1px;
  right: -19.3px;
}

/* D-shape container: ORANGE, semicircle LEFT, flush RIGHT edge */
.cpf-access__container {
  margin-left: calc(-1 * clamp(30px, 7vw, 103px));
  margin-right: calc(-1 * clamp(30px, 7vw, 103px));
  background: #fb9516;
  border-radius: clamp(300px, 40vw, 580px) 0 0 clamp(300px, 40vw, 580px) / 50% 0 0 50%;
  overflow: hidden;
  padding: clamp(28px, 3vw, 48px) 0 clamp(40px, 4vw, 60px);
}

.cpf-access__upper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(20px, 3vw, 40px);
  align-items: start;
  padding: clamp(20px, 3vw, 40px) clamp(20px, 3vw, 40px) 0 clamp(80px, 10vw, 160px);
}

.cpf-access__label {
  margin: 0 0 8px;
  font-size: clamp(16px, 1.6vw, 22.9px);
  font-weight: 700;
  color: #ffffff;
}

.cpf-access__text {
  margin: 0;
  color: #ffffff;
  font-size: clamp(16px, 1.6vw, 22.9px);
  font-weight: 700;
  line-height: 1.6;
}

.cpf-access__tel {
  margin: 10px 0 0;
  color: #ffffff;
  font-size: clamp(16px, 1.6vw, 22.9px);
  font-weight: 700;
}

.cpf-access__info .cpf-access__detail + .cpf-access__detail {
  margin-top: clamp(16px, 2vw, 28px);
}

.cpf-access__map {
  background: #f3f3f3;
  border-radius: 8px;
  overflow: hidden;
  margin-top: clamp(20px, 3vw, 48px);
  /* clip-path forces GPU compositing so iframe popups don't escape overflow:hidden */
  clip-path: inset(0 0 0 0 round 8px);
}

.cpf-access__map iframe {
  width: 100%;
  max-width: 100%;
  display: block;
  height: clamp(200px, 20vw, 320px);
}

/* --------------------------------------------------------------------------
   GALLERY title (on orange, outside D-container) + scroll (inside D-container)
   -------------------------------------------------------------------------- */
.cpf-access__container > .cpf-section-title--right:last-of-type {
  margin-top: clamp(16px, 2vw, 28px);
  padding-bottom: clamp(8px, 1vw, 16px);
}

.cpf-access .cpf-section-title--right:last-of-type .cpf-section-title__main {
  font-size: clamp(44px, 5.6vw, 80.3px);
}

.cpf-access .cpf-section-title--right:last-of-type .cpf-section-title__shadow {
  font-size: clamp(44px, 5.6vw, 80.3px);
  top: 15.1px;
  right: -19.3px;
}

.cpf-gallery__scroll {
  overflow: hidden;
  padding: clamp(20px, 2.5vw, 40px) 0 clamp(30px, 3.5vw, 50px);
}

.cpf-gallery__track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(260px, 30vw, 420px);
  gap: 4px;
  width: max-content;
  animation: cpf-gallery-flow 50s linear infinite;
}

.cpf-gallery__track img {
  width: 100%;
  height: clamp(180px, 22vw, 320px);
  object-fit: cover;
  border-radius: 4px;
}

@keyframes cpf-gallery-flow {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* --------------------------------------------------------------------------
   CTA (CONTACT / NEWS) — buttons on orange, white arch spacer below
   -------------------------------------------------------------------------- */
.cpf-cta {
  position: relative;
  z-index: 3;
  background: #fb9516;
}

.cpf-cta__buttons {
  display: flex;
  justify-content: center;
  gap: clamp(20px, 3.2vw, 48px);
  padding: 0 24px;
}

/* White arch spacer — no content, purely decorative downward curve
   border-bottom-radius は .u-footer-arch から継承 */
.cpf-cta__arch {
  width: 100%;
  background: #ffffff;
  height: clamp(400px, 42vw, 620px);
  margin-top: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding-top: clamp(120px, 13.5vw, 192px);
}

.cpf-cta__button {
  display: block;
  width: clamp(200px, 23.82vw, 343px);
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.cpf-cta__button:hover {
  transform: translateY(-3px);
  opacity: 0.88;
}

.cpf-cta__button img {
  width: 100%;
  height: auto;
  display: block;
}

/* Footer — curve fill color only (override handled by .has-footer-arch) */
.has-footer-arch.cpf-profile + .l-footer .l-footer__curve-path {
  fill: #fb9516;
}

/* --------------------------------------------------------------------------
   Responsive: 1200px
   -------------------------------------------------------------------------- */
@media (max-width: 1200px) {
  .cpf-info__grid {
    grid-template-columns: 1fr;
  }

  .cpf-info__illust {
    width: clamp(280px, 60vw, 500px);
    margin: clamp(24px, 3vw, 40px) auto 0;
  }

  /* 1200px footer override → .has-footer-arch に統合済み */
}

/* --------------------------------------------------------------------------
   Responsive: 1024px
   -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  .cpf-hero {
    padding-top: 74px;
  }

  .cpf-hero__arch {
    padding-left: 40px;
    padding-right: 40px;
    min-height: clamp(350px, 48vw, 480px);
  }

  .cpf-info,
  .cpf-board,
  .cpf-advisors,
  .cpf-assoc,
  .cpf-access {
    padding-left: 40px;
    padding-right: 40px;
  }

  .cpf-board__grid,
  .cpf-advisors__grid {
    gap: 28px clamp(20px, 3vw, 36px);
  }

  .cpf-member {
    grid-template-columns: clamp(100px, 12vw, 150px) 1fr;
  }
}

/* --------------------------------------------------------------------------
   Responsive: 900px
   -------------------------------------------------------------------------- */
@media (max-width: 900px) {
  .cpf-board__grid,
  .cpf-advisors__grid {
    grid-template-columns: 1fr;
  }

  .cpf-member {
    grid-template-columns: 1fr 1.5fr;
  }

  .cpf-access__upper {
    grid-template-columns: 1fr;
  }

  .cpf-access__container {
    border-radius: clamp(200px, 40vw, 400px) 0 0 clamp(200px, 40vw, 400px) / 50% 0 0 50%;
  }

  .cpf-access__upper {
    padding-left: clamp(50px, 8vw, 100px);
  }
}

/* --------------------------------------------------------------------------
   Responsive: 767px
   -------------------------------------------------------------------------- */
@media (max-width: 767px) {
  .cpf-hero__arch {
    min-height: 280px;
    padding: 100px 24px 24px;
    border-top-left-radius: 50% 280px;
    border-top-right-radius: 50% 280px;
  }

  .cpf-cta__arch {
    height: 500px;
    padding-top: 60px;
    /* border-bottom-radius は .u-footer-arch から継承 */
  }

  .cpf-info,
  .cpf-board,
  .cpf-advisors,
  .cpf-assoc,
  .cpf-access {
    padding-left: 24px;
    padding-right: 24px;
  }

  .cpf-section-title__main,
  .cpf-section-title__shadow {
    font-size: clamp(28px, 6vw, 42px) !important;
  }

  .cpf-section-title__shadow,
  .cpf-info .cpf-section-title__shadow,
  .cpf-board .cpf-section-title .cpf-section-title__shadow,
  .cpf-advisors .cpf-section-title .cpf-section-title__shadow {
    top: 6px;
    left: 10px;
  }

  .cpf-access .cpf-section-title--right .cpf-section-title__shadow {
    top: 6px;
    right: -10px;
  }

  .cpf-hero__subtitle {
    font-size: clamp(20px, 4vw, 28px);
  }

  .cpf-info__table div {
    grid-template-columns: clamp(110px, 28vw, 160px) 1fr;
  }

  .cpf-info__table dt {
    font-size: 15px;
  }

  .cpf-info__table dd {
    font-size: 15px;
  }

  .cpf-member {
    grid-template-columns: 1fr;
  }

  .cpf-member__info {
    text-align: center;
    border-radius: 4px 4px 0 0;
    padding: 16px;
  }

  .cpf-member__name {
    margin-top: 12px;
  }

  .cpf-member__career-wrap {
    border-radius: 0 0 4px 4px;
    padding: 12px 16px;
  }

  .cpf-member__career {
    font-size: 11px;
  }

  .cpf-cta__buttons {
    flex-direction: column;
    align-items: center;
  }

  .cpf-cta__button {
    width: clamp(180px, 52vw, 260px);
  }

  .cpf-access__container {
    border-radius: 0;
    margin-left: -24px;
    margin-right: -24px;
  }

  .cpf-access__upper {
    padding: 24px 16px;
  }

  .cpf-gallery__track {
    grid-auto-columns: 200px;
  }

  .cpf-gallery__track img {
    height: 160px;
  }

  .cpf-access__map iframe {
    height: 200px;
  }

  .cpf-access {
    padding-top: 120px;
  }

  .cpf-advisors {
    padding-top: 80px;
  }

  .cpf-assoc {
    padding-top: 100px;
  }
}

/* --------------------------------------------------------------------------
   Responsive: 620px
   -------------------------------------------------------------------------- */
@media (max-width: 620px) {
  .cpf-section-title__main,
  .cpf-section-title__shadow {
    font-size: clamp(24px, 5.5vw, 36px) !important;
  }

  .cpf-info__table dt,
  .cpf-info__table dd {
    padding: 7px clamp(10px, 2vw, 14px);
    font-size: 14px;
  }

  .cpf-info__table div {
    grid-template-columns: 110px minmax(0, 1fr);
  }

  .cpf-member__role {
    font-size: 14px;
  }

  .cpf-member__name {
    font-size: 17px;
  }

  .cpf-member__name-en {
    font-size: 12px;
  }

  .cpf-assoc__link {
    padding: 20px 28px;
  }

  .cpf-assoc__logo {
    width: clamp(150px, 50vw, 240px);
  }

  .cpf-assoc__name {
    font-size: 16px;
  }
}

/* --------------------------------------------------------------------------
   Responsive: 480px
   -------------------------------------------------------------------------- */
@media (max-width: 480px) {
  .cpf-hero {
    padding-top: 64px;
  }

  .cpf-hero__arch {
    min-height: 240px;
    padding: 80px 16px 18px;
    border-top-left-radius: 50% 200px;
    border-top-right-radius: 50% 200px;
  }

  .cpf-hero__visual {
    width: 140px;
  }

  .cpf-hero__title {
    font-size: 34px;
  }

  .cpf-hero__subtitle {
    font-size: 20px;
  }

  .cpf-info,
  .cpf-board,
  .cpf-advisors,
  .cpf-assoc,
  .cpf-access {
    padding-left: 16px;
    padding-right: 16px;
  }

  .cpf-access__container {
    border-radius: 0;
    margin-left: -16px;
    margin-right: -16px;
  }

  .cpf-access__upper {
    padding: 16px 10px;
    gap: 12px;
  }

  .cpf-access__label {
    font-size: 15px;
  }

  .cpf-access__text,
  .cpf-access__tel {
    font-size: 14px;
  }

  .cpf-access__map iframe {
    height: 160px;
  }

  .cpf-gallery__track {
    grid-auto-columns: 160px;
  }

  .cpf-gallery__track img {
    height: 130px;
  }

  .cpf-access {
    padding-top: 60px;
  }

  .cpf-advisors {
    padding-top: 40px;
  }

  .cpf-assoc {
    padding-top: 60px;
  }

  .cpf-info__table div {
    grid-template-columns: 100px minmax(0, 1fr);
  }

  .cpf-info__table dt {
    font-size: 13px;
  }

  .cpf-info__table dd {
    font-size: 13px;
  }

  .cpf-member__role {
    font-size: 13px;
  }

  .cpf-member__name {
    font-size: 16px;
  }

  .cpf-cta__arch {
    height: 420px;
    padding-top: 50px;
    /* border-bottom-radius は .u-footer-arch から継承 */
  }

  .cpf-cta__button {
    width: min(220px, 65vw);
  }
}
