/* =========================================================
   Apex Alluring — Redesign (editorial / atelier)
   コンテンツは原本維持。画像は image/ を再利用。
   ブランド継承: gold #DFB76D / brown #63492F を現代的トーンへ
   ========================================================= */

:root{
  --ink:        #1a1613;
  --ink-soft:   #4d463e;
  --ink-faint:  #8a8074;
  --paper:      #f5f1e8;
  --paper-2:    #ece5d6;
  --paper-3:    #e3dac8;
  --gold:       #b08a52;
  --gold-deep:  #8a6a3a;
  --gold-light: #d8b878;
  --line:       rgba(26,22,19,.14);
  --line-soft:  rgba(26,22,19,.08);

  --serif-en: "Cormorant Garamond", "Times New Roman", serif;
  --serif-jp: "Shippori Mincho B1", "Shippori Mincho", "游明朝", serif;
  --sans-jp:  "Zen Kaku Gothic New", "Noto Sans JP", "Hiragino Kaku Gothic ProN", sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
  --maxw: 1280px;
  --gut: clamp(20px, 5vw, 90px);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans-jp);
  background:var(--paper);
  color:var(--ink);
  line-height:1.9;
  font-weight:300;
  letter-spacing:.02em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* ---------- selection ---------- */
::selection{ background:var(--gold); color:var(--paper); }

/* ---------- helpers ---------- */
.shell{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.en{ font-family:var(--serif-en); }
.eyebrow{
  font-family:var(--serif-en);
  font-size:.72rem; letter-spacing:.42em; text-transform:uppercase;
  color:var(--gold-deep); font-weight:500;
  display:inline-flex; align-items:center; gap:.9em;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold); display:inline-block; }

/* reveal-on-scroll */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1.1s var(--ease), transform 1.1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.12s; }
.reveal.d2{ transition-delay:.24s; }
.reveal.d3{ transition-delay:.36s; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1 !important; transform:none !important; }
  html{ scroll-behavior:auto; }
}

/* =========================================================
   Header
   ========================================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:clamp(16px,2.4vw,30px) var(--gut);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease);
  mix-blend-mode:normal;
}
.site-header.scrolled{
  background:rgba(245,241,232,.86);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  padding-block:14px;
  box-shadow:0 1px 0 var(--line-soft);
}
.wordmark{
  font-family:var(--serif-en);
  font-size:clamp(1.15rem,1.7vw,1.5rem);
  letter-spacing:.34em; text-transform:uppercase; font-weight:500;
  color:var(--paper); transition:color .5s var(--ease); padding-left:.34em;
}
.scrolled .wordmark{ color:var(--ink); }
.nav{ display:flex; align-items:center; gap:clamp(22px,2.6vw,46px); }
.nav a{
  font-family:var(--serif-en); font-size:1rem; letter-spacing:.16em;
  color:var(--paper); position:relative; padding-block:4px; transition:color .5s var(--ease);
}
.scrolled .nav a{ color:var(--ink); }
.nav a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--gold);
  transition:width .4s var(--ease);
}
.nav a:hover::after{ width:100%; }
.nav a.is-cta{
  border:1px solid currentColor; border-radius:999px; padding:.5em 1.3em;
  color:var(--paper); opacity:.92;
}
.scrolled .nav a.is-cta{ color:var(--ink); border-color:var(--gold); }
.nav a.is-cta::after{ display:none; }
.nav a.is-cta:hover{ background:var(--gold); color:var(--paper); border-color:var(--gold); }

/* burger */
.burger{ display:none; flex-direction:column; gap:6px; width:34px; height:24px; justify-content:center; background:none; border:0; z-index:80; }
.burger span{ height:1.5px; width:100%; background:var(--paper); transition:.4s var(--ease); }
.scrolled .burger span, .menu-open .burger span{ background:var(--ink); }
.menu-open .burger span:nth-child(1){ transform:translateY(7.5px) rotate(45deg); }
.menu-open .burger span:nth-child(2){ opacity:0; }
.menu-open .burger span:nth-child(3){ transform:translateY(-7.5px) rotate(-45deg); }

/* mobile overlay */
.mobile-nav{
  position:fixed; inset:0; z-index:70; background:var(--paper);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:2.2rem;
  opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s var(--ease);
}
.menu-open .mobile-nav{ opacity:1; visibility:visible; }
.mobile-nav a{ font-family:var(--serif-en); font-size:2rem; letter-spacing:.18em; color:var(--ink); }
.mobile-nav a span{ font-family:var(--sans-jp); font-size:.7rem; letter-spacing:.3em; color:var(--gold-deep); display:block; text-align:center; margin-top:.3em; }

/* =========================================================
   Hero
   ========================================================= */
.hero{ position:relative; height:100svh; min-height:620px; overflow:hidden; display:flex; align-items:flex-end; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:50% 28%;
  animation:kenburns 18s var(--ease) infinite alternate; }
@keyframes kenburns{ from{ transform:scale(1.02); } to{ transform:scale(1.12); } }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,16,13,.42) 0%, rgba(20,16,13,.18) 38%, rgba(20,16,13,.62) 100%);
}
.hero__inner{ position:relative; z-index:2; width:100%; padding:0 var(--gut) clamp(54px,7vw,110px); color:var(--paper); }
.hero__eyebrow{ color:var(--gold-light); }
.hero__eyebrow::before{ background:var(--gold-light); }
.hero h1{
  font-family:var(--serif-jp); font-weight:600;
  font-size:clamp(2.3rem,6.4vw,5.2rem); line-height:1.28; letter-spacing:.04em;
  margin:.5em 0 .2em; text-shadow:0 2px 40px rgba(0,0,0,.3);
}
.hero h1 .sm{ display:block; font-size:.46em; font-weight:400; letter-spacing:.08em; opacity:.92; margin-top:.5em; line-height:1.7; }
.hero__lead{
  font-family:var(--serif-jp); font-size:clamp(1rem,1.5vw,1.35rem); font-weight:400;
  letter-spacing:.1em; max-width:30ch; opacity:.95; margin-bottom:2.2em;
}
.hero__cta{
  display:inline-flex; align-items:center; gap:.9em;
  font-family:var(--serif-en); letter-spacing:.22em; text-transform:uppercase; font-size:.92rem;
  color:var(--paper); border:1px solid rgba(245,241,232,.5); border-radius:999px;
  padding:1em 2.2em; transition:.45s var(--ease); backdrop-filter:blur(2px);
}
.hero__cta:hover{ background:var(--paper); color:var(--ink); border-color:var(--paper); gap:1.4em; }
.hero__cta .arr{ transition:transform .45s var(--ease); }
.hero__cta:hover .arr{ transform:translateX(4px); }

.hero__scroll{
  position:absolute; right:var(--gut); bottom:clamp(54px,7vw,110px); z-index:2;
  writing-mode:vertical-rl; font-family:var(--serif-en); letter-spacing:.3em; text-transform:uppercase;
  font-size:.72rem; color:var(--paper); opacity:.8; display:flex; align-items:center; gap:1em;
}
.hero__scroll::after{ content:""; width:1px; height:60px; background:linear-gradient(var(--gold-light), transparent); animation:scrolldrop 2.2s var(--ease) infinite; }
@keyframes scrolldrop{ 0%{ transform:scaleY(0); transform-origin:top; } 50%{ transform:scaleY(1); transform-origin:top; } 50.1%{ transform-origin:bottom; } 100%{ transform:scaleY(0); transform-origin:bottom; } }

/* =========================================================
   Statement line
   ========================================================= */
.statement{ padding:clamp(80px,12vw,170px) 0; text-align:center; }
.statement p{
  font-family:var(--serif-jp); font-weight:400;
  font-size:clamp(1.4rem,3.6vw,2.9rem); line-height:1.7; letter-spacing:.08em; color:var(--ink);
}
.statement .mark{ color:var(--gold-deep); font-style:italic; font-family:var(--serif-en); }

/* =========================================================
   Concept blocks (個人のブランディング / プロセス…)
   ========================================================= */
.concepts{ padding-bottom:clamp(40px,8vw,120px); }
.concept{
  display:grid; grid-template-columns:1.05fr .95fr; align-items:center; gap:clamp(28px,6vw,90px);
  padding-block:clamp(40px,6vw,80px);
}
.concept:nth-child(even){ direction:rtl; }
.concept:nth-child(even) > *{ direction:ltr; }
.concept__media{ position:relative; overflow:hidden; }
.concept__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; transition:transform 1.4s var(--ease); }
.concept:nth-child(even) .concept__media img{ aspect-ratio:5/4; }
.concept__media:hover img{ transform:scale(1.05); }
.concept__media .idx{
  position:absolute; top:-.3em; left:-.1em; font-family:var(--serif-en); font-size:clamp(4rem,9vw,8rem);
  color:var(--paper); mix-blend-mode:soft-light; opacity:.9; line-height:1; pointer-events:none;
}
.concept__body .num{ font-family:var(--serif-en); color:var(--gold-deep); letter-spacing:.2em; font-size:1rem; }
.concept__body h3{
  font-family:var(--serif-jp); font-weight:600; font-size:clamp(1.6rem,3.2vw,2.5rem);
  line-height:1.5; letter-spacing:.05em; margin:.5em 0 .7em;
}
.concept__body p{ color:var(--ink-soft); font-size:1.02rem; line-height:2.1; letter-spacing:.06em; }
.concept__rule{ width:54px; height:1px; background:var(--gold); margin-top:1.6em; }

/* =========================================================
   Section header (index style)
   ========================================================= */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; padding-block:clamp(34px,5vw,64px); border-top:1px solid var(--line); }
.sec-head .lead{ display:flex; align-items:baseline; gap:clamp(16px,2vw,30px); }
.sec-head .no{ font-family:var(--serif-en); font-size:1rem; letter-spacing:.2em; color:var(--gold-deep); }
.sec-head h2{
  font-family:var(--serif-en); font-weight:500; font-size:clamp(2.4rem,6vw,4.6rem);
  letter-spacing:.04em; line-height:1; text-transform:uppercase;
}
.sec-head .jp{ font-family:var(--serif-jp); color:var(--ink-faint); font-size:.95rem; letter-spacing:.2em; padding-bottom:.6em; }

/* =========================================================
   Sample gallery (masonry + lightbox)
   ========================================================= */
.gallery{ columns:3; column-gap:clamp(10px,1.4vw,20px); padding-bottom:clamp(20px,3vw,40px); }
.gallery figure{ break-inside:avoid; margin:0 0 clamp(10px,1.4vw,20px); position:relative; overflow:hidden; cursor:pointer; background:var(--paper-2); }
.gallery img{ width:100%; transition:transform 1.2s var(--ease), filter .6s var(--ease); filter:saturate(.96); }
.gallery figure::after{
  content:"VIEW"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--serif-en); letter-spacing:.34em; font-size:.78rem; color:var(--paper);
  background:rgba(26,22,19,.28); opacity:0; transition:opacity .5s var(--ease);
}
.gallery figure:hover img{ transform:scale(1.06); filter:saturate(1.05); }
.gallery figure:hover::after{ opacity:1; }
.gallery__more{ text-align:center; padding:clamp(20px,4vw,56px) 0 0; }
.gallery__more a{
  font-family:var(--serif-en); letter-spacing:.24em; text-transform:uppercase; font-size:.9rem; color:var(--ink);
  display:inline-flex; align-items:center; gap:.8em; padding-bottom:.4em; border-bottom:1px solid var(--gold);
  transition:gap .4s var(--ease), color .4s var(--ease);
}
.gallery__more a:hover{ gap:1.3em; color:var(--gold-deep); }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:120; background:rgba(16,13,10,.94); display:flex; align-items:center; justify-content:center; padding:5vmin;
  opacity:0; visibility:hidden; transition:opacity .45s var(--ease), visibility .45s var(--ease); }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox img{ max-width:100%; max-height:90vh; object-fit:contain; box-shadow:0 30px 90px rgba(0,0,0,.5); transform:scale(.97); transition:transform .45s var(--ease); }
.lightbox.open img{ transform:none; }
.lightbox__close{ position:absolute; top:clamp(18px,3vw,40px); right:clamp(18px,3vw,40px); width:54px; height:54px; border:1px solid rgba(245,241,232,.4); border-radius:50%; background:none; color:var(--paper); font-size:1.2rem; display:flex; align-items:center; justify-content:center; transition:.4s var(--ease); }
.lightbox__close:hover{ background:var(--paper); color:var(--ink); transform:rotate(90deg); }
.lightbox__nav{ position:absolute; top:50%; transform:translateY(-50%); width:56px; height:56px; border:1px solid rgba(245,241,232,.35); border-radius:50%; background:none; color:var(--paper); font-family:var(--serif-en); font-size:1.4rem; display:flex; align-items:center; justify-content:center; transition:.4s var(--ease); }
.lightbox__nav:hover{ background:var(--gold); border-color:var(--gold); }
.lightbox__nav.prev{ left:clamp(12px,3vw,40px); }
.lightbox__nav.next{ right:clamp(12px,3vw,40px); }

/* =========================================================
   Member Profile
   ========================================================= */
.members{ padding-bottom:clamp(40px,7vw,110px); }
.member{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(28px,5vw,80px); padding-block:clamp(40px,6vw,80px); align-items:start; }
.member:nth-child(even){ direction:rtl; }
.member:nth-child(even) > *{ direction:ltr; }
.member__photo{ position:relative; }
.member__photo img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.member__photo figcaption{
  position:absolute; left:-1px; bottom:18px; background:var(--ink); color:var(--paper);
  padding:.7em 1.2em; font-family:var(--serif-en); letter-spacing:.18em; font-size:.78rem; text-transform:uppercase;
}
.member__role{ font-family:var(--serif-en); color:var(--gold-deep); letter-spacing:.24em; text-transform:uppercase; font-size:.85rem; }
.member__name{ font-family:var(--serif-jp); font-weight:600; font-size:clamp(1.8rem,3.6vw,2.8rem); letter-spacing:.06em; margin:.25em 0 1.1em; }
.credit{ display:grid; grid-template-columns:max-content 1fr; gap:.2em 1.4em; padding:1.1em 0; border-top:1px solid var(--line-soft); }
.credit dt{ font-family:var(--serif-en); letter-spacing:.2em; font-size:.74rem; color:var(--gold-deep); text-transform:uppercase; padding-top:.45em; }
.credit dd{ font-size:.86rem; line-height:1.95; color:var(--ink-soft); letter-spacing:.03em; }
.credit dd a{ color:var(--gold-deep); border-bottom:1px solid var(--line); }
.credit dd a:hover{ color:var(--ink); }

/* =========================================================
   Price
   ========================================================= */
.price-wrap{ padding-bottom:clamp(40px,7vw,110px); }
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.8vw,24px); }
.plan{ border:1px solid var(--line); padding:clamp(28px,3vw,44px) clamp(22px,2.4vw,34px); background:var(--paper); transition:.5s var(--ease); position:relative; }
.plan:hover{ background:#fff; transform:translateY(-6px); box-shadow:0 26px 50px -28px rgba(26,22,19,.4); }
.plan.feat{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.plan.feat .plan__name, .plan.feat .plan__cuts{ color:var(--paper); }
.plan.feat .plan__price{ color:var(--gold-light); }
.plan__tag{ font-family:var(--serif-en); letter-spacing:.2em; font-size:.7rem; text-transform:uppercase; color:var(--gold-deep); }
.plan.feat .plan__tag{ color:var(--gold-light); }
.plan__name{ font-family:var(--serif-jp); font-weight:600; font-size:1.25rem; letter-spacing:.06em; margin:.5em 0 .8em; }
.plan__price{ font-family:var(--serif-en); font-size:clamp(2rem,3.4vw,2.8rem); font-weight:500; color:var(--ink); letter-spacing:.02em; line-height:1; }
.plan__price .yen{ font-size:.42em; letter-spacing:.1em; margin-left:.3em; color:var(--ink-faint); }
.plan.feat .plan__price .yen{ color:var(--paper); opacity:.7; }
.plan__cuts{ margin-top:1.2em; padding-top:1.2em; border-top:1px solid var(--line-soft); font-size:.9rem; color:var(--ink-soft); letter-spacing:.05em; }

.plans-sub{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,1.8vw,24px); margin-top:clamp(14px,1.8vw,24px); }
.plan-row{ display:flex; align-items:baseline; justify-content:space-between; gap:1em; border:1px solid var(--line); padding:1.5em clamp(20px,2.4vw,32px); }
.plan-row .nm{ font-family:var(--serif-jp); font-weight:500; letter-spacing:.05em; }
.plan-row .va{ font-family:var(--serif-en); letter-spacing:.18em; color:var(--gold-deep); font-size:.95rem; white-space:nowrap; }
.price-note{ margin-top:2.4em; text-align:center; color:var(--ink-faint); font-size:.86rem; line-height:2; letter-spacing:.05em; }

/* =========================================================
   Contact (closing)
   ========================================================= */
.contact{ position:relative; margin-top:clamp(60px,9vw,140px); overflow:hidden; color:var(--paper); }
.contact__bg{ position:absolute; inset:0; z-index:0; }
.contact__bg img{ width:100%; height:100%; object-fit:cover; object-position:50% 30%; }
.contact__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,16,13,.7), rgba(20,16,13,.82)); }
.contact__inner{ position:relative; z-index:2; text-align:center; padding:clamp(90px,15vw,200px) var(--gut); }
.contact h2{ font-family:var(--serif-en); font-weight:500; font-size:clamp(3rem,9vw,6.5rem); letter-spacing:.04em; text-transform:uppercase; line-height:1; }
.contact .sub{ font-family:var(--serif-jp); font-size:clamp(1rem,1.6vw,1.3rem); letter-spacing:.1em; margin:1.4em 0 2.4em; opacity:.92; }
.contact__cta{ display:inline-flex; align-items:center; gap:1em; font-family:var(--serif-en); letter-spacing:.22em; text-transform:uppercase; font-size:.95rem;
  border:1px solid rgba(245,241,232,.55); border-radius:999px; padding:1.1em 2.6em; transition:.45s var(--ease); }
.contact__cta:hover{ background:var(--gold); border-color:var(--gold); gap:1.5em; }
.contact__mail{ display:block; margin-top:2em; font-family:var(--serif-en); letter-spacing:.14em; font-size:1rem; opacity:.85; }
.contact__mail a{ border-bottom:1px solid rgba(245,241,232,.4); padding-bottom:2px; }
.contact__mail a:hover{ border-color:var(--gold-light); }

/* ---------- contact form ---------- */
.cform{ max-width:640px; margin:2.6em auto 0; text-align:left; }
.cform__row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(14px,2vw,22px); }
.cform__field{ display:block; margin-bottom:clamp(14px,2vw,20px); }
.cform__label{ display:block; font-family:var(--serif-jp); font-size:.82rem; letter-spacing:.12em; color:rgba(245,241,232,.82); margin-bottom:.7em; }
.cform__label em{ color:var(--gold-light); font-style:normal; }
.cform input, .cform textarea{
  width:100%; font-family:var(--sans-jp); font-size:1rem; font-weight:300; color:var(--paper);
  background:rgba(245,241,232,.06); border:1px solid rgba(245,241,232,.22); border-radius:2px;
  padding:.9em 1.05em; letter-spacing:.03em; transition:border-color .35s var(--ease), background .35s var(--ease);
}
.cform input:focus, .cform textarea:focus{ outline:none; border-color:var(--gold-light); background:rgba(245,241,232,.1); }
.cform textarea{ resize:vertical; min-height:130px; line-height:1.8; }
.cform__hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.cform__submit{ margin-top:1.4em; cursor:pointer; background:none; }
.cform__submit:disabled{ opacity:.5; cursor:default; }
.cform__status{ min-height:1.4em; margin-top:1.2em; font-family:var(--serif-jp); font-size:.9rem; letter-spacing:.06em; }
.cform__status.is-ok{ color:var(--gold-light); }
.cform__status.is-error{ color:#e6a48c; }
@media (max-width:560px){ .cform__row{ grid-template-columns:1fr; gap:0; } }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:var(--ink); color:var(--paper); padding:clamp(40px,6vw,72px) var(--gut); display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; }
.site-footer .wm{ font-family:var(--serif-en); letter-spacing:.34em; text-transform:uppercase; font-size:1.2rem; }
.site-footer small{ color:var(--ink-faint); font-family:var(--serif-en); letter-spacing:.2em; font-size:.8rem; }

/* back-to-top */
.totop{ position:fixed; right:clamp(16px,2.4vw,30px); bottom:clamp(16px,2.4vw,30px); z-index:50; width:48px; height:48px; border-radius:50%;
  background:var(--ink); color:var(--paper); border:0; display:flex; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transform:translateY(10px); transition:.45s var(--ease); }
.totop.show{ opacity:1; visibility:visible; transform:none; }
.totop:hover{ background:var(--gold); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width:980px){
  .gallery{ columns:2; }
  .concept, .member{ grid-template-columns:1fr; direction:ltr !important; }
  .concept > *, .member > *{ direction:ltr !important; }
  .concept__media img, .concept:nth-child(even) .concept__media img{ aspect-ratio:4/5; }
  .plans, .plans-sub{ grid-template-columns:1fr; }
}
@media (max-width:720px){
  .nav{ display:none; }
  .burger{ display:flex; }
  .gallery{ columns:2; }
  .hero__scroll{ display:none; }
  .sec-head{ flex-direction:column; align-items:flex-start; gap:10px; }
  .credit{ grid-template-columns:1fr; gap:.2em; }
  .credit dt{ padding-top:1em; }
}
@media (max-width:460px){
  .gallery{ columns:1; }
}

/* =========================================================
   Motion pass — entrance choreography / scroll parallax
   2026-06-24: 既存トーンを踏襲した上品な動きを追加
   ========================================================= */

/* ---- hero: 読み込み時のシネマティックな立ち上がり ---- */
@keyframes rise{ from{ opacity:0; transform:translateY(40px); } to{ opacity:1; transform:none; } }
.hero__inner > *{ opacity:0; animation:rise 1.25s var(--ease) forwards; }
.hero__inner > .hero__eyebrow{ animation-delay:.25s; }
.hero__inner > h1{ animation-delay:.45s; }
.hero__inner > .hero__lead{ animation-delay:.72s; }
.hero__inner > .hero__cta{ animation-delay:.95s; }
.hero__scroll{ opacity:0; animation:rise 1.2s var(--ease) 1.25s forwards; }
.hero__inner{ will-change:transform, opacity; }   /* JS パララックス用 */
.hero__media{ will-change:transform; }

/* ---- concept / member 画像: リビール時に de-zoom ---- */
.member__photo{ overflow:hidden; }
.concept.reveal .concept__media img,
.member.reveal .member__photo img{ transform:scale(1.14); transition:transform 1.5s var(--ease); }
.concept.reveal.in .concept__media img,
.member.reveal.in .member__photo img{ transform:scale(1); }

/* ---- sample gallery: タイルを順番にカスケード ---- */
.gallery.reveal figure{ opacity:0; transform:translateY(28px) scale(.985);
  transition:opacity .95s var(--ease), transform .95s var(--ease); }
.gallery.reveal.in figure{ opacity:1; transform:none; }
.gallery.reveal.in figure:nth-child(1){ transition-delay:.04s; }
.gallery.reveal.in figure:nth-child(2){ transition-delay:.10s; }
.gallery.reveal.in figure:nth-child(3){ transition-delay:.16s; }
.gallery.reveal.in figure:nth-child(4){ transition-delay:.22s; }
.gallery.reveal.in figure:nth-child(5){ transition-delay:.28s; }
.gallery.reveal.in figure:nth-child(6){ transition-delay:.34s; }
.gallery.reveal.in figure:nth-child(7){ transition-delay:.40s; }
.gallery.reveal.in figure:nth-child(8){ transition-delay:.46s; }
.gallery.reveal.in figure:nth-child(9){ transition-delay:.52s; }
.gallery.reveal.in figure:nth-child(10){ transition-delay:.58s; }
.gallery.reveal.in figure:nth-child(n+11){ transition-delay:.64s; }

/* ---- price: プランを順番に ---- */
.plans.reveal .plan{ opacity:0; transform:translateY(28px);
  transition:opacity .85s var(--ease), transform .85s var(--ease), background .5s var(--ease), box-shadow .5s var(--ease); }
.plans.reveal.in .plan{ opacity:1; transform:none; }
.plans.reveal.in .plan:nth-child(2){ transition-delay:.12s; }
.plans.reveal.in .plan:nth-child(3){ transition-delay:.24s; }

/* ---- section heading: gold ラインを引く ---- */
.sec-head.reveal{ position:relative; }
.sec-head.reveal::after{ content:""; position:absolute; top:-1px; left:0; height:1px; width:0;
  background:var(--gold); transition:width 1.4s var(--ease) .15s; }
.sec-head.reveal.in::after{ width:100%; }

/* ---- statement: 強調語をゆっくり光らせる ---- */
@keyframes markglow{ 0%,100%{ color:var(--gold-deep); } 50%{ color:var(--gold-light); } }
.statement.reveal.in .mark{ animation:markglow 4.5s var(--ease) 1.2s infinite; }

@media (prefers-reduced-motion:reduce){
  .hero__inner > *, .hero__scroll{ opacity:1 !important; animation:none !important; }
  .hero__inner, .hero__media{ transform:none !important; }
  .concept.reveal .concept__media img, .member.reveal .member__photo img{ transform:none !important; }
  .gallery.reveal figure, .plans.reveal .plan{ opacity:1 !important; transform:none !important; }
  .sec-head.reveal::after{ width:100% !important; transition:none !important; }
  .statement.reveal.in .mark{ animation:none !important; }
}
