:root{
  --c-text:#222222;
  --c-text-soft:#666666;
  --c-text-muted:#888888;
  --c-bg:#EFF0EE;
  --c-bg-cream:#EFF0EE;
  --c-bg-soft:#EFF0EE;
  --c-line:#D8D9D6;
  --c-line-soft:#E4E5E2;
  --c-accent:#BCD331;
  --c-accent-deep:#BCD331;
  --c-dark:#1A1A1A;

  --ff-jp:'Noto Sans JP',-apple-system,'Hiragino Kaku Gothic ProN',sans-serif;
  --ff-en:'Noto Sans JP',-apple-system,sans-serif;

  --container:1280px;
  --container-narrow:880px;
  --container-wide:1440px;
  --gutter:clamp(1.25rem,4vw,2.5rem);
  --space-section:clamp(5rem,11vw,9rem);
  --space-block:clamp(2.5rem,5vw,4rem);

  --r-md:8px;
  --r-lg:16px;

  --dur:.45s;
  --dur-hover:.28s;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--ff-jp);
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  font-size:15px;
  line-height:1.95;
  font-weight:400;
  font-feature-settings:"palt";
}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--c-accent);color:var(--c-dark)}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.container-narrow{max-width:var(--container-narrow);margin:0 auto;padding:0 var(--gutter)}
.container-wide{max-width:var(--container-wide);margin:0 auto;padding:0 var(--gutter)}

/* ===== HEADER ===== */
.header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur-hover) ease;
}
.header.scrolled{border-bottom-color:var(--c-line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:80px}
.logo{display:inline-flex;align-items:center;gap:.6rem;color:var(--c-dark)}
.logo-mark{
  font-family:var(--ff-en);font-weight:800;font-size:1.05rem;letter-spacing:.04em;
}
.logo-sub{font-size:.7rem;color:var(--c-text-soft);letter-spacing:.12em;font-weight:500;padding-left:.6rem;border-left:1px solid var(--c-line)}

.nav{display:flex;align-items:center;gap:2.4rem}
.nav-list{display:flex;align-items:center;gap:1.9rem}
.nav-list a{
  position:relative;font-size:.82rem;font-weight:500;color:var(--c-text);
  letter-spacing:.05em;padding:.5rem 0;display:inline-block;
  transition:color var(--dur-hover) ease;
}
.nav-list a::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:1.5px;
  background:var(--c-accent);
  transform:scaleX(0);transform-origin:right;transition:transform var(--dur-hover) ease;
}
.nav-list a:hover::after,.nav-list a.active::after{transform:scaleX(1);transform-origin:left}

.nav-cta{display:flex;gap:.6rem}
.btn-cta{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.65rem 1.2rem;border-radius:99px;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
  background:var(--c-dark);color:#fff;
  transition:background var(--dur-hover) ease,transform var(--dur-hover) ease;
}
.btn-cta:hover{background:var(--c-accent-deep);transform:translateY(-1px)}
.btn-cta.-accent{background:var(--c-accent);color:var(--c-dark)}
.btn-cta.-accent:hover{background:var(--c-accent-deep);color:#fff}
.btn-cta .arrow{display:inline-block;font-size:.75rem}

.menu-toggle{display:none;flex-direction:column;width:38px;height:38px;justify-content:center;align-items:center;gap:5px;border:1px solid var(--c-line);border-radius:50%}
.menu-toggle span{display:block;width:14px;height:1.5px;background:var(--c-dark);transition:transform var(--dur-hover) ease,opacity var(--dur-hover) ease}
.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ===== HERO / FV ===== */
.fv{
  position:relative;
  min-height:100vh;
  min-height:100svh;       /* iOS Safari の動的ビューポート対応 */
  padding:calc(80px + 2rem) 0 clamp(2.5rem,5vw,4.5rem);
  background:var(--c-bg-cream);
  overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
}
.fv-inner{position:relative;width:100%}
.fv-line{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(1rem,3vw,2.5rem);
}
.fv-line.line2{margin-top:clamp(1rem,2vw,1.6rem)}
.fv-text{
  font-family:var(--ff-en);
  font-weight:300;
  font-size:clamp(2.6rem,9vw,8rem);
  line-height:.95;
  letter-spacing:-.01em;
  color:var(--c-dark);
  white-space:nowrap;
}
.fv-text.-accent{color:var(--c-accent);font-weight:800;text-shadow:0 1px 0 rgba(188,211,49,.08)}
.fv-text.-bold{font-weight:600}
.fv-line.line1 .fv-text:first-child{justify-self:start}
.fv-line.line1 .fv-text:last-child{justify-self:start}
.fv-line.line2 .fv-text:nth-child(2){justify-self:start}
.fv-line.line2 .fv-text:last-child{justify-self:start}

.fv-image{
  position:relative;border-radius:8px;overflow:hidden;background:#D8D9D6;
  aspect-ratio:1/1;
  width:clamp(8rem,15vw,14rem);
  display:grid;place-items:center;
}
.fv-image.-wide{aspect-ratio:1.6/1;width:clamp(11rem,18vw,17rem)}
.fv-image .ph{
  text-align:center;font-size:.7rem;color:var(--c-text-muted);
  padding:.55rem .9rem;border:1px dashed #B0B1AE;border-radius:6px;background:rgba(255,255,255,.6);line-height:1.4;
}
.fv-image .ph b{display:block;font-size:.78rem;color:var(--c-dark);font-weight:600;margin-bottom:.2rem}

.fv-jp{
  display:block;margin-top:1.4rem;text-align:right;
  font-size:clamp(1.1rem,1.8vw,1.5rem);font-weight:500;color:var(--c-dark);letter-spacing:.04em;line-height:1.6;
}

/* ===== BODY COPY ===== */
.bodycopy{
  position:relative;padding:var(--space-section) 0;background:var(--c-bg);overflow:hidden;
}
.bodycopy-inner{position:relative;max-width:560px;margin:0 auto;text-align:left}
.bodycopy-inner p{font-size:1.02rem;line-height:2.4;letter-spacing:.04em;margin-bottom:1.6rem;color:var(--c-text)}
.bodycopy-inner p:last-of-type{margin-bottom:0}

.bodycopy-img{
  position:absolute;border-radius:8px;overflow:hidden;background:#D8D9D6;
  display:grid;place-items:center;
}
.bodycopy-img.-a{top:-2.5rem;left:-12rem;width:13rem;aspect-ratio:3/2}
.bodycopy-img.-b{bottom:-3rem;right:-13rem;width:15rem;aspect-ratio:3/2}
.bodycopy-img .ph{
  font-size:.66rem;color:var(--c-text-muted);text-align:center;padding:.45rem .8rem;border:1px dashed #B0B1AE;border-radius:6px;background:rgba(255,255,255,.6);line-height:1.4;
}

/* ===== SECTION COMMON ===== */
.section{padding:var(--space-section) 0;background:var(--c-bg)}
.section.-cream{background:var(--c-bg-cream)}
.section.-dark{background:var(--c-dark);color:#fff}

.hgroup{display:flex;flex-direction:column;gap:.7rem;margin-bottom:var(--space-block)}
.hgroup .subtitle{
  font-family:var(--ff-en);font-size:clamp(2.8rem,6vw,5rem);font-weight:300;
  line-height:.95;letter-spacing:-.01em;color:var(--c-dark);
}
.hgroup .title{
  font-size:clamp(1rem,1.5vw,1.15rem);font-weight:500;letter-spacing:.06em;color:var(--c-text-soft);line-height:1.6;
}
.section.-dark .hgroup .subtitle{color:#fff}
.section.-dark .hgroup .title{color:rgba(255,255,255,.65)}

/* ===== SECTION CARD (about / business / numbers etc) ===== */
.feature{
  display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,4rem);
}
.feature-image{
  border-radius:var(--r-md);overflow:hidden;background:#D8D9D6;aspect-ratio:3/2;
  display:grid;place-items:center;
}
.feature-image .ph{
  font-size:.78rem;color:var(--c-text-muted);text-align:center;padding:.6rem 1rem;border:1px dashed #B0B1AE;border-radius:6px;background:rgba(255,255,255,.7);
}
.feature-image .ph b{display:block;font-size:.85rem;color:var(--c-dark);font-weight:600;margin-bottom:.2rem}
.feature-text{font-size:.95rem;line-height:2.1;color:var(--c-text);max-width:48em}

/* link button (animated underline) */
.linkbtn{
  display:inline-grid;grid-template-columns:1fr auto;align-items:end;gap:1.2rem;
  position:relative;min-width:clamp(15rem,28vw,22rem);
  padding-bottom:1rem;padding-top:1.6rem;
  margin-top:2rem;
}
.linkbtn::before{
  content:'';position:absolute;left:0;right:0;top:0;height:1.5px;background:var(--c-line);
}
.linkbtn::after{
  content:'';position:absolute;left:0;top:0;height:1.5px;width:0;background:var(--c-accent-deep);
  transition:width var(--dur-hover) ease;
}
.linkbtn:hover::after{width:100%}
.linkbtn .text{font-size:.92rem;font-weight:500;line-height:1.4;color:var(--c-dark)}
.linkbtn .icon{
  display:inline-grid;place-items:center;width:36px;height:36px;border-radius:50%;
  background:var(--c-dark);color:#fff;font-size:.85rem;
  transition:background var(--dur-hover) ease,transform var(--dur-hover) ease;
}
.linkbtn:hover .icon{background:var(--c-accent-deep);transform:translateX(3px)}

.section.-dark .linkbtn::before{background:rgba(255,255,255,.18)}
.section.-dark .linkbtn .text{color:#fff}
.section.-dark .linkbtn .icon{background:#fff;color:var(--c-dark)}
.section.-dark .linkbtn:hover .icon{background:var(--c-accent);color:var(--c-dark)}

/* ===== PEOPLE / DUAL CARDS ===== */
.dualcards{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.dualcard{
  position:relative;border-radius:var(--r-lg);overflow:hidden;
  aspect-ratio:3/4;background:#D8D9D6;
  display:grid;align-items:end;
  transition:transform var(--dur) ease;
}
.dualcard:hover{transform:translateY(-4px)}
.dualcard .dc-ph{
  position:absolute;inset:0;display:grid;place-items:center;
  font-size:.85rem;color:var(--c-text-muted);
}
.dualcard .dc-ph .ph{padding:.6rem 1rem;border:1px dashed #B0B1AE;border-radius:6px;background:rgba(255,255,255,.7);text-align:center}
.dualcard .dc-ph .ph b{display:block;color:var(--c-dark);font-weight:600;margin-bottom:.2rem}
.dualcard .dc-body{
  position:relative;display:grid;grid-template-columns:1fr auto;gap:.8rem;align-items:center;
  padding:1.4rem 1.5rem;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.55) 60%,rgba(0,0,0,.8) 100%);
  color:#fff;
}
.dualcard .dc-text{font-size:1rem;font-weight:600;line-height:1.5}
.dualcard .dc-icon{
  display:inline-grid;place-items:center;width:30px;height:30px;border-radius:50%;
  background:#fff;color:var(--c-dark);font-size:.75rem;
}

/* ===== POSITION CARDS ===== */
.positions{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.position{
  position:relative;display:flex;flex-direction:column;
  min-height:100%;padding:1.6rem 1.7rem;
  border:1.5px solid var(--c-line);border-radius:var(--r-md);
  background:var(--c-bg);transition:border-color var(--dur-hover) ease;
}
.position:hover{border-color:var(--c-accent-deep)}
.position .p-title-ja{font-size:1.1rem;font-weight:600;color:var(--c-dark);line-height:1.4}
.position .p-title-en{margin-top:.4rem;font-size:.78rem;color:var(--c-text-soft);font-weight:500;letter-spacing:.04em}
.position .p-summary{
  display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:end;
  margin-top:1.2rem;flex:1;
}
.position .p-summary p{font-size:.82rem;line-height:1.7;color:var(--c-text-soft)}
.position .p-icon{
  display:inline-grid;place-items:center;width:28px;height:28px;border-radius:50%;
  background:var(--c-dark);color:#fff;font-size:.7rem;align-self:end;flex-shrink:0;
  transition:background var(--dur-hover) ease;
}
.position:hover .p-icon{background:var(--c-accent-deep)}

/* ===== NUMBERS PANEL (実績) ===== */
.numbers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.num{padding:1.6rem 0;border-top:1.5px solid rgba(255,255,255,.16)}
.num .n-label{font-size:.75rem;letter-spacing:.1em;color:rgba(255,255,255,.55);margin-bottom:.7rem;font-weight:500}
.num .n-value{
  font-family:var(--ff-en);font-size:clamp(2rem,3.6vw,3rem);font-weight:300;line-height:1;
  color:#fff;letter-spacing:-.02em;display:flex;align-items:baseline;gap:.2rem;
}
.num .n-value em{font-style:normal;font-size:.42em;color:var(--c-accent);font-weight:600;margin-left:.1em}
.num .n-note{font-size:.74rem;color:rgba(255,255,255,.5);margin-top:.6rem;line-height:1.6}

/* ===== NEWS LIST ===== */
.news-list{display:flex;flex-direction:column;gap:0;max-width:920px}
.news-row{
  display:grid;grid-template-columns:120px 90px 1fr auto;gap:1.5rem;align-items:center;
  padding:1.4rem 0;border-bottom:1px solid var(--c-line);
  transition:padding-left var(--dur-hover) ease,background var(--dur-hover) ease;
}
.news-row:first-child{border-top:1px solid var(--c-line)}
.news-row:hover{padding-left:.6rem}
.news-date{font-family:var(--ff-en);font-size:.85rem;color:var(--c-text-soft);font-weight:500}
.news-tag{
  display:inline-block;font-size:.68rem;letter-spacing:.1em;font-weight:600;
  padding:.2rem .65rem;border:1px solid var(--c-line);border-radius:99px;color:var(--c-text-soft);
}
.news-tag.-press{border-color:var(--c-accent-deep);color:var(--c-accent-deep)}
.news-tag.-media{border-color:#c89d2c;color:#c89d2c}
.news-title{font-size:.95rem;font-weight:500;color:var(--c-dark);line-height:1.7}
.news-row .arrow{font-size:.85rem;color:var(--c-text-muted)}

/* ===== FOOTER ===== */
.footer{background:var(--c-dark);color:rgba(255,255,255,.7);padding:5rem 0 2.5rem}
.footer-main{display:grid;grid-template-columns:1.3fr 1.7fr;gap:clamp(2rem,5vw,5rem);padding-bottom:3.5rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer .logo{color:#fff}
.footer .logo-sub{color:rgba(255,255,255,.55);border-color:rgba(255,255,255,.18)}
.footer-tagline{margin-top:1.4rem;font-size:.85rem;color:rgba(255,255,255,.55);line-height:1.85;max-width:24em}
.footer-nav{display:flex;flex-wrap:wrap;gap:1rem 2.3rem;align-content:flex-start}
.footer-nav a{font-size:.85rem;color:rgba(255,255,255,.75);transition:color var(--dur-hover) ease}
.footer-nav a:hover{color:var(--c-accent)}
.footer-sub{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;flex-wrap:wrap;gap:1rem}
.footer-external{display:flex;gap:1.6rem;flex-wrap:wrap}
.footer-external a{font-size:.78rem;color:rgba(255,255,255,.55);transition:color var(--dur-hover) ease}
.footer-external a:hover{color:var(--c-accent)}
.footer-copy{font-family:var(--ff-en);font-size:.72rem;color:rgba(255,255,255,.4);letter-spacing:.05em}

/* ===== REVEAL ANIMATION (Reference-faithful) ===== */
:root{
  --duration-base:1.6s;
  --duration-hover:.28s;
  --rv-ease:cubic-bezier(.2,.7,.15,1);
  --rv-ease-out:cubic-bezier(.22,1,.36,1);
}

/* basic fade-up */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 1s var(--rv-ease),transform 1s var(--rv-ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* === Heading clip-path wipe + green shadow (reference-faithful) === */
/* duration-base * .5 = 0.8s for clip-path
   duration-base * .1 = 0.16s clip-path delay
   duration-base * .2 = 0.32s opacity delay
   shadow color: lime yellow (#BCD331) */
.hgroup .subtitle,.hgroup .title{position:relative;overflow:visible;display:block}
.hgroup .inner{
  position:relative;display:inline-block;
  width:fit-content;max-width:100%;
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  transition:clip-path .8s .16s ease-out;
  will-change:clip-path;
}
.hgroup.is-hidden .inner{
  clip-path:polygon(0 0,0 0,0 100%,0 100%);
}
.hgroup .inner > span[aria-hidden="true"]{
  position:absolute;top:0;left:0;z-index:1;
  display:inline-block;width:fit-content;max-width:100%;
  color:var(--c-accent);            /* lightgreen, like reference */
  opacity:0;
  transition:opacity .8s .32s ease-in-out;
  pointer-events:none;
}
.hgroup.is-hidden .inner > span[aria-hidden="true"]{opacity:1}
.section.-dark .hgroup .inner > span[aria-hidden="true"]{color:var(--c-accent)}
@media(prefers-reduced-motion:reduce){
  .hgroup .inner,.hgroup .inner > span[aria-hidden="true"]{transition:none}
  .hgroup.is-hidden .inner{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
  .hgroup.is-hidden .inner > span[aria-hidden="true"]{opacity:0}
}

/* === Image scale + fade reveal (reference-faithful)
   Stronger scale (1.12 → 1) over duration-base * .85 = 1.36s
   Opacity 0 → 1 over duration-base * .55 = 0.88s with .15 delay */
.rv-img{
  position:relative;
  opacity:0;
  transform:scale(1.12);
  transform-origin:center center;
  transition:opacity .88s .15s ease-out,transform 1.36s var(--rv-ease-out);
  will-change:opacity,transform;
}
.rv-img.in{opacity:1;transform:scale(1)}
.feature-image,.fv-image,.bodycopy-img,.dualcard .dc-ph{overflow:hidden}
@media(prefers-reduced-motion:reduce){
  .rv-img{transition:none;opacity:1;transform:none}
}

/* === FV reveal (page-load) ===
   Text: clip-path wipe + green shadow (same as hgroup, reference-faithful)
   Image: fade + scale stagger */
.fv{visibility:hidden}
.fv.is-ready{visibility:visible}

/* Image fade + scale */
.fv .fv-image{
  opacity:0;transform:translateY(20px) scale(1.1);
  transition:opacity 1.1s var(--rv-ease-out),transform 1.3s var(--rv-ease-out);
}
.fv.is-ready .fv-image{opacity:1;transform:translateY(0) scale(1)}

/* Text clip-path wipe — matches hgroup pattern.
   Primary text reveals left→right; green shadow visible underneath until wipe completes. */
.fv .fv-text .inner,.fv .fv-jp .inner{
  position:relative;display:inline-block;width:fit-content;max-width:100%;
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  transition:clip-path .85s ease-out;
  will-change:clip-path;
}
.fv:not(.is-ready) .fv-text .inner,.fv:not(.is-ready) .fv-jp .inner{
  clip-path:polygon(0 0,0 0,0 100%,0 100%);
}
.fv .fv-text .inner > span[aria-hidden="true"],.fv .fv-jp .inner > span[aria-hidden="true"]{
  position:absolute;top:0;left:0;
  color:var(--c-accent);
  opacity:0;
  transition:opacity .8s ease-in-out;
  pointer-events:none;
  font-weight:inherit;
}
.fv:not(.is-ready) .fv-text .inner > span[aria-hidden="true"],.fv:not(.is-ready) .fv-jp .inner > span[aria-hidden="true"]{opacity:1}
/* CAPITAL./TRUST. はライム本文。シャドウを黒にして「黒 → ライム」方向のリビールに */
.fv .fv-text.-accent .inner > span[aria-hidden="true"]{color:var(--c-dark)}

/* Stagger delays */
.fv.is-ready .fv-line.line1 .fv-text:nth-child(1) .inner{transition-delay:.1s}
.fv.is-ready .fv-line.line1 .fv-text:nth-child(1) .inner > span[aria-hidden="true"]{transition-delay:.22s}
.fv.is-ready .fv-line.line1 .fv-image{transition-delay:.22s,.22s}
.fv.is-ready .fv-line.line1 .fv-text:nth-child(3) .inner{transition-delay:.34s}
.fv.is-ready .fv-line.line1 .fv-text:nth-child(3) .inner > span[aria-hidden="true"]{transition-delay:.46s}
.fv.is-ready .fv-line.line2 .fv-image{transition-delay:.46s,.46s}
.fv.is-ready .fv-line.line2 .fv-text:nth-child(2) .inner{transition-delay:.58s}
.fv.is-ready .fv-line.line2 .fv-text:nth-child(2) .inner > span[aria-hidden="true"]{transition-delay:.7s}
.fv.is-ready .fv-line.line2 .fv-text:nth-child(3) .inner{transition-delay:.7s}
.fv.is-ready .fv-line.line2 .fv-text:nth-child(3) .inner > span[aria-hidden="true"]{transition-delay:.82s}
.fv.is-ready .fv-jp .inner{transition-delay:.95s}
.fv.is-ready .fv-jp .inner > span[aria-hidden="true"]{transition-delay:1.07s}

@media(prefers-reduced-motion:reduce){
  .fv .fv-text .inner,.fv .fv-jp .inner,.fv .fv-image{transition:none}
  .fv .fv-text .inner,.fv .fv-jp .inner{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
  .fv .fv-text .inner > span[aria-hidden="true"],.fv .fv-jp .inner > span[aria-hidden="true"]{opacity:0}
  .fv .fv-image{opacity:1;transform:none}
}

/* clip mask line reveal (utility — not currently in markup) */
.reveal-clip{display:block;overflow:hidden}
.reveal-clip > *{display:block;transform:translateY(110%);transition:transform .7s var(--rv-ease)}
.reveal-clip.in > *{transform:translateY(0)}

/* === Hover refinements (reference-faithful) === */
@media(hover:hover){
  .position{transition:border-color .28s ease-in-out}
  .position:hover{border-color:var(--c-accent)}
  .position .p-icon{transition:background .28s ease,transform .28s ease}
  .position:hover .p-icon{background:var(--c-accent-deep);transform:translateX(2px)}
  .linkbtn::after{transition:width .35s ease-in-out}
  .linkbtn .icon{transition:background .28s ease,transform .28s ease}
  .nav-list a::after{transition:transform .28s ease-in-out}
}

/* ===== COUNTUP ===== */
.num-value[data-count]{visibility:visible}

/* ===== RESPONSIVE (900px以下で1カラム) ===== */
@media (max-width:900px){
  body{font-size:14.5px}
  .header-inner{height:64px}
  .menu-toggle{display:flex}
  .nav{
    position:fixed;top:64px;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    padding:1.4rem var(--gutter);background:var(--c-bg);border-bottom:1px solid var(--c-line);
    transform:translateY(-160%);transition:transform var(--dur) ease;
    box-shadow:0 12px 26px rgba(0,0,0,.05);
  }
  .nav.open{transform:translateY(0)}
  .nav-list{flex-direction:column;gap:0;align-items:stretch;width:100%}
  .nav-list a{padding:1rem 0;border-bottom:1px solid var(--c-line);font-size:1rem}
  .nav-cta{padding-top:1rem;flex-direction:column;width:100%}
  .nav-cta .btn-cta{justify-content:center}

  .fv{padding-top:calc(64px + 3rem)}
  .fv-line{grid-template-columns:1fr;gap:1rem}
  .fv-line.line2{margin-top:.4rem}
  .fv-text{font-size:clamp(2.4rem,12vw,4rem);white-space:normal}
  .fv-line.line1 .fv-text:first-child,.fv-line.line1 .fv-text:last-child{justify-self:center;text-align:center}
  .fv-line.line2 .fv-text:nth-child(2),.fv-line.line2 .fv-text:last-child{justify-self:center;text-align:center}
  .fv-image{width:60%;margin:0 auto;aspect-ratio:3/2}
  .fv-image.-wide{width:80%}
  .fv-jp{text-align:center;margin-top:2rem}

  .bodycopy-img.-a,.bodycopy-img.-b{display:none}

  .hgroup .subtitle{font-size:clamp(2.4rem,10vw,4rem)}

  .dualcards{grid-template-columns:1fr;gap:1rem}
  .positions{grid-template-columns:1fr;gap:.85rem}
  .numbers-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .news-row{grid-template-columns:auto auto 1fr;gap:.6rem 1.1rem;padding:1.2rem 0}
  .news-row .arrow{grid-column:1 / -1;justify-self:end;margin-top:.2rem}
  .footer-main{grid-template-columns:1fr;gap:2.5rem}
  .footer-sub{flex-direction:column;align-items:flex-start;text-align:left}
}
@media (max-width:560px){
  .numbers-grid{grid-template-columns:1fr;gap:0}
  .fv-image{width:74%}
}

/* ===== PAGE HERO (subpages — substitutes FV) ===== */
.page-hero{
  position:relative;
  min-height:65vh;
  min-height:65svh;
  padding:calc(80px + clamp(2.5rem,5vw,4rem)) 0 clamp(2.5rem,5vw,4rem);
  background:var(--c-bg-cream);overflow:hidden;
  display:flex;flex-direction:column;justify-content:center;
}
.page-hero-inner{position:relative;width:100%}
.crumb{
  font-family:var(--ff-en);font-size:.72rem;letter-spacing:.16em;font-weight:600;
  color:var(--c-text-soft);margin-bottom:1.8rem;text-transform:uppercase;
}
.crumb a{color:var(--c-text-soft);transition:color .25s ease}
.crumb a:hover{color:var(--c-dark)}
.crumb i{font-style:normal;margin:0 .5rem;color:var(--c-line)}
.ph-en{
  font-family:var(--ff-en);
  font-size:clamp(3.4rem,10vw,8rem);
  font-weight:300;line-height:.92;letter-spacing:-.015em;color:var(--c-dark);
}
.ph-en .em{color:var(--c-accent);font-weight:800}
.ph-jp{margin-top:1.2rem;font-size:clamp(1.15rem,1.8vw,1.5rem);font-weight:500;color:var(--c-dark);letter-spacing:.04em}
.ph-lead{
  margin-top:2rem;max-width:42em;
  font-size:clamp(.95rem,1.15vw,1.1rem);line-height:2.1;color:var(--c-text);
}

/* page-hero reveal — clip-path wipe on en title (like FV), fade on others */
.page-hero{visibility:hidden}
.page-hero.is-ready{visibility:visible}

/* en title: clip-path wipe + shadow */
.page-hero .ph-en .inner{
  position:relative;display:inline-block;width:fit-content;max-width:100%;
  clip-path:polygon(0 0,100% 0,100% 100%,0 100%);
  transition:clip-path .9s ease-out .25s;
  will-change:clip-path;
}
.page-hero:not(.is-ready) .ph-en .inner{clip-path:polygon(0 0,0 0,0 100%,0 100%)}
.page-hero .ph-en .inner > span[aria-hidden="true"]{
  position:absolute;top:0;left:0;color:var(--c-accent);opacity:0;
  transition:opacity .8s ease-in-out .42s;pointer-events:none;font-weight:inherit;
}
.page-hero:not(.is-ready) .ph-en .inner > span[aria-hidden="true"]{opacity:1}

/* crumb / jp / lead: fade-up stagger */
.page-hero .crumb,.page-hero .ph-jp,.page-hero .ph-lead{
  opacity:0;transform:translateY(20px);
  transition:opacity 1.05s var(--rv-ease-out),transform 1.2s var(--rv-ease-out);
}
.page-hero.is-ready .crumb,.page-hero.is-ready .ph-jp,.page-hero.is-ready .ph-lead{opacity:1;transform:translateY(0)}
.page-hero.is-ready .crumb{transition-delay:.1s,.1s}
.page-hero.is-ready .ph-jp{transition-delay:.7s,.7s}
.page-hero.is-ready .ph-lead{transition-delay:.85s,.85s}
@media(prefers-reduced-motion:reduce){
  .page-hero .crumb,.page-hero .ph-jp,.page-hero .ph-lead,.page-hero .ph-en .inner,.page-hero .ph-en .inner > span[aria-hidden="true"]{transition:none}
  .page-hero .crumb,.page-hero .ph-jp,.page-hero .ph-lead{opacity:1;transform:none}
  .page-hero .ph-en .inner{clip-path:polygon(0 0,100% 0,100% 100%,0 100%)}
  .page-hero .ph-en .inner > span[aria-hidden="true"]{opacity:0}
}

/* ===== Sub-page utilities ===== */
.section.first{padding-top:clamp(3rem,6vw,5rem)}
.hgroup.left{align-items:flex-start}
.hgroup .subtitle.-sm{font-size:clamp(2rem,4vw,3rem)}

/* member grid */
.member-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.member-card{
  background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);
  overflow:hidden;transition:border-color var(--dur-hover) ease;
}
.member-card:hover{border-color:var(--c-accent)}
.member-photo{aspect-ratio:1/1.15;background:#D8D9D6;display:grid;place-items:center;overflow:hidden}
.member-photo .ph{font-size:.7rem;color:var(--c-text-muted);padding:.5rem .85rem;background:rgba(255,255,255,.7);border:1px dashed #B0B1AE;border-radius:4px;text-align:center}
.member-photo .ph b{display:block;color:var(--c-dark);font-weight:600;margin-bottom:.2rem;font-size:.78rem}
.member-body{padding:1.3rem 1.4rem}
.member-role{font-family:var(--ff-en);font-size:.68rem;letter-spacing:.18em;font-weight:600;color:var(--c-accent-deep);margin-bottom:.5rem;text-transform:uppercase}
.member-name{font-size:1.05rem;font-weight:700;color:var(--c-dark);line-height:1.4}
.member-name-ja{font-size:.78rem;color:var(--c-text-soft);font-weight:500;margin-top:.2rem}
.member-quote{margin-top:.9rem;padding-top:.85rem;border-top:1px dashed var(--c-line);font-size:.82rem;color:var(--c-text);line-height:1.7}
.member-quote::before{content:'\201C';color:var(--c-accent);font-weight:700;font-size:1.4em;line-height:0;vertical-align:-.2em;margin-right:.1em}

/* interview cards */
.iv-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.iv-card{
  display:grid;grid-template-columns:130px 1fr;gap:1.4rem;align-items:center;
  background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);padding:1.4rem 1.6rem;
  transition:border-color var(--dur-hover) ease;
}
.iv-card:hover{border-color:var(--c-accent)}
.iv-photo{aspect-ratio:1;background:#D8D9D6;border-radius:var(--r-md);display:grid;place-items:center;overflow:hidden}
.iv-photo .ph{font-size:.62rem;color:var(--c-text-muted);text-align:center;line-height:1.4;padding:.3rem .55rem;background:rgba(255,255,255,.6);border:1px dashed #B0B1AE;border-radius:4px}
.iv-meta{font-family:var(--ff-en);font-size:.66rem;letter-spacing:.16em;color:var(--c-text-soft);margin-bottom:.4rem;font-weight:600;text-transform:uppercase}
.iv-name{font-size:1rem;font-weight:700;color:var(--c-dark);margin-bottom:.3rem}
.iv-prev{font-size:.76rem;color:var(--c-text-soft);margin-bottom:.55rem}
.iv-quote{font-size:.85rem;color:var(--c-text);line-height:1.7}
.iv-quote::before{content:'\201C';color:var(--c-accent);font-weight:700;margin-right:.1em}

/* company table */
.company-table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{text-align:left;padding:1rem 0;border-bottom:1px solid var(--c-line);font-size:.9rem;line-height:1.85}
.company-table th{width:28%;color:var(--c-text-soft);font-weight:500;font-size:.85rem;letter-spacing:.04em}
.company-table td{color:var(--c-text)}

/* CEO message */
.ceo-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.ceo-photo{aspect-ratio:4/5;background:#D8D9D6;border-radius:var(--r-lg);display:grid;place-items:center;overflow:hidden}
.ceo-photo .ph{font-size:.78rem;color:var(--c-text-muted);text-align:center;padding:.6rem 1rem;background:rgba(255,255,255,.7);border:1px dashed #B0B1AE;border-radius:4px}
.ceo-photo .ph b{display:block;color:var(--c-dark);font-weight:600;font-size:.88rem;margin-bottom:.2rem}
.ceo-text h3{font-family:var(--ff-en);font-size:clamp(1.8rem,3.6vw,2.8rem);font-weight:300;line-height:1.2;color:var(--c-dark);margin-bottom:.7rem}
.ceo-text h3 .em{color:var(--c-accent-deep);font-weight:800}
.ceo-text .ja-sub{font-size:1.05rem;font-weight:500;color:var(--c-dark);margin-bottom:1.8rem}
.ceo-text p{font-size:.95rem;line-height:2.1;color:var(--c-text);margin-bottom:1.1rem}
.ceo-sign{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--c-line);font-size:.82rem;color:var(--c-text-soft)}
.ceo-sign strong{display:block;font-size:1.05rem;color:var(--c-dark);font-weight:700;margin-top:.3rem}

/* history timeline */
.history{position:relative;max-width:820px;margin:0 auto;padding-left:1.5rem}
.history::before{content:'';position:absolute;left:80px;top:.5rem;bottom:.5rem;width:1.5px;background:var(--c-line)}
.history-row{display:grid;grid-template-columns:100px 1fr;gap:2.2rem;padding:1rem 0;position:relative}
.history-row::before{content:'';position:absolute;left:76px;top:1.5rem;width:9px;height:9px;border-radius:50%;background:var(--c-accent-deep);box-shadow:0 0 0 4px var(--c-bg-cream)}
.section:not(.-cream) .history-row::before{box-shadow:0 0 0 4px var(--c-bg)}
.history-year{font-family:var(--ff-en);font-size:1rem;font-weight:700;color:var(--c-dark);line-height:1.4;padding-top:.2rem}
.history-text{font-size:.9rem;line-height:1.95;color:var(--c-text)}
.history-text small{display:block;font-size:.78rem;color:var(--c-text-soft);margin-top:.25rem}

/* industries grid (results) */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.ind-cell{padding:1.4rem 1.3rem;background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);transition:border-color var(--dur-hover) ease}
.ind-cell:hover{border-color:var(--c-accent)}
.ind-name{font-size:.88rem;font-weight:600;color:var(--c-dark);margin-bottom:.6rem}
.ind-stat{font-family:var(--ff-en);font-size:1.5rem;font-weight:700;color:var(--c-dark);line-height:1}
.ind-stat small{font-size:.55em;color:var(--c-text-soft);font-weight:500;margin-left:.15em}
.ind-bar{height:3px;background:var(--c-bg-cream);border-radius:2px;margin-top:.9rem;overflow:hidden}
.section.-cream .ind-bar{background:#E8E5DA}
.ind-bar span{display:block;height:100%;background:var(--c-accent)}

/* voice grid */
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.voice-card{background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);padding:1.7rem 1.6rem;display:flex;flex-direction:column;gap:1rem;transition:border-color var(--dur-hover) ease}
.voice-card:hover{border-color:var(--c-accent)}
.voice-quote{font-size:.92rem;line-height:1.85;color:var(--c-text);flex:1}
.voice-quote::before{content:'\201C';color:var(--c-accent);font-size:2em;line-height:0;vertical-align:-.3em;font-weight:700;margin-right:.1em}
.voice-meta{display:flex;align-items:center;gap:.85rem;padding-top:.9rem;border-top:1px solid var(--c-line)}
.voice-avatar{width:44px;height:44px;border-radius:50%;background:#D8D9D6;display:grid;place-items:center;font-size:.6rem;color:var(--c-text-soft);flex-shrink:0}
.voice-info b{display:block;font-size:.85rem;color:var(--c-dark);font-weight:600;margin-bottom:.15rem}
.voice-info span{font-size:.74rem;color:var(--c-text-soft)}

/* bank list */
.banks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.7rem;margin-top:1rem}
.bank-cell{padding:.95rem 1rem;background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);text-align:center;font-size:.84rem;color:var(--c-dark);font-weight:500;transition:border-color var(--dur-hover) ease}
.bank-cell:hover{border-color:var(--c-accent)}
.bank-cat-label{font-family:var(--ff-en);font-size:.72rem;letter-spacing:.16em;color:var(--c-accent-deep);font-weight:600;margin:2rem 0 .7rem;text-transform:uppercase}
.bank-cat-label:first-child{margin-top:0}

/* news listing page */
.news-list{display:flex;flex-direction:column;gap:0;max-width:980px}
.news-list .news-row{padding:1.4rem 0}

/* benefits */
.benefit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.benefit-cell{padding:1.2rem 1.3rem;background:var(--c-bg);border:1.5px solid var(--c-line);border-radius:var(--r-md);transition:border-color var(--dur-hover) ease}
.benefit-cell:hover{border-color:var(--c-accent)}
.benefit-label{font-family:var(--ff-en);font-size:.68rem;color:var(--c-accent-deep);letter-spacing:.14em;font-weight:600;margin-bottom:.5rem;text-transform:uppercase}
.benefit-val{font-size:.94rem;color:var(--c-dark);font-weight:600;line-height:1.5}
.benefit-val small{display:block;font-size:.75rem;color:var(--c-text-soft);font-weight:400;margin-top:.25rem;line-height:1.6}

/* responsive overrides for new components */
@media (max-width:900px){
  .member-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .iv-grid{grid-template-columns:1fr;gap:1rem}
  .iv-card{grid-template-columns:90px 1fr;padding:1.1rem 1.2rem;gap:1rem}
  .ceo-grid{grid-template-columns:1fr;gap:2rem}
  .history{padding-left:0}
  .history::before{left:60px}
  .history-row{grid-template-columns:78px 1fr;gap:1.3rem}
  .history-row::before{left:56px}
  .ind-grid{grid-template-columns:1fr 1fr;gap:.7rem}
  .voice-grid{grid-template-columns:1fr;gap:.95rem}
  .banks-grid{grid-template-columns:1fr 1fr;gap:.6rem}
  .benefit-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .member-grid{grid-template-columns:1fr;gap:.95rem}
  .ind-grid,.banks-grid,.benefit-grid{grid-template-columns:1fr}
}

/* ====================================================
   FEATURE LAYOUT VARIANTS — 画像配置バリエーション
   ==================================================== */

/* aspect-ratio variants (single value) */
.feature-image.-wide{aspect-ratio:16/9}
.feature-image.-square{aspect-ratio:1/1}
.feature-image.-portrait{aspect-ratio:3/4}
.feature-image.-tall{aspect-ratio:2/3}

/* -side : image on the right, content on the left (50/50) */
.feature.-side{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:clamp(2rem,6vw,5rem);
}
.feature.-side .feature-image{aspect-ratio:4/5;grid-row:1 / span 3}
.feature.-side .feature-text{grid-column:1}
.feature.-side .linkbtn{grid-column:1}

/* -side -flip : image on the LEFT, content on the right */
.feature.-side.-flip .feature-image{order:-1;grid-column:1}
.feature.-side.-flip .feature-text{grid-column:2}
.feature.-side.-flip .linkbtn{grid-column:2}

/* -bleed-right : image extends past the right edge of the container */
.feature .feature-image.-bleed-right{margin-right:calc(-1 * var(--gutter) - 1rem)}
.feature .feature-image.-bleed-left{margin-left:calc(-1 * var(--gutter) - 1rem)}

/* -duo : two images side by side */
.feature-images{
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2.5vw,1.7rem);
}
.feature-images .feature-image{aspect-ratio:4/5}

/* -split : asymmetric — image takes 1.4fr (left), text+btn 1fr (right, aligned end) */
.feature.-split{
  display:grid;
  grid-template-columns:1.3fr 1fr;
  gap:clamp(2rem,5vw,4rem);
  align-items:end;
}
.feature.-split .feature-image{aspect-ratio:4/5;grid-row:1 / span 3}
.feature.-split .feature-text{grid-column:2;grid-row:1}
.feature.-split .linkbtn{grid-column:2;grid-row:2}

/* -split -flip : image on right */
.feature.-split.-flip{grid-template-columns:1fr 1.3fr}
.feature.-split.-flip .feature-image{order:0;grid-column:2}
.feature.-split.-flip .feature-text{grid-column:1;grid-row:1}
.feature.-split.-flip .linkbtn{grid-column:1;grid-row:2}

/* -gallery : 1 large image + 2 small (mosaic) */
.feature-gallery{
  display:grid;grid-template-columns:1.6fr 1fr;grid-template-rows:1fr 1fr;
  gap:clamp(1rem,2vw,1.5rem);min-height:36rem;
}
.feature-gallery > .feature-image:first-child{grid-row:1 / span 2;aspect-ratio:auto}
.feature-gallery > .feature-image:not(:first-child){aspect-ratio:4/3}

/* Responsive: collapse to single column on mobile */
@media (max-width:900px){
  .feature.-side,.feature.-split,.feature.-split.-flip,.feature-gallery{
    grid-template-columns:1fr;grid-template-rows:auto;
  }
  .feature.-side .feature-image,.feature.-split .feature-image,.feature.-split.-flip .feature-image{
    grid-row:auto;grid-column:auto;order:0;aspect-ratio:3/2;
  }
  .feature.-side .feature-text,.feature.-side .linkbtn,
  .feature.-split .feature-text,.feature.-split .linkbtn,
  .feature.-split.-flip .feature-text,.feature.-split.-flip .linkbtn{
    grid-column:auto;grid-row:auto;
  }
  .feature .feature-image.-bleed-right,.feature .feature-image.-bleed-left{margin-left:0;margin-right:0}
  .feature-images{grid-template-columns:1fr 1fr;gap:.7rem}
  .feature-images .feature-image{aspect-ratio:3/4}
  .feature-gallery{grid-template-columns:1fr;min-height:0}
  .feature-gallery > .feature-image:first-child{aspect-ratio:3/2}
  .feature-gallery > .feature-image:not(:first-child){aspect-ratio:3/2}
}

/* ====================================================
   SPLIT GRID — 参考サイト準拠の非対称2カラム
   見出し（hgroup）が左カラム、画像+本文+ボタンが右カラム
   ==================================================== */
.split-grid{
  display:grid;
  grid-template-columns:1fr 1.7fr;
  gap:clamp(2.5rem,6vw,6rem);
  align-items:start;
}
.split-grid > .hgroup{
  grid-column:1;
  margin-bottom:0;
  position:sticky;top:calc(80px + 2rem);
  align-self:start;
}
/* 左カラム=hgroup の英字大見出しを少し小さめに調整（参考サイト準拠） */
.split-grid > .hgroup .subtitle{font-size:clamp(2.2rem,4.5vw,3.8rem)}

/* hgroup 以外の直下子は強制的に右カラムへ（複数兄弟がある場合の auto-flow 問題を防止） */
.split-grid > :not(.hgroup){grid-column:2}

/* split-grid内の .feature は内部gapを引き締める */
.split-grid > .feature{gap:clamp(1.5rem,3vw,2.5rem)}
.split-grid > .feature .feature-text{max-width:none}

/* ニュース行・募集職種カードも右カラム側で完結する */
.split-grid > .news-list,
.split-grid > .positions,
.split-grid > .dualcards{margin:0}

@media (max-width:900px){
  .split-grid{grid-template-columns:1fr;gap:clamp(1.5rem,4vw,2.5rem)}
  .split-grid > .hgroup{grid-column:1;position:static;margin-bottom:var(--space-block)}
  .split-grid > :not(.hgroup){grid-column:1}
  .split-grid > .hgroup .subtitle{font-size:clamp(2.4rem,10vw,4rem)}
}

/* split-grid 内グリッドの列数自動調整（右カラム狭め=1.7fr に最適化） */
.split-grid > .member-grid{grid-template-columns:repeat(2,1fr)}
.split-grid > .banks-grid{grid-template-columns:repeat(3,1fr);gap:.6rem}
.split-grid > .ind-grid{grid-template-columns:repeat(3,1fr)}
.split-grid > .voice-grid{grid-template-columns:repeat(2,1fr)}
.split-grid > .iv-grid{grid-template-columns:1fr}
.split-grid > .news-list .news-row{grid-template-columns:100px 80px 1fr auto;gap:.7rem 1rem;font-size:.9rem}
.split-grid > .news-list .news-row .news-title{font-size:.9rem}
/* 銀行カテゴリラベル */
.split-grid > .bank-cat-label{margin-top:1.5rem}

@media (max-width:900px){
  .split-grid > .member-grid{grid-template-columns:1fr 1fr}
  .split-grid > .banks-grid{grid-template-columns:1fr 1fr}
  .split-grid > .ind-grid{grid-template-columns:1fr 1fr}
  .split-grid > .voice-grid{grid-template-columns:1fr}
}
