:root{
  --ink:#070A0D; --bone:#F4F2EC; --mute:#A4A29B; --faint:#7C7B76;
  --blood:#A82A20; --line:rgba(244,242,236,0.12);
  --fs:"Zen Kaku Gothic New",system-ui,-apple-system,sans-serif;
  color-scheme:dark;
}
*{box-sizing:border-box;margin:0;padding:0}
html{background:var(--ink);scroll-behavior:smooth}
body{min-height:100svh;background:var(--ink);color:var(--bone);font-family:var(--fs);
  font-weight:300;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:680px;margin:0 auto;padding:0 28px}
.member-hero{position:relative;min-height:42svh;padding:32px 28px 62px;display:flex;
  flex-direction:column;justify-content:flex-end;overflow:hidden;border-bottom:0.5px solid var(--line)}
.member-hero::before{content:"";position:absolute;inset:0;background:url("hero.jpg") center/contain no-repeat;
  opacity:.42}
.member-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,8,9,.5),rgba(8,8,9,.92))}
.hero-inner{position:relative;z-index:1;width:min(680px,100%);margin:0 auto}
.back{position:absolute;z-index:2;top:28px;left:max(28px,calc((100vw - 680px)/2 + 28px));
  color:var(--mute);font-size:13px;letter-spacing:.08em;transition:color .2s ease}
.back:hover{color:var(--bone)}
.eyebrow{font-size:11px;font-weight:500;letter-spacing:.42em;color:var(--faint);
  text-transform:lowercase;margin-bottom:24px}
h1{font-weight:700;font-size:clamp(38px,11vw,68px);line-height:1.04;letter-spacing:.03em}
.role{margin-top:14px;color:var(--mute);font-size:14px;letter-spacing:.26em}
.block{padding-block:clamp(62px,12vh,112px);border-top:0.5px solid var(--line)}
.block:first-child{border-top:0}
.copy{font-size:clamp(17px,4vw,21px);line-height:2.05;letter-spacing:.03em}
.sub{margin-top:22px;color:var(--faint);font-size:13px;line-height:1.9;letter-spacing:.04em}
.member-nav{display:flex;flex-direction:column}
.member-nav a{display:flex;justify-content:space-between;align-items:baseline;gap:18px;
  padding:16px 0;border-top:0.5px solid var(--line);transition:color .2s ease}
.member-nav a:last-child{border-bottom:0.5px solid var(--line)}
.member-nav .name{font-weight:500;font-size:16px;letter-spacing:.04em}
.member-nav .part{color:var(--faint);font-size:12px;letter-spacing:.16em;text-align:right;white-space:nowrap}
.member-nav .is-current .name{color:var(--blood)}
.member-nav a:hover .name{color:var(--bone)}
footer{padding:36px 0 54px;text-align:center;color:var(--faint);font-size:11px;letter-spacing:.3em}
a:focus-visible{outline:2px solid var(--blood);outline-offset:3px}

.member-profile-page{overflow-x:hidden}
.profile-hero{min-height:100svh;display:grid;border-bottom:0.5px solid var(--line)}
.profile-visual{position:relative;min-height:62svh;background:#05080A;overflow:hidden}
.profile-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;object-position:center bottom;z-index:0}
.profile-visual::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(7,10,13,0) 68%,var(--ink) 100%);pointer-events:none}
.profile-visual.is-kimura{background:#05080A url("kimura.webp") center bottom/contain no-repeat}
.profile-visual.is-kobayashi{background:#05080A url("kobayashi.webp") center bottom/contain no-repeat}
.profile-visual.is-hasegawa{background:#05080A url("hasegawa.webp") center bottom/contain no-repeat}
.profile-visual.is-yamanaka{background:#05080A url("yamanaka.webp") center bottom/contain no-repeat}
.profile-intro{padding:84px 28px 58px;display:flex;align-items:flex-end}
.profile-intro-inner{width:min(680px,100%);margin:0 auto}
.roman{display:block;margin-top:8px;color:var(--mute);font-weight:300;font-size:clamp(17px,4.5vw,25px);letter-spacing:.16em}
.profile-role{margin-top:22px;color:var(--mute);font-size:14px;line-height:1.9;letter-spacing:.18em}
.profile-lead{margin-top:34px;font-size:clamp(18px,4.5vw,24px);line-height:1.9;letter-spacing:.03em}
.profile-body{max-width:760px}
.profile-body .copy{font-size:clamp(16px,3.7vw,19px);line-height:2.05}
.profile-body .copy + .copy{margin-top:26px}
.profile-lang{margin-top:54px;padding-top:36px;border-top:0.5px solid var(--line)}
.profile-lang .eyebrow{margin-bottom:18px}
.language-switch{display:inline-flex;align-items:center;gap:10px;margin:0 0 30px;
  color:var(--faint);font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase}
.language-switch button{min-width:36px;min-height:34px;padding:6px 0;border:0;background:transparent;
  color:rgba(244,242,236,.38);font:inherit;letter-spacing:inherit;cursor:pointer;transition:color .18s ease}
.language-switch button[aria-pressed="true"]{color:rgba(244,242,236,.96)}
.language-switch button:hover{color:rgba(244,242,236,.78)}
.language-switch button:focus-visible{outline:2px solid var(--blood);outline-offset:3px}
.profile-copy [hidden]{display:none!important}

@media (min-width:860px){
  .profile-hero{grid-template-columns:minmax(390px,46vw) minmax(420px,1fr);min-height:100vh}
  .profile-visual{min-height:100vh}
  .profile-visual img{object-fit:contain;object-position:center center}
  .profile-visual.is-kimura,
  .profile-visual.is-kobayashi,
  .profile-visual.is-hasegawa,
  .profile-visual.is-yamanaka{background-position:center center}
  .profile-visual::after{background:linear-gradient(to right,rgba(7,10,13,0) 74%,var(--ink) 100%)}
  .profile-intro{min-height:100vh;padding:92px clamp(42px,6vw,86px) 78px}
  .profile-intro-inner{margin:0}
}
