/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   JOWA — kouji-tanaka.css
   代表プロフィールページ固有スタイル
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── HERO (代表ページ固有) ── */
.hero-right-img {
  position: absolute; inset: 0;
  background: url('../images/tanaka-kouji-outdoor.jpg') center top / cover no-repeat;
}
.hero-role {
  font-size: 13px; font-weight: 700; letter-spacing: .16em;
  color: rgba(255,255,255,.6); text-transform: uppercase; margin-bottom: 12px;
}
.hero-name {
  font-family: var(--font-disp);
  font-size: clamp(52px, 6vw, 80px); font-weight: 800;
  color: #fff; line-height: 1; letter-spacing: -.03em; margin-bottom: 6px;
}
.hero-name-en { font-size: 16px; color: rgba(255,255,255,.5); margin-bottom: 32px; font-weight: 500; letter-spacing: .08em; }

/* ── STATS BAR ── */
.stats-bar { background: var(--white); border-bottom: 1px solid var(--rule); padding: 32px 48px; }
.stats-bar-inner {
  max-width: 960px; margin: 0 auto;
  display: flex; justify-content: space-around; align-items: center; gap: 32px; flex-wrap: wrap;
}
.stat-item { text-align: center; }
.stat-item .num {
  font-family: var(--font-disp); font-size: 40px; font-weight: 800;
  color: var(--green); line-height: 1; letter-spacing: -.03em;
}
.stat-item .label { font-size: 12px; color: var(--sub); margin-top: 4px; letter-spacing: .04em; }

/* ── STORY ── */
.story-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start; margin-top: 56px; }
.story-text p { font-size: 16px; color: var(--sub); line-height: 2; margin-bottom: 20px; }
.story-text p:last-child { margin-bottom: 0; }
.story-quote {
  background: var(--green); border-radius: var(--radius-lg);
  padding: 40px; position: relative; overflow: hidden;
}
.story-quote::before {
  content: '"'; font-family: Georgia, serif; font-size: 120px;
  color: rgba(255,255,255,.12); line-height: .8;
  position: absolute; top: 16px; left: 24px; pointer-events: none;
}
.story-quote p {
  font-family: var(--font-disp); font-size: 18px; font-weight: 700;
  color: #fff; line-height: 1.65; position: relative; z-index: 1;
}
.story-quote cite {
  display: block; margin-top: 16px; font-size: 13px;
  color: rgba(255,255,255,.6); font-style: normal; position: relative; z-index: 1;
}

/* ── TIMELINE ── */
.timeline { position: relative; margin-top: 56px; }
.timeline::before {
  content: ''; position: absolute; left: 80px; top: 0; bottom: 0; width: 2px;
  background: linear-gradient(to bottom, var(--green), var(--cream-d));
}
.tl-item { display: grid; grid-template-columns: 80px 1fr; gap: 0 32px; margin-bottom: 40px; align-items: start; }
.tl-year {
  font-family: var(--font-disp); font-size: 14px; font-weight: 800;
  color: var(--green); text-align: right; padding-top: 4px; padding-right: 16px;
}
.tl-dot { position: relative; }
.tl-dot::before {
  content: ''; position: absolute; left: -39px; top: 10px;
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--green); border: 3px solid var(--white);
  box-shadow: 0 0 0 2px var(--green); z-index: 1;
}
.tl-content { padding-left: 8px; }
.tl-content h4 {
  font-family: var(--font-disp); font-size: 17px; font-weight: 700;
  color: var(--ink); margin-bottom: 6px; line-height: 1.3;
}
.tl-content p { font-size: 14px; color: var(--sub); line-height: 1.8; }

/* ── CREDENTIALS ── */
.cred-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 48px; }
.cred-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-md); padding: 32px 28px;
  transition: border-color .15s, box-shadow .15s;
}
.cred-card:hover { border-color: var(--green); box-shadow: 0 4px 20px rgba(30,107,69,.08); }
.cred-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: rgba(30,107,69,.09);
  display: flex; align-items: center; justify-content: center;
  color: var(--green); margin-bottom: 18px;
}
.cred-icon svg { width: 24px; height: 24px; }
.cred-card h4 {
  font-family: var(--font-disp); font-size: 16px; font-weight: 700;
  color: var(--ink); line-height: 1.4; margin-bottom: 8px;
}
.cred-card p { font-size: 13px; color: var(--sub); line-height: 1.75; }

/* ── BOOK ── */
.book-section { background: var(--green); padding: 80px 48px; }
.book-inner { max-width: 900px; margin: 0 auto; display: grid; grid-template-columns: auto 1fr; gap: 56px; align-items: center; }
.book-cover {
  width: 180px; aspect-ratio: 3/4; background: var(--green-d);
  border-radius: 6px; box-shadow: 8px 12px 32px rgba(0,0,0,.35);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 20px; text-align: center; flex-shrink: 0; position: relative; overflow: hidden;
}
.book-cover::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 16px; background: rgba(0,0,0,.2);
}
.book-cover-title {
  font-family: var(--font-disp); font-size: 15px; font-weight: 800;
  color: #fff; line-height: 1.4; position: relative; z-index: 1;
}
.book-cover-sub { font-size: 10px; color: rgba(255,255,255,.6); margin-top: 8px; position: relative; z-index: 1; }
.book-info-kt h3 {
  font-family: var(--font-disp); font-size: clamp(22px, 2.5vw, 32px); font-weight: 800;
  color: #fff; line-height: 1.2; margin-bottom: 16px;
}
.book-info-kt p { font-size: 15px; color: rgba(255,255,255,.72); line-height: 1.9; margin-bottom: 24px; }
.book-meta { display: flex; gap: 12px; flex-wrap: wrap; }
.book-tag {
  font-size: 12px; font-weight: 600; color: rgba(255,255,255,.8);
  border: 1px solid rgba(255,255,255,.25); padding: 5px 14px; border-radius: var(--radius-pill);
}
.btn-book {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; color: var(--green); padding: 14px 28px;
  border-radius: var(--radius-pill); font-size: 14px; font-weight: 700;
  margin-top: 24px; transition: all .15s;
}
.btn-book:hover { background: var(--cream); }

/* ── MEDIA ── */
.media-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 48px; }
.media-card {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-md); padding: 28px 24px;
}
.media-tag {
  display: inline-block; font-size: 10px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--radius-pill); margin-bottom: 14px;
}
.media-tag.tv { background: rgba(41,128,185,.12); color: #2980b9; }
.media-tag.magazine { background: rgba(142,68,173,.12); color: #8e44ad; }
.media-tag.web { background: rgba(22,160,133,.12); color: #16a085; }
.media-tag.seminar { background: rgba(30,107,69,.12); color: var(--green); }
.media-card h4 {
  font-family: var(--font-disp); font-size: 15px; font-weight: 700;
  color: var(--ink); line-height: 1.4; margin-bottom: 6px;
}
.media-card p { font-size: 13px; color: var(--sub); line-height: 1.7; }

/* ── INQUIRY ── */
.inquiry-section { background: var(--cream-d); }
.inquiry-types { display: grid; grid-template-columns: repeat(4,1fr); gap: 12px; margin: 40px 0; }
.inq-type {
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-md); padding: 24px 20px;
  text-align: center; transition: border-color .15s;
}
.inq-type:hover { border-color: var(--green); }
.inq-type-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(30,107,69,.09);
  display: flex; align-items: center; justify-content: center;
  color: var(--green); margin: 0 auto 12px;
}
.inq-type-icon svg { width: 22px; height: 22px; }
.inq-type h4 { font-family: var(--font-disp); font-size: 14px; font-weight: 700; color: var(--ink); margin-bottom: 4px; }
.inq-type p { font-size: 12px; color: var(--sub); line-height: 1.6; }
.contact-form-wrap {
  max-width: 640px; margin: 0 auto;
  background: var(--white); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 48px;
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .stats-bar { padding: 24px; }
  .story-grid { grid-template-columns: 1fr; gap: 40px; }
  .timeline::before { left: 60px; }
  .tl-item { grid-template-columns: 60px 1fr; }
  .tl-dot::before { left: -27px; }
  .cred-grid { grid-template-columns: 1fr 1fr; }
  .book-inner { grid-template-columns: 1fr; text-align: center; }
  .book-cover { margin: 0 auto; }
  .media-grid { grid-template-columns: 1fr 1fr; }
  .inquiry-types { grid-template-columns: 1fr 1fr; }
  .contact-form-wrap { padding: 28px 20px; }
}
@media (max-width: 600px) {
  .cred-grid { grid-template-columns: 1fr; }
  .media-grid { grid-template-columns: 1fr; }
}
