  /* ============================================================
     PROFILE — 榎 弥生 (YAYOI ENOKI)
     Editorial, premium, business-oriented. Built on release.css.
     Page-scoped layout only.
     ============================================================ */

  /* shared photo frame */
  .pf-frame { position: relative; overflow: hidden; background: var(--bg-3); border-radius: 2px; box-shadow: 0 34px 66px -36px rgba(43,37,32,0.40); }
  .pf-frame img { width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ---- 1. HERO ---- */
  .pf-hero { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: clamp(36px, 5vw, 76px); align-items: center; }
  .pf-hero__eyebrow { display: inline-block; margin-bottom: 22px; }
  .pf-hero__jp {
    font-family: var(--jp-mincho);
    font-size: clamp(14px, 1.7vw, 17px);
    letter-spacing: 0.34em;
    color: var(--accent-deep);
    margin: 14px 0 22px;
  }
  .pf-hero__role {
    font-family: var(--label);
    font-size: 12px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--ink-soft);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    padding-bottom: 26px;
    margin-bottom: 26px;
    border-bottom: 1px solid var(--line-soft);
  }
  .pf-hero__role > span:not(.sep) { white-space: nowrap; }
  .pf-hero__role .sep { width: 5px; height: 5px; background: var(--accent); transform: rotate(45deg); flex: none; }
  .pf-hero__intro p {
    font-family: var(--jp-mincho);
    font-size: clamp(15px, 1.8vw, 17px);
    line-height: 2.3;
    letter-spacing: 0.06em;
    color: var(--ink);
  }
  .pf-social-links {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 10px;
    margin-top: 28px;
  }
  .pf-social-links a {
    min-height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid var(--line);
    background: rgba(250, 247, 242, 0.58);
    color: var(--ink);
    font-family: var(--label);
    font-size: 11px;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    transition: transform .3s ease, background .3s ease, border-color .3s ease, color .3s ease;
  }
  .pf-social-links a:hover {
    transform: translateY(-2px);
    background: var(--accent-deep);
    border-color: var(--accent-deep);
    color: #fff;
  }
  .pf-social-links .arrow {
    font-size: 12px;
    letter-spacing: 0;
  }
  .pf-hero__img { aspect-ratio: 4 / 5; }

  /* ---- 2. MAIN PROFILE ---- */
  .pf-main { display: grid; grid-template-columns: 0.74fr 1.26fr; gap: clamp(32px, 5vw, 84px); align-items: start; }
  .pf-name__en {
    font-family: var(--label);
    font-size: 12px; letter-spacing: 0.34em; text-transform: uppercase;
    color: var(--accent-deep); margin-bottom: 14px;
  }
  .pf-name {
    font-family: var(--jp-mincho); font-weight: 500;
    font-size: clamp(40px, 6vw, 60px);
    letter-spacing: 0.12em; line-height: 1.15; color: var(--ink);
  }
  .pf-name .dot { color: var(--accent); }
  .pf-name__meta {
    margin-top: 24px;
    font-family: var(--jp);
    font-size: 13.5px; line-height: 2; letter-spacing: 0.08em;
    color: var(--ink-soft);
  }
  .pf-name__rule { width: 44px; height: 1px; background: var(--accent-deep); margin: 26px 0 0; }
  .pf-bio { display: flex; flex-direction: column; gap: 24px; max-width: 720px; }
  .pf-bio p {
    font-family: var(--jp-mincho);
    font-size: 16px; line-height: 2.28; letter-spacing: 0.05em; color: var(--ink);
  }
  .pf-bio p.lead { color: var(--ink); font-weight: 500; }
  .pf-bio .hl { color: var(--accent-deep); font-weight: 600; }

  /* ---- 3. ACTIVITY FIELD ---- */
  .pf-fields { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
  .field-card {
    background: var(--card);
    border: 1px solid var(--line-soft);
    padding: 32px 26px 30px;
    display: flex; flex-direction: column; gap: 14px;
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  }
  .field-card:hover { transform: translateY(-3px); box-shadow: 0 22px 40px -28px rgba(43,37,32,0.45); border-color: var(--line); }
  .field-card__no {
    font-family: var(--serif); font-size: 15px; letter-spacing: 0.18em;
    color: var(--accent); 
  }
  .field-card__en {
    font-family: var(--serif); font-weight: 500;
    font-size: 21px; letter-spacing: 0.04em; line-height: 1.3; color: var(--ink);
  }
  .field-card__line { width: 26px; height: 1px; background: var(--line); }
  .field-card__jp {
    font-family: var(--jp); font-size: 13.5px; line-height: 1.95;
    letter-spacing: 0.04em; color: var(--ink-soft);
  }

  /* ---- 4. BOOK ---- */
  .pf-book { display: grid; grid-template-columns: minmax(460px, 1.08fr) minmax(360px, 0.92fr); gap: clamp(36px, 5vw, 70px); align-items: center; }
  .pf-book__img { aspect-ratio: 1402 / 1122; max-width: 680px; width: 100%; }
  .pf-book__img img { object-position: center; }
  .pf-book__copy .eyebrow { display: inline-block; margin-bottom: 18px; }
  .pf-book__title {
    font-family: var(--jp-mincho);
    font-size: clamp(22px, 2.7vw, 28px); line-height: 1.7;
    letter-spacing: 0.06em; color: var(--ink); margin-bottom: 26px;
  }
  .pf-book__copy p {
    font-family: var(--jp-mincho); font-size: 15.5px; line-height: 2.25;
    letter-spacing: 0.05em; color: var(--ink);
  }
  .pf-book__copy p + p { margin-top: 18px; }
  .pf-book__cta { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 36px; }

  /* ---- 5. ACHIEVEMENTS ---- */
  .pf-ach { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 5vw, 64px) clamp(44px, 7vw, 96px); max-width: 1000px; margin: 0 auto; }
  .ach-cat__head {
    display: flex; align-items: baseline; gap: 16px;
    padding-bottom: 16px; margin-bottom: 8px;
    border-bottom: 1px solid var(--line);
  }
  .ach-cat__no {
    font-family: var(--serif); font-size: 15px; letter-spacing: 0.16em; color: var(--accent);
  }
  .ach-cat__name {
    font-family: var(--serif); font-weight: 500; font-size: 20px;
    letter-spacing: 0.06em; color: var(--ink);
  }
  .ach-cat__jp {
    font-family: var(--jp); font-size: 12px; letter-spacing: 0.14em; color: var(--muted);
    margin-left: auto;
  }
  .ach-list { list-style: none; margin: 0; padding: 0; }
  .ach-item { padding: 15px 2px; border-bottom: 1px solid var(--line-soft); }
  .ach-item__main {
    display: block; font-family: var(--jp-mincho);
    font-size: 14.5px; line-height: 1.75; letter-spacing: 0.03em; color: var(--ink);
  }
  .ach-item__sub {
    display: block; font-family: var(--jp); font-size: 12px;
    letter-spacing: 0.05em; color: var(--muted); margin-top: 5px; line-height: 1.6;
  }

  /* ---- 6. WORK REQUEST CTA ---- */
  .pf-business-cta-section {
    position: relative;
    overflow: hidden;
    background:
      linear-gradient(rgba(242,236,227,0.34), rgba(242,236,227,0.42)),
      url("img/profile-business-cta-bg.jpg") center / cover no-repeat;
  }
  .pf-business-cta-section::before {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: radial-gradient(circle at 50% 50%, rgba(250,247,242,0.82) 0 34%, rgba(250,247,242,0.48) 56%, rgba(250,247,242,0.16) 100%);
  }
  .pf-business-cta-section > .container {
    position: relative;
    z-index: 1;
  }
  .pf-cta { max-width: 760px; margin: 0 auto; text-align: center; }
  .pf-cta .eyebrow { display: inline-block; margin-bottom: 20px; }
  .pf-cta__title {
    font-family: var(--jp-mincho);
    font-size: clamp(21px, 2.7vw, 30px); line-height: 1.7;
    letter-spacing: 0.06em; color: var(--ink); margin-bottom: 26px;
  }
  .pf-cta__text {
    font-family: var(--jp); font-size: 15px; line-height: 2.15;
    letter-spacing: 0.04em; color: var(--ink-soft); margin-bottom: 40px;
  }
  .btn--fill { background: var(--accent-deep); color: #fff; border-color: var(--accent-deep); }
  .btn--fill:hover { background: var(--ink); border-color: var(--ink); color: #fff; }
  .btn--jp { font-family: var(--jp); letter-spacing: 0.14em; text-transform: none; font-size: 14px; }

  /* ---- responsive ---- */
  @media (max-width: 900px) {
    .pf-hero { grid-template-columns: 1fr; gap: 36px; }
    .pf-hero__img { max-width: 400px; width: 100%; margin-inline: auto; order: -1; }
    .pf-social-links { max-width: 520px; }
    .pf-main { grid-template-columns: 1fr; gap: 30px; }
    .pf-name__rule { display: none; }
    .pf-fields { grid-template-columns: 1fr 1fr; gap: 18px; }
    .pf-book { grid-template-columns: 1fr; gap: 32px; }
    .pf-book__img { max-width: min(760px, 100%); margin-inline: auto; order: -1; }
    .pf-book__copy { text-align: center; }
    .pf-book__copy .pf-book__cta { justify-content: center; }
    .pf-ach { grid-template-columns: 1fr; gap: 40px; max-width: 520px; }
  }
  @media (max-width: 560px) {
    .pf-social-links { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 9px; }
    .pf-social-links a { min-height: 50px; font-size: 10px; }
    .pf-fields { grid-template-columns: 1fr; gap: 16px; max-width: 420px; margin-inline: auto; }
    .pf-book__cta { gap: 14px; }
    .pf-book__cta .btn { width: 100%; justify-content: center; }
    .pf-name { font-size: clamp(38px, 13vw, 50px); }
    .ach-cat__jp { margin-left: 0; }
    .ach-cat__head { flex-wrap: wrap; gap: 10px 14px; }
  }
