/* =====================================================================
   RINA MIYAKE — Official Site
   Design system : pastel / blush · Mincho · airy whitespace
   ===================================================================== */

:root{
  /* palette — blush pastel base */
  --bg:        #fdf6f4;
  --bg-tint:   #fbeef0;
  --bg-deep:   #f7e6e8;
  --ink:       #4b4247;
  --ink-soft:  #978b8f;
  --ink-faint: #b9aeb1;
  --line:      rgba(75,66,71,.13);
  --line-soft: rgba(75,66,71,.07);

  /* accent — switchable via Tweaks */
  --accent:      #e6a6b3;   /* blush pink */
  --accent-deep: #d98b9c;
  --accent-soft: #f7dde2;
  --accent-wash: #fceef1;

  /* secondary pastels (section accents) */
  --sage:   #bcd6c6;
  --sky:    #aecbe8;
  --butter: #f1dca6;

  /* type */
  --font-jp: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", "Noto Sans JP", sans-serif;
  --font-en: "MS 明朝", "MS Mincho", "Yu Mincho", "YuMincho", "Hiragino Mincho ProN", serif;
  --weight-base: 700;

  --maxw: 1620px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html{ background:var(--bg); }
body{
  margin:0;
  background:transparent;
  color:var(--ink);
  font-family:var(--font-jp);
  font-weight:700;
  line-height:1.95;
  letter-spacing:.04em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* selection */
::selection{ background:var(--accent-soft); color:var(--ink); }

/* ---- shared type helpers ------------------------------------------- */
.label-en{
  font-family:var(--font-en);
  font-weight:500;
  letter-spacing:.42em;
  text-transform:uppercase;
  font-size:13px;
  color:var(--accent-deep);
}
.eyebrow{
  display:flex; align-items:center; gap:18px;
  margin-bottom:34px;
}
.eyebrow .num{
  font-family:var(--font-en);
  font-style:italic;
  font-size:15px;
  color:var(--ink-faint);
  letter-spacing:.04em;
}
.eyebrow .bar{ flex:0 0 46px; height:1px; background:var(--accent); opacity:.6; }

.sec-title{
  font-family:var(--font-en);
  font-weight:500;
  font-size:clamp(40px,6vw,74px);
  line-height:1.02;
  letter-spacing:.02em;
  margin:0 0 10px;
}
.sec-title .jp{
  display:block;
  font-family:var(--font-jp);
  font-size:clamp(14px,1.5vw,17px);
  letter-spacing:.34em;
  color:var(--ink-soft);
  margin-top:18px;
  font-weight:500;
}

/* ---- layout shell -------------------------------------------------- */
.section{
  position:relative;
  padding:clamp(96px,13vw,190px) clamp(24px,7vw,120px);
  max-width:var(--maxw);
  margin:0 auto;
}
.section--wide{ max-width:1840px; }
.section--tint{ background:transparent; }
.divider{ height:1px; background:var(--line); max-width:var(--maxw); margin:0 auto; }

/* =====================================================================
   FIXED PHOTO BACKGROUND  — crossfades per section, pastel veil over it
   ===================================================================== */
#bgstage{ position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none; }
.bgphoto{
  position:absolute; inset:-4% ; background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.6s var(--ease), transform 8s linear;
  transform:scale(1.04);
}
.bgphoto.active{ opacity:1; transform:scale(1.12); }
#bgveil{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    linear-gradient(180deg, var(--bg) 0%, color-mix(in srgb, var(--bg) 84%, transparent) 16%, color-mix(in srgb, var(--bg) 80%, transparent) 84%, var(--bg) 100%),
    radial-gradient(120% 80% at 50% 30%, color-mix(in srgb, var(--accent-wash) 60%, transparent), transparent 70%);
}
@supports not (background: color-mix(in srgb, red, blue)){
  #bgveil{ background:linear-gradient(180deg, var(--bg), rgba(253,246,244,.86) 16%, rgba(253,246,244,.82) 84%, var(--bg)); }
}

/* =====================================================================
   FULLPAGE MODE  — whole-screen panels, snap one page at a time
   ===================================================================== */
body.fp{ height:100vh; overflow:hidden; }
.fp-viewport{ position:fixed; inset:0; z-index:1; }
.fp-panel{
  position:absolute; inset:0;
  opacity:0; visibility:hidden; pointer-events:none;
}
.fp-panel.active{ opacity:1; visibility:visible; pointer-events:auto; }
/* scrollable inner wrapper — centers short content, fully scrolls tall content (no top clipping) */
.fp-scroll{ height:100vh; overflow-y:auto; overflow-x:hidden; -webkit-overflow-scrolling:touch; scrollbar-width:none; display:flex; flex-direction:column; }
.fp-scroll::-webkit-scrollbar{ display:none; }
.fp-center{ margin:auto 0; width:100%; }
/* tighten section padding so each fits one screen where possible */
body.fp .fp-scroll .section{ padding-top:clamp(96px,12vh,150px); padding-bottom:clamp(96px,12vh,150px); }
body.fp .fp-scroll .contact{ padding:0; }

/* curtain — cinematic photo wipe between pages */
.fp-curtain{ position:fixed; inset:0; z-index:75; pointer-events:none; will-change:transform; }
.fp-curtain .cphoto{ position:absolute; inset:0; background-size:cover; background-position:center; }
.fp-curtain .cveil{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(46,32,36,.5), rgba(46,32,36,.34) 50%, rgba(46,32,36,.6)); }
.fp-curtain .cveil::after{ content:""; position:absolute; inset:0; background:radial-gradient(80% 70% at 50% 50%, transparent 45%, rgba(30,18,22,.45)); }
.fp-curtain .clabel{
  position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; align-items:center; justify-content:center;
  color:#fff; text-align:center; opacity:0; transform:scale(1.08); transition:opacity .5s var(--ease), transform .9s var(--ease);
}
.fp-curtain.show .clabel{ opacity:1; transform:none; }
.fp-curtain .clabel .en{ font-family:var(--font-en); font-weight:500; text-transform:uppercase; font-size:clamp(48px,9vw,132px); line-height:1; letter-spacing:.05em; text-shadow:0 6px 60px rgba(15,8,12,.5); }
.fp-curtain .clabel .ln{ width:62px; height:1px; background:var(--accent); margin:22px 0; opacity:.92; }
.fp-curtain .clabel .jp{ font-family:var(--font-jp); font-weight:500; letter-spacing:.5em; font-size:clamp(12px,1.5vw,16px); color:rgba(255,255,255,.92); }

/* page dots */
.fp-dots{ position:fixed; right:clamp(16px,2.4vw,34px); top:50%; transform:translateY(-50%); z-index:55; display:flex; flex-direction:column; gap:18px; }
.fp-dots button{ position:relative; width:9px; height:9px; padding:0; border:0; border-radius:50%; background:transparent; box-shadow:inset 0 0 0 1.4px var(--ink-faint); transition:.4s var(--ease); cursor:pointer; }
.fp-dots button:hover{ box-shadow:inset 0 0 0 1.4px var(--accent-deep); transform:scale(1.25); }
.fp-dots button.on{ background:var(--accent-deep); box-shadow:inset 0 0 0 1.4px var(--accent-deep); transform:scale(1.15); animation:dot-pop .55s cubic-bezier(.34,1.56,.64,1); }
.fp-dots button.on::before{
  content:""; position:absolute; left:50%; top:50%; width:9px; height:9px; border-radius:50%;
  transform:translate(-50%,-50%); border:1.5px solid var(--accent-deep); pointer-events:none;
  animation:dot-wave 1.9s ease-out infinite;
}
.fp-dots button.on::after{
  content:""; position:absolute; left:50%; top:50%; width:9px; height:9px; border-radius:50%;
  transform:translate(-50%,-50%); border:1.5px solid var(--accent-deep); pointer-events:none;
  animation:dot-wave 1.9s ease-out .95s infinite;
}
@keyframes dot-pop{ 0%{ transform:scale(.6); } 55%{ transform:scale(1.45); } 100%{ transform:scale(1.15); } }
@keyframes dot-wave{ 0%{ width:9px; height:9px; opacity:.75; } 100%{ width:30px; height:30px; opacity:0; } }
.fp-dots button .tip{
  position:absolute; right:22px; top:50%; transform:translateY(-50%) translateX(6px); white-space:nowrap;
  font-family:var(--font-en); text-transform:uppercase; letter-spacing:.22em; font-size:10.5px; color:var(--ink-soft);
  opacity:0; pointer-events:none; transition:.4s var(--ease);
}
.fp-dots button:hover .tip{ opacity:1; transform:translateY(-50%); }
.fp-dots.dark button{ box-shadow:inset 0 0 0 1.4px rgba(255,255,255,.6); }
.fp-dots.dark button.on{ background:#fff; box-shadow:inset 0 0 0 1.4px #fff; }
.fp-dots.dark button.on::before, .fp-dots.dark button.on::after{ border-color:rgba(255,255,255,.85); }
.fp-dots.dark button .tip{ color:rgba(255,255,255,.85); }

/* page indicator (current / total) bottom-left */
.fp-index{ position:fixed; left:clamp(18px,4vw,46px); bottom:clamp(20px,4vh,40px); z-index:55; font-family:var(--font-en); letter-spacing:.18em; font-size:13px; color:var(--ink-soft); display:flex; align-items:center; gap:10px; }
.fp-index.dark{ color:rgba(255,255,255,.85); }
.fp-index .cur{ font-style:italic; font-size:20px; color:var(--accent-deep); }
.fp-index.dark .cur{ color:#fff; }

@media (max-width:680px){ .fp-dots{ display:none; } }
@media (prefers-reduced-motion:reduce){
  .fp-curtain .clabel{ transition:none; }
}

/* =====================================================================
   PARALLAX BAND  — cinematic section-to-section transition
   ===================================================================== */
.band{ position:relative; height:clamp(360px,56vh,620px); overflow:hidden; display:flex; align-items:center; justify-content:center; isolation:isolate; }
.band-photo{
  position:absolute; inset:0; background-size:cover; background-position:center;
  background-attachment:fixed; z-index:-1;
}
.band-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(48,34,38,.42), rgba(48,34,38,.22) 45%, rgba(48,34,38,.5)); }
.band-photo::before{ content:""; position:absolute; inset:0; background:radial-gradient(90% 70% at 50% 50%, transparent 40%, rgba(40,26,30,.4)); z-index:1; }
.band-label{ position:relative; z-index:2; text-align:center; color:#fff; padding:0 24px; }
.band-label .en{
  display:block; font-family:var(--font-en); font-weight:500; text-transform:uppercase;
  font-size:clamp(46px,9vw,128px); line-height:1; letter-spacing:.04em;
  text-shadow:0 4px 50px rgba(20,10,14,.5);
  opacity:0; transform:translateY(40px) scale(.96); filter:blur(8px);
  transition:opacity 1.2s var(--ease), transform 1.4s var(--ease), filter 1.2s var(--ease);
}
.band-label .ln{ display:block; width:0; height:1px; background:var(--accent); margin:24px auto; transition:width 1.1s var(--ease) .2s; opacity:.9; }
.band-label .jp{
  display:block; font-family:var(--font-jp); font-weight:500; letter-spacing:.46em;
  font-size:clamp(12px,1.5vw,16px); color:rgba(255,255,255,.9);
  opacity:0; transform:translateY(18px); transition:opacity 1s var(--ease) .35s, transform 1s var(--ease) .35s;
}
.band.in .en{ opacity:1; transform:none; filter:blur(0); }
.band.in .ln{ width:64px; }
.band.in .jp{ opacity:1; transform:none; }
@media (max-width:820px){ .band-photo{ background-attachment:scroll; } }

/* =====================================================================
   REVEAL ON SCROLL — blur + lift + cascade
   ===================================================================== */
.reveal{ opacity:0; transform:translateY(38px); filter:blur(7px); transition:opacity 1.15s var(--ease), transform 1.25s var(--ease), filter 1.1s var(--ease); }
.reveal.in{ opacity:1; transform:none; filter:blur(0); }
.sec-title.reveal, .reveal--clip{ clip-path:inset(0 0 100% 0); transition:opacity 1.2s var(--ease), transform 1.3s var(--ease), filter 1.1s var(--ease), clip-path 1.4s var(--ease); }
.sec-title.reveal.in, .reveal--clip.in{ clip-path:inset(0 0 0 0); }
@media (prefers-reduced-motion:reduce){
  .reveal,.sec-title.reveal,.reveal--clip{ opacity:1; transform:none; filter:none; clip-path:none; transition:none; }
  .band-label .en,.band-label .jp{ opacity:1; transform:none; filter:none; } .band-label .ln{ width:64px; }
}

/* =====================================================================
   HEADER  (appears on scroll)
   ===================================================================== */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:22px clamp(20px,5vw,56px);
  transition:background .5s var(--ease), transform .5s var(--ease), padding .5s var(--ease);
  transform:translateY(-100%);
  pointer-events:none;
}
.site-header.show{
  transform:none; pointer-events:auto;
  background:rgba(253,246,244,.82);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid var(--line-soft);
}
.brand{
  font-family:var(--font-en); font-size:19px; letter-spacing:.34em;
  text-transform:uppercase; font-weight:500;
}
.brand small{ display:block; font-family:var(--font-jp); font-size:9.5px; letter-spacing:.5em; color:var(--ink-soft); margin-top:3px; }
.head-nav{ display:flex; gap:30px; align-items:center; }
.head-nav a{
  font-family:var(--font-en); font-size:13px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--ink-soft); position:relative; padding:4px 0;
}
.head-nav a::after{ content:""; position:absolute; left:0; right:100%; bottom:0; height:1px; background:var(--accent-deep); transition:right .4s var(--ease); }
.head-nav a:hover{ color:var(--ink); }
.head-nav a:hover::after{ right:0; }

.menu-toggle{ display:none; border:0; background:none; padding:8px; }
.menu-toggle span{ display:block; width:24px; height:1.5px; background:var(--ink); margin:5px 0; transition:.4s var(--ease); }

/* mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:70; background:var(--bg);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:26px;
  opacity:0; pointer-events:none; transition:opacity .5s var(--ease);
}
.drawer.open{ opacity:1; pointer-events:auto; }
.drawer a{ font-family:var(--font-en); font-size:26px; letter-spacing:.2em; text-transform:uppercase; }
.drawer a small{ display:block; font-family:var(--font-jp); font-size:11px; letter-spacing:.4em; color:var(--ink-soft); text-align:center; margin-top:6px; }
.drawer-x{ position:absolute; top:24px; right:24px; border:0; background:none; font-size:30px; color:var(--ink); line-height:1; }

/* =====================================================================
   HERO  — full viewport, 3 layout variants (data-hero a|b|c)
   ===================================================================== */
.hero{ position:relative; height:100svh; min-height:600px; overflow:hidden; color:#fff; }
.hero-media{ position:absolute; inset:0; z-index:0; }
.hero-media .slide{
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 2.4s var(--ease);
  animation:kenburns 20s ease-out infinite alternate;
}
.hero-media .slide.active{ opacity:1; }
.hero-media video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
@keyframes kenburns{ from{ transform:scale(1.06); } to{ transform:scale(1.16); } }
@media (prefers-reduced-motion:reduce){ .hero-media .slide{ animation:none; } }

.hero-veil{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(to bottom, rgba(40,30,34,.30) 0%, rgba(40,30,34,.04) 30%, rgba(40,30,34,.06) 64%, rgba(40,30,34,.52) 100%),
    radial-gradient(120% 90% at 50% 40%, transparent 40%, rgba(60,40,46,.28) 100%);
}
/* soft pink wash so it reads pastel not stark */
.hero-veil::after{ content:""; position:absolute; inset:0; background:radial-gradient(90% 70% at 50% 60%, rgba(230,166,179,.16), transparent 70%); mix-blend-mode:screen; }

.hero-inner{ position:relative; z-index:2; height:100%; }

/* video tag (placeholder indicator) */
.movie-tag{
  position:absolute; z-index:3; bottom:30px; right:clamp(20px,5vw,56px);
  display:flex; align-items:center; gap:9px;
  font-family:var(--font-en); font-size:11px; letter-spacing:.34em; text-transform:uppercase;
  color:rgba(255,255,255,.78);
}
.movie-tag .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 5px rgba(230,166,179,.28); animation:pulse 2.6s ease-in-out infinite; }
@keyframes pulse{ 50%{ box-shadow:0 0 0 9px rgba(230,166,179,0); } }

.hero-name{ font-family:"Cormorant Garamond", serif; font-weight:500; line-height:.94; letter-spacing:.04em; }
.hero-sub{ font-family:var(--font-jp); letter-spacing:.5em; font-weight:500; }
.hero-tag{ font-family:var(--font-en); letter-spacing:.4em; text-transform:uppercase; font-size:12px; opacity:.85; }

/* ---- dramatic divider under the name ---- */
.hero-rule{
  display:flex; align-items:center; justify-content:center;
  width:min(520px,78vw); margin:clamp(20px,3.4vh,40px) auto 0;
}
.hero-rule .ln{
  flex:1; height:2px; transform:scaleX(0); transform-origin:right center;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.55) 30%, var(--accent) 100%);
  box-shadow:0 0 18px color-mix(in srgb, var(--accent) 60%, transparent);
  animation:rule-grow 1.1s cubic-bezier(.7,0,.25,1) .45s both;
}
.hero-rule .ln:last-child{
  transform-origin:left center;
  background:linear-gradient(90deg, var(--accent), rgba(255,255,255,.55) 70%, transparent);
}
.hero-rule .orn{
  position:relative; width:12px; height:12px; margin:0 18px; flex:none;
  background:var(--accent); transform:rotate(45deg) scale(0);
  box-shadow:0 0 0 5px color-mix(in srgb, var(--accent) 22%, transparent), 0 0 26px var(--accent);
  animation:rule-orn .8s cubic-bezier(.34,1.56,.64,1) 1.15s both, orn-glow 3.2s ease-in-out 2s infinite;
}
.hero-rule .orn::after{
  content:""; position:absolute; inset:-11px; border:1px solid color-mix(in srgb, var(--accent) 65%, transparent);
  transform:rotate(0deg); opacity:.6;
}
.hero-rule--left{ margin-left:0; margin-right:auto; justify-content:flex-start; }
@keyframes rule-grow{ from{ transform:scaleX(0); } to{ transform:scaleX(1); } }
@keyframes rule-orn{ from{ transform:rotate(45deg) scale(0); opacity:0; } to{ transform:rotate(45deg) scale(1); opacity:1; } }
@keyframes orn-glow{ 0%,100%{ box-shadow:0 0 0 5px color-mix(in srgb,var(--accent) 22%, transparent), 0 0 22px var(--accent); } 50%{ box-shadow:0 0 0 9px color-mix(in srgb,var(--accent) 6%, transparent), 0 0 34px var(--accent); } }
@media (prefers-reduced-motion:reduce){
  .hero-rule .ln{ transform:scaleX(1); animation:none; }
  .hero-rule .orn{ transform:rotate(45deg) scale(1); animation:none; }
}

/* ---- signature treatment for the name ---- */
.hero-sign{
  font-family:"Mr Dafoe", cursive;
  font-weight:400; line-height:.92; margin:0;
  color:#fff; letter-spacing:.005em;
  filter:drop-shadow(0 6px 26px rgba(20,12,16,.45)) drop-shadow(0 1px 1px rgba(0,0,0,.25));
  position:relative; display:inline-block;
}
/* the writing reveal: a clip wipes left→right like a pen stroke */
.hero-sign .ink{
  display:inline-block;
  background:linear-gradient(90deg,#fff 0 60%, color-mix(in srgb,#fff 70%, var(--accent-soft)) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  -webkit-text-fill-color:transparent;
  clip-path:inset(0 100% -0.25em 0);
  animation:sign-write 2.4s cubic-bezier(.77,.05,.28,1) .55s both;
}
/* nib: a soft glowing dot that travels with the stroke tip */
.hero-sign::after{
  content:""; position:absolute; left:0; top:54%; width:14px; height:14px; border-radius:50%;
  background:radial-gradient(circle, #fff 0 30%, rgba(255,255,255,.5) 45%, transparent 70%);
  opacity:0; transform:translate(-50%,-50%);
  animation:nib-run 2.4s cubic-bezier(.77,.05,.28,1) .55s both;
}
/* flourish underline drawn after the name */
.hero-sign::before{
  content:""; position:absolute; left:4%; right:4%; bottom:-.06em; height:2px;
  background:linear-gradient(90deg, transparent, var(--accent) 12%, var(--accent) 88%, transparent);
  transform:scaleX(0); transform-origin:left center; opacity:.85; border-radius:2px;
  animation:flourish 1s cubic-bezier(.7,0,.3,1) 2.7s both;
}
@keyframes sign-write{ from{ clip-path:inset(0 100% -0.25em 0); } to{ clip-path:inset(0 0 -0.25em 0); } }
@keyframes nib-run{
  0%{ opacity:0; left:1%; } 8%{ opacity:1; } 92%{ opacity:1; left:99%; } 100%{ opacity:0; left:100%; }
}
@keyframes flourish{ from{ transform:scaleX(0); } to{ transform:scaleX(1); } }
@media (prefers-reduced-motion:reduce){
  .hero-sign .ink{ clip-path:none; animation:none; }
  .hero-sign::after{ display:none; }
  .hero-sign::before{ transform:scaleX(1); animation:none; }
}
/* romaji caps beneath the signature */
.hero-romaji-cap{
  font-family:var(--font-en); text-transform:uppercase; letter-spacing:.5em; font-weight:500;
  font-size:clamp(11px,1.3vw,15px); color:rgba(255,255,255,.82);
  opacity:0; animation:fade-up 1s var(--ease) 2.9s both; padding-left:.5em;
}
@keyframes fade-up{ from{ opacity:0; transform:translateY(10px); } to{ opacity:.82; transform:none; } }

/* hero nav (the in-hero menu) */
.hero-nav a{
  font-family:var(--font-en); text-transform:uppercase; letter-spacing:.26em;
  font-size:13.5px; color:rgba(255,255,255,.82); position:relative; transition:color .4s;
}
.hero-nav a .jp{ font-family:var(--font-jp); }
.hero-nav a:hover{ color:#fff; }

.scroll-cue{ position:absolute; z-index:3; left:50%; bottom:26px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:10px; color:rgba(255,255,255,.8); }
.scroll-cue .ln{ width:1px; height:46px; background:linear-gradient(rgba(255,255,255,.7),rgba(255,255,255,0)); animation:cue 2.4s var(--ease) infinite; transform-origin:top; }
.scroll-cue span{ font-family:var(--font-en); font-size:10px; letter-spacing:.34em; text-transform:uppercase; }
@keyframes cue{ 0%{ transform:scaleY(0); opacity:0; } 40%{ opacity:1; } 100%{ transform:scaleY(1); opacity:0; } }

/* ---- Variant A : centered ----------------------------------------- */
[data-hero="a"] .hero-inner{ display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; }
[data-hero="a"] .hero-tag{ margin-bottom:26px; }
[data-hero="a"] .hero-name{ font-size:clamp(40px,10vw,150px); white-space:nowrap; }
[data-hero="a"] .hero-sign{ font-size:clamp(76px,17vw,260px); }
[data-hero="a"] .hero-romaji-cap{ margin-top:22px; }
[data-hero="a"] .hero-sub{ font-size:clamp(13px,1.7vw,18px); margin-top:24px; }
[data-hero="a"] .hero-nav{ display:flex; gap:clamp(20px,3vw,46px); margin-top:clamp(42px,7vh,86px); flex-wrap:wrap; justify-content:center; }
[data-hero="b"] .hero-nav, [data-hero="c"] .hero-nav{ display:flex; }

/* ---- Variant B : vertical / tategaki ------------------------------ */
[data-hero="b"] .hero-inner{ display:block; }
[data-hero="b"] .hero-vert{
  position:absolute; top:0; right:clamp(28px,7vw,96px); height:100%;
  display:flex; align-items:center; gap:clamp(20px,3vw,48px);
}
[data-hero="b"] .hero-name-v{
  writing-mode:vertical-rl; font-family:var(--font-jp); font-weight:500;
  font-size:clamp(40px,8vw,104px); letter-spacing:.16em; line-height:1;
  text-shadow:0 2px 30px rgba(40,25,30,.35);
}
[data-hero="b"] .hero-romaji{
  writing-mode:vertical-rl; font-family:var(--font-en); text-transform:uppercase;
  letter-spacing:.4em; font-size:14px; color:rgba(255,255,255,.8); padding-top:10px;
}
[data-hero="b"] .hero-sign--v{
  font-size:clamp(56px,9vw,130px); align-self:flex-start; padding-top:6px;
  transform:rotate(8deg); transform-origin:top center;
}
[data-hero="b"] .hero-nav{
  position:absolute; left:clamp(28px,6vw,72px); bottom:clamp(40px,9vh,96px);
  flex-direction:column; gap:18px; align-items:flex-start;
}
[data-hero="b"] .hero-tag-b{
  position:absolute; left:clamp(28px,6vw,72px); top:clamp(40px,9vh,96px);
  writing-mode:horizontal-tb;
}

/* ---- Variant C : editorial lower-left + framed --------------------- */
[data-hero="c"]{ background:var(--bg); padding:clamp(14px,2.2vw,30px); }
[data-hero="c"] .hero-media{ inset:clamp(14px,2.2vw,30px); border-radius:3px; overflow:hidden; }
[data-hero="c"] .hero-veil{ inset:clamp(14px,2.2vw,30px); border-radius:3px; }
[data-hero="c"] .movie-tag{ bottom:calc(clamp(14px,2.2vw,30px) + 26px); right:calc(clamp(14px,2.2vw,30px) + 30px); }
[data-hero="c"] .scroll-cue{ display:none; }
[data-hero="c"] .hero-inner{ display:flex; flex-direction:column; justify-content:flex-end; align-items:flex-start; padding:clamp(40px,7vw,96px); }
[data-hero="c"] .hero-tag{ margin-bottom:18px; }
[data-hero="c"] .hero-name{ font-size:clamp(46px,10vw,140px); }
[data-hero="c"] .hero-sign{ font-size:clamp(64px,14vw,210px); }
[data-hero="c"] .hero-romaji-cap{ margin-top:14px; }
[data-hero="c"] .hero-sub{ font-size:clamp(12px,1.5vw,17px); margin-top:18px; }
[data-hero="c"] .hero-nav{ position:absolute; top:clamp(40px,7vw,72px); right:clamp(40px,7vw,72px); flex-direction:column; gap:15px; align-items:flex-end; text-align:right; }

/* =====================================================================
   NEWS
   ===================================================================== */
.news-list{ display:flex; flex-direction:column; }
.news-row{
  display:grid; grid-template-columns:150px 130px 1fr 28px; gap:28px; align-items:baseline;
  padding:28px 6px; border-top:1px solid var(--line);
  transition:background .4s var(--ease), padding-left .4s var(--ease);
}
.news-row:last-child{ border-bottom:1px solid var(--line); }
.news-row:hover{ background:var(--accent-wash); padding-left:18px; }
.news-date{ font-family:var(--font-en); font-style:italic; color:var(--ink-soft); font-size:16px; letter-spacing:.06em; }
.news-cat{ justify-self:start; align-self:center; font-family:var(--font-en); font-size:10.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--accent-deep); border:1px solid var(--accent); border-radius:30px; padding:5px 14px; }
.news-ttl{ font-size:17px; line-height:1.7; color:var(--ink); }
.news-arrow{ justify-self:end; align-self:center; color:var(--ink-faint); transition:transform .4s var(--ease), color .4s; }
.news-row:hover .news-arrow{ transform:translateX(6px); color:var(--accent-deep); }
.news-more{ margin-top:54px; display:flex; justify-content:center; }

/* ---- news detail modal ---- */
.news-modal{
  position:fixed; inset:0; z-index:90; display:flex; align-items:center; justify-content:center;
  padding:24px; background:rgba(46,32,36,.5); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  opacity:0; pointer-events:none; transition:opacity .45s var(--ease);
}
.news-modal.open{ opacity:1; pointer-events:auto; }
.news-dialog{
  position:relative; width:min(620px,100%); max-height:84vh; overflow-y:auto;
  background:var(--bg); border:1px solid var(--line); border-radius:4px;
  padding:clamp(34px,5vw,58px); box-shadow:0 40px 110px rgba(46,28,32,.34);
  transform:translateY(22px) scale(.97); transition:transform .5s var(--ease);
}
.news-modal.open .news-dialog{ transform:none; }
.news-dialog-photo{ margin:-8px 0 26px; border-radius:3px; overflow:hidden; aspect-ratio:16/10; background:var(--accent-wash); }
.news-dialog-photo img{ width:100%; height:100%; object-fit:cover; }
.news-dialog-x{
  position:absolute; top:14px; right:18px; border:0; background:none; font-size:28px; line-height:1; color:var(--ink-soft);
  transition:color .3s, transform .3s var(--ease);
}
.news-dialog-x:hover{ color:var(--accent-deep); transform:rotate(90deg); }
.news-dialog-meta{ display:flex; align-items:center; gap:18px; margin-bottom:20px; }
.news-dialog-date{ font-family:var(--font-en); font-style:italic; font-size:18px; color:var(--ink-soft); letter-spacing:.06em; }
.news-dialog-ttl{ margin:0; font-size:clamp(20px,2.6vw,26px); line-height:1.7; letter-spacing:.04em; }
.news-dialog-rule{ width:48px; height:2px; background:var(--accent); margin:24px 0; border-radius:2px; }
.news-dialog-body{ margin:0; color:var(--ink-soft); font-size:16px; line-height:2.15; }

/* =====================================================================
   SCHEDULE
   ===================================================================== */
.sched-list{ display:flex; flex-direction:column; }
.sched-row{
  display:grid; grid-template-columns:130px 120px 72px 1fr 28px; gap:24px; align-items:center;
  width:100%; text-align:left; border:0; background:none; cursor:pointer;
  padding:24px 6px; border-top:1px solid var(--line); color:inherit; font-family:inherit;
  transition:background .4s var(--ease), padding-left .4s var(--ease);
}
.sched-row:last-child{ border-bottom:1px solid var(--line); }
.sched-row:hover{ background:var(--accent-wash); padding-left:18px; }
.sched-date{ display:flex; flex-direction:column; gap:2px; }
.sd-md{ font-family:var(--font-en); font-size:28px; line-height:1; color:var(--accent-deep); letter-spacing:.02em; }
.sd-md i{ font-style:normal; opacity:.4; margin:0 3px; }
.sd-y{ font-family:var(--font-en); font-style:italic; font-size:13px; color:var(--ink-faint); }
.sched-cat{ justify-self:start; align-self:center; font-family:var(--font-en); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--accent-deep); border:1px solid var(--accent); border-radius:30px; padding:5px 14px; }
.sched-thumb{ width:72px; height:54px; border-radius:4px; overflow:hidden; background:var(--accent-wash); }
.sched-thumb img{ width:100%; height:100%; object-fit:cover; }
.sched-thumb--none{ background:none; }
.sched-main{ display:flex; flex-direction:column; gap:5px; }
.sched-ttl{ font-size:17.5px; line-height:1.6; color:var(--ink); }
.sched-place{ font-size:13.5px; color:var(--ink-soft); }
.sched-row:hover .news-arrow{ transform:translateX(6px); color:var(--accent-deep); }
.sched-empty{ padding:54px 6px; color:var(--ink-faint); font-style:italic; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.sched-d-place{ margin:0 0 10px; font-size:14.5px; color:var(--accent-deep); font-weight:500; letter-spacing:.04em; }

@media (max-width:760px){
  .sched-row{ grid-template-columns:96px 1fr; gap:10px 16px; }
  .sched-cat{ grid-row:1; grid-column:2; justify-self:start; }
  .sched-thumb{ grid-column:1 / -1; width:100%; height:160px; }
  .sched-thumb--none{ display:none; }
  .sched-main{ grid-column:1 / -1; }
  .sched-row .news-arrow{ display:none; }
  .sd-md{ font-size:23px; }
}

.btn-line{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--font-en); text-transform:uppercase; letter-spacing:.28em; font-size:13px;
  color:var(--ink); padding:16px 38px; border:1px solid var(--ink); border-radius:40px;
  transition:.45s var(--ease); background:transparent;
}
.btn-line:hover{ background:var(--ink); color:var(--bg); gap:20px; }
.btn-line.alt{ border-color:var(--accent-deep); color:var(--accent-deep); }
.btn-line.alt:hover{ background:var(--accent-deep); color:#fff; }

/* =====================================================================
   PROFILE
   ===================================================================== */
.profile-grid{ display:grid; grid-template-columns:1fr 1.3fr; gap:clamp(40px,6vw,90px); align-items:center; }
.profile-media{ position:relative; }
.profile-photo{ position:relative; }
.profile-photo .frame{ position:relative; aspect-ratio:3/4; overflow:hidden; border-radius:2px; }
.profile-photo .frame img{ width:100%; height:100%; object-fit:cover; }
.profile-photo .wash{ position:absolute; inset:0; background:linear-gradient(180deg, transparent 60%, rgba(230,166,179,.12)); pointer-events:none; }
.profile-photo .deco{ position:absolute; left:-22px; top:-22px; right:34px; bottom:34px; border:1px solid var(--accent); border-radius:2px; z-index:-1; }
.profile-photo .cap{ position:absolute; bottom:16px; left:16px; font-family:var(--font-en); font-style:italic; font-size:13px; color:#fff; letter-spacing:.06em; text-shadow:0 1px 14px rgba(0,0,0,.4); }

.profile-lead{ font-size:clamp(18px,2vw,23px); line-height:1.85; font-weight:500; margin:0 0 22px; letter-spacing:.05em; }
.profile-lead em{ font-style:normal; color:var(--accent-deep); }
.profile-body p{ color:var(--ink-soft); font-size:14.5px; line-height:1.95; margin:0 0 14px; }

.data-list{ margin-top:28px; border-top:1px solid var(--line); display:grid; grid-template-columns:1fr 1fr; column-gap:clamp(24px,3vw,48px); }
.data-list dl{ display:grid; grid-template-columns:96px 1fr; gap:0; margin:0; padding:12px 4px; border-bottom:1px solid var(--line); }
.data-list dt{ font-family:var(--font-en); text-transform:uppercase; letter-spacing:.18em; font-size:10.5px; color:var(--accent-deep); align-self:center; }
.data-list dd{ margin:0; font-size:14px; color:var(--ink); align-self:center; }
.ph{ color:var(--ink-faint); font-style:italic; }

/* =====================================================================
   BIOGRAPHY
   ===================================================================== */
.bio-wrap{ display:grid; grid-template-columns:1fr; gap:0; }
.bio-intro{ max-width:1100px; margin:0 auto 84px; text-align:center; }
.bio-intro .q{ font-family:var(--font-en); font-style:italic; font-size:clamp(20px,3.4vw,44px); line-height:1.5; color:var(--ink); white-space:nowrap; }
.bio-intro .q .mk{ color:var(--accent); }
.bio-intro p{ margin-top:30px; color:var(--ink-soft); font-size:16px; line-height:2.2; }

.timeline{ max-width:820px; margin:0 auto; position:relative; }
.timeline::before{ content:""; position:absolute; left:118px; top:6px; bottom:6px; width:1px; background:var(--line); }
.tl-row{ display:grid; grid-template-columns:118px 1fr; gap:46px; padding:26px 0; position:relative; }
.tl-year{ font-family:var(--font-en); font-style:italic; font-size:24px; color:var(--accent-deep); text-align:right; padding-top:2px; }
.tl-row::before{ content:""; position:absolute; left:114px; top:34px; width:9px; height:9px; border-radius:50%; background:var(--bg); border:1.5px solid var(--accent); }
.tl-body h4{ margin:0 0 6px; font-size:18px; font-weight:500; letter-spacing:.06em; }
.tl-body p{ margin:0; color:var(--ink-soft); font-size:14.5px; line-height:1.95; }

/* =====================================================================
   WORKS  (tabs : songs / activities)
   ===================================================================== */
.tabs{ display:flex; gap:8px; justify-content:center; margin-bottom:64px; }
.tab{
  font-family:var(--font-en); text-transform:uppercase; letter-spacing:.22em; font-size:13px;
  padding:12px 30px; border:1px solid var(--line); border-radius:40px; color:var(--ink-soft);
  background:transparent; transition:.4s var(--ease); position:relative;
}
.tab .jp{ font-family:var(--font-jp); letter-spacing:.18em; }
.tab[aria-selected="true"]{ background:var(--accent); border-color:var(--accent); color:#fff; }

.tabpanel{ display:none; animation:fade .7s var(--ease); }
.tabpanel.active{ display:block; }
@keyframes fade{ from{ opacity:0; transform:translateY(14px); } }

/* songs */
.disc{ display:grid; grid-template-columns:repeat(auto-fill,minmax(250px,1fr)); gap:clamp(28px,4vw,52px); }
.song{ }
.song .art{ position:relative; aspect-ratio:1; border-radius:3px; overflow:hidden; margin-bottom:20px; }
.song .art .ph-art{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.song .art:hover .play{ opacity:1; transform:scale(1); }
.play{ position:absolute; inset:0; margin:auto; width:62px; height:62px; border-radius:50%; background:rgba(253,246,244,.92); display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.85); transition:.45s var(--ease); }
.play svg{ margin-left:3px; }
.song h4{ margin:0 0 5px; font-size:17px; font-weight:500; letter-spacing:.06em; }
.song .meta{ font-family:var(--font-en); font-style:italic; color:var(--ink-soft); font-size:14px; }
.song .yr{ font-family:var(--font-en); letter-spacing:.16em; color:var(--ink-faint); font-size:12px; }

/* activities */
.acts{ display:flex; flex-direction:column; gap:0; }
.act{ display:grid; grid-template-columns:118px 150px 1fr; gap:30px; align-items:center; padding:26px 6px; border-top:1px solid var(--line); transition:background .4s; }
.act:last-child{ border-bottom:1px solid var(--line); }
.act:hover{ background:var(--accent-wash); }
.act .yr{ font-family:var(--font-en); font-style:italic; font-size:18px; color:var(--accent-deep); }
.act .kind{ font-family:var(--font-en); text-transform:uppercase; letter-spacing:.2em; font-size:10.5px; color:var(--ink-soft); }
.act h4{ margin:0 0 4px; font-size:17px; font-weight:500; }
.act p{ margin:0; color:var(--ink-soft); font-size:14px; line-height:1.8; }
.act-photo{ grid-column:1 / -1; order:-1; margin:0 0 4px; width:100%; max-width:260px; aspect-ratio:16/10; overflow:hidden; border-radius:4px; background:var(--accent-wash); }
.act-photo img{ width:100%; height:100%; object-fit:cover; }

/* =====================================================================
   GALLERY
   ===================================================================== */
.gallery{ columns:3; column-gap:18px; }
.gal-item{ break-inside:avoid; margin-bottom:18px; position:relative; overflow:hidden; border-radius:2px; cursor:pointer; }
.gal-item img{ width:100%; transition:transform 1.1s var(--ease), filter .6s; }
.gal-item::after{ content:""; position:absolute; inset:0; background:rgba(230,166,179,0); transition:background .5s; }
.gal-item:hover img{ transform:scale(1.05); }
.gal-item:hover::after{ background:rgba(75,66,71,.12); }
.gal-item .plus{ position:absolute; top:14px; right:14px; color:#fff; opacity:0; transition:.5s; font-size:20px; }
.gal-item:hover .plus{ opacity:1; }
.gal-ph{ aspect-ratio:3/4; }

/* lightbox */
.lightbox{ position:fixed; inset:0; z-index:90; background:rgba(40,30,34,.94); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity .5s var(--ease); }
.lightbox.open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:88vw; max-height:84vh; object-fit:contain; box-shadow:0 30px 90px rgba(0,0,0,.5); }
.lb-close{ position:absolute; top:24px; right:30px; border:0; background:none; color:#fff; font-size:30px; line-height:1; }
.lb-nav{ position:absolute; top:50%; transform:translateY(-50%); border:0; background:none; color:rgba(255,255,255,.7); font-size:40px; padding:20px; transition:color .3s; }
.lb-nav:hover{ color:#fff; }
.lb-prev{ left:10px; } .lb-next{ right:10px; }
.lb-count{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); font-family:var(--font-en); letter-spacing:.3em; color:rgba(255,255,255,.8); font-size:13px; }

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact{ background:color-mix(in srgb, var(--bg-tint) 70%, transparent); }
.contact-card{ background:#fff; border:1px solid var(--line); border-radius:10px; padding:clamp(28px,4vw,46px); box-shadow:0 24px 70px rgba(75,66,71,.10); }
.contact-card .form-field input, .contact-card .form-field textarea, .contact-card .form-field select{ background:#fdfafa; border:1px solid var(--line); border-radius:8px; padding:12px 13px; }
.contact-card .form-field input:focus, .contact-card .form-field textarea:focus, .contact-card .form-field select:focus{ border-color:var(--accent); background:#fff; }
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(48px,8vw,120px); align-items:start; }
.contact-lead{ font-size:16px; color:var(--ink-soft); line-height:2.2; max-width:420px; margin:0 0 40px; }
.sns{ display:flex; flex-direction:column; gap:0; margin-top:8px; }
.sns a{ display:flex; align-items:center; justify-content:space-between; padding:22px 4px; border-top:1px solid var(--line); transition:padding-left .4s var(--ease), color .4s; }
.sns a:last-child{ border-bottom:1px solid var(--line); }
.sns a:hover{ padding-left:14px; color:var(--accent-deep); }
.sns .nm{ font-family:var(--font-en); text-transform:uppercase; letter-spacing:.22em; font-size:15px; display:flex; align-items:center; gap:16px; }
.sns .handle{ font-family:var(--font-en); font-style:italic; color:var(--ink-soft); font-size:14px; }

.form-field{ margin-bottom:28px; }
.form-field label{ display:block; font-family:var(--font-en); text-transform:uppercase; letter-spacing:.2em; font-size:11px; color:var(--accent-deep); margin-bottom:10px; }
.form-field input, .form-field textarea, .form-field select{
  width:100%; background:transparent; border:0; border-bottom:1px solid var(--line);
  font-family:var(--font-jp); font-size:16px; color:var(--ink); padding:10px 2px; letter-spacing:.04em;
  transition:border-color .4s;
}
.form-field input:focus, .form-field textarea:focus, .form-field select:focus{ outline:none; border-color:var(--accent); }
.form-field textarea{ resize:vertical; min-height:120px; line-height:1.9; }
.form-submit{ margin-top:14px; }
.form-note{ font-size:13px; color:var(--ink-faint); margin-top:18px; line-height:1.8; }
.form-done{ padding:40px 0; font-size:17px; color:var(--accent-deep); }

/* =====================================================================
   FOOTER
   ===================================================================== */
.site-footer{ text-align:center; padding:90px 24px 56px; background:color-mix(in srgb, var(--bg-tint) 78%, transparent); border-top:1px solid var(--line); position:relative; }
.site-footer .fbrand{ font-family:var(--font-en); font-size:30px; letter-spacing:.32em; text-transform:uppercase; }
.site-footer .fbrand small{ display:block; font-family:var(--font-jp); font-size:11px; letter-spacing:.5em; color:var(--ink-soft); margin-top:10px; }
.to-top{ margin:40px auto 0; display:inline-flex; flex-direction:column; align-items:center; gap:8px; font-family:var(--font-en); letter-spacing:.24em; text-transform:uppercase; font-size:11px; color:var(--ink-soft); border:0; background:none; }
.copyright{ margin-top:46px; font-family:var(--font-en); font-size:11px; letter-spacing:.18em; color:var(--ink-faint); }

/* shared placeholder swatch (for image slots) */
.ph-art{ background:
    repeating-linear-gradient(135deg, var(--accent-wash) 0 14px, var(--accent-soft) 14px 28px); }
.ph-note{ font-family:ui-monospace,monospace; font-size:10.5px; letter-spacing:.08em; color:var(--accent-deep); background:rgba(253,246,244,.7); padding:5px 10px; border-radius:3px; text-align:center; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:900px){
  .disc{ grid-template-columns:repeat(2,1fr); }
  .head-nav{ display:none; }
  .menu-toggle{ display:block; pointer-events:auto; }
  .profile-grid{ grid-template-columns:1fr; gap:40px; }
  .profile-media{ max-width:420px; margin:0 auto; }
  .data-list{ grid-template-columns:1fr; }
  .contact-grid{ grid-template-columns:1fr; }
  .gallery{ columns:2; }
  .news-row{ grid-template-columns:100px 1fr; gap:8px 18px; }
  .news-cat{ grid-row:1; grid-column:2; justify-self:start; }
  .news-ttl{ grid-column:1 / -1; }
  .news-arrow{ display:none; }
  .act{ grid-template-columns:90px 1fr; gap:6px 18px; }
  .act .kind{ grid-column:2; }
  .act .body-wrap{ grid-column:1 / -1; }
  .timeline::before{ left:74px; }
  .tl-row{ grid-template-columns:74px 1fr; gap:26px; }
  .tl-row::before{ left:70px; }
  .tl-year{ font-size:19px; }
  [data-hero="b"] .hero-name-v{ font-size:clamp(48px,16vw,90px); }
}
@media (max-width:560px){
  .gallery{ columns:1; }
  .disc{ grid-template-columns:1fr 1fr; gap:20px; }
  [data-hero] .hero-nav{ font-size:12px; }
  [data-hero="a"] .hero-nav{ gap:14px 22px; }
}

/* =====================================================================
   GLOBAL BOLD  — per request: 全体的に太文字
   ===================================================================== */
body, body h1, body h2, body h3, body h4, body h5, body h6,
body p, body a, body span, body div, body li, body dt, body dd,
body small, body strong, body em, body b,
body button, body input, body textarea, body select, body label,
body figcaption, body th, body td,
.label-en, .sec-title, .sec-title .jp, .hero-name, .hero-sub, .hero-tag,
.brand, .head-nav a, .news-ttl, .news-cat, .news-date,
.profile-lead, .profile-body p, .data-list dt, .data-list dd,
.bio-intro .q, .bio-intro p, .tl-year, .tl-body h4, .tl-body p,
.tab, .song h4, .song .meta, .song .yr, .act .yr, .act .kind, .act h4, .act p,
.sns .nm, .sns .handle, .contact-lead, .form-field label,
.band-label .en, .band-label .jp, .fp-curtain .clabel .en, .fp-curtain .clabel .jp,
.fp-index, .fp-index .cur, .fp-dots button .tip,
.site-footer .fbrand, .to-top, .copyright, .btn-line{
  font-weight:700 !important;
}
/* keep the very large display headings from synthetic over-bolding into mush */
.sec-title{ font-weight:700; }
