:root{
  --yellow:#FFD600;
  --pink:#FF5CA8;
  --blue:#4D8DFF;
  --purple:#8B5CFF;
  --black:#111111;
  --gray-700:#444;
  --gray-500:#777;
  --gray-300:#d9d9d9;
  --gray-100:#f5f5f7;
  --gray-50:#fafafa;
  --shadow-sm:0 4px 14px rgba(0,0,0,.06);
  --shadow-md:0 10px 30px rgba(0,0,0,.08);
  --shadow-lg:0 20px 50px rgba(0,0,0,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP","Inter",-apple-system,BlinkMacSystemFont,"Helvetica Neue",sans-serif;
  font-weight:400;color:var(--black);background:#fff;line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
body.is-loading{overflow:hidden;height:100vh}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* Splash */
.splash{position:fixed;inset:0;z-index:9999;background:#fff;display:grid;place-items:center;
  transition:opacity .6s ease .9s, visibility 0s linear 1.5s;}
.splash.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{display:flex;flex-direction:column;align-items:center;gap:18px;
  opacity:0;transform:translateY(8px) scale(.96);
  animation:splashIn .8s cubic-bezier(.2,.8,.2,1) .15s forwards;}
.splash-logo img{height:78px;width:auto;display:block;filter:drop-shadow(0 8px 24px rgba(0,0,0,.06));}
.splash-bar{width:120px;height:3px;border-radius:3px;background:#f0f0f0;position:relative;overflow:hidden;margin-top:6px;}
.splash-bar::after{content:"";position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,var(--yellow),transparent);
  transform:translateX(-100%);animation:splashShimmer 1.2s ease-in-out infinite;}
@keyframes splashIn{to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes splashShimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

/* Header */
.header{position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.9);backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(0,0,0,.04);}
.header-inner{display:flex;align-items:center;justify-content:space-between;
  height:72px;max-width:1280px;margin:0 auto;padding:0 28px;}
.logo{display:inline-flex;align-items:center;transition:opacity .25s}
.logo:hover{opacity:.78}
.logo img{height:38px;width:auto}
.nav{display:flex;align-items:center;gap:32px}
.nav a{font-size:13px;font-weight:600;letter-spacing:.08em;
  color:var(--gray-700);position:relative;padding:6px 0;}
.nav a:hover{color:var(--black)}
.nav a::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:2px;
  background:var(--yellow);transition:all .3s;transform:translateX(-50%);}
.nav a:hover::after{width:100%}
.cta-pill{display:inline-flex;align-items:center;gap:8px;background:var(--black);color:#fff;
  padding:12px 22px;border-radius:999px;font-weight:700;font-size:14px;
  box-shadow:0 8px 20px rgba(0,0,0,.18);transition:transform .25s,box-shadow .25s;}
.cta-pill:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.25)}
.cta-pill svg{width:16px;height:16px}
.menu-toggle{display:none;width:40px;height:40px;border-radius:10px;background:var(--gray-100)}
.menu-toggle span{display:block;width:18px;height:2px;background:var(--black);margin:4px auto;border-radius:2px}

/* Lang switch */
.lang-switch{position:relative;margin-right:6px}
.lang-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;
  background:rgba(0,0,0,.04);color:var(--gray-700);font-size:12px;font-weight:700;letter-spacing:.05em;
  transition:background .25s,color .25s;}
.lang-toggle:hover{background:var(--yellow);color:var(--black)}
.lang-toggle svg{width:14px;height:14px}
.lang-toggle .chev{width:10px;height:10px;transition:transform .25s}
.lang-switch.open .lang-toggle .chev{transform:rotate(180deg)}
.lang-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;
  box-shadow:0 12px 30px rgba(0,0,0,.12);border:1px solid rgba(0,0,0,.05);min-width:140px;padding:6px;
  opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .2s,transform .2s,visibility 0s linear .2s;z-index:120;}
.lang-switch.open .lang-menu{opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .2s,transform .2s,visibility 0s;}
.lang-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:9px 12px;
  font-size:13px;font-weight:600;color:var(--gray-700);border-radius:8px;text-align:left;}
.lang-menu button:hover{background:var(--gray-100);color:var(--black)}
.lang-menu button.active{background:var(--yellow);color:var(--black)}
.lang-menu .flag{font-size:14px;line-height:1}

@media (max-width:960px){
  .nav{
    display:flex;
    position:fixed;
    top:74px;left:0;right:0;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    background:#fff;
    padding:16px 20px 24px;
    box-shadow:0 18px 30px rgba(0,0,0,.12);
    border-top:1px solid var(--gray-200);
    transform:translateY(-12px);
    opacity:0;visibility:hidden;
    transition:opacity .25s,transform .25s,visibility 0s linear .25s;
    z-index:90;
  }
  .nav.is-open{
    opacity:1;visibility:visible;transform:translateY(0);
    transition:opacity .25s,transform .25s,visibility 0s;
  }
  .nav a{
    display:block;padding:14px 8px;
    font-size:14px;font-weight:700;
    border-bottom:1px solid var(--gray-100);
    color:var(--black);
  }
  .nav a:last-child{border-bottom:none}
  .menu-toggle{display:block}
  .menu-toggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .menu-toggle.is-open span:nth-child(2){opacity:0}
  .menu-toggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .menu-toggle span{transition:transform .25s,opacity .2s}
  .cta-pill{padding:10px 16px;font-size:12px}
}
@media (max-width:768px){
  .header .cta-pill{display:none}
  .lang-switch{margin-right:0}
}

.fab{
  display:none;
  position:fixed;right:18px;bottom:18px;z-index:200;
  background:var(--yellow);color:var(--black);
  padding:14px 20px;border-radius:999px;
  font-weight:800;font-size:14px;
  box-shadow:0 12px 30px rgba(255,214,0,.55),0 4px 12px rgba(0,0,0,.18);
  align-items:center;gap:8px;
  transition:transform .25s,box-shadow .25s;
  text-decoration:none;
}
.fab:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(255,214,0,.7),0 6px 14px rgba(0,0,0,.25)}
.fab svg{width:18px;height:18px;flex-shrink:0}
@media (max-width:768px){.fab{display:inline-flex}}

/* Profile Hero */
.profile-hero{padding:120px 0 70px;position:relative;overflow:hidden;
  background:linear-gradient(180deg,#FFF8DC 0%,#fff 100%);}
.profile-hero::before{content:"";position:absolute;right:-160px;top:-120px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#FFE875 0%,#FFD600 60%);
  opacity:.4;z-index:0;}
.profile-hero-inner{position:relative;z-index:1}
.crumbs{font-size:12px;color:var(--gray-500);display:flex;align-items:center;gap:8px;margin-bottom:30px;flex-wrap:wrap;}
.crumbs a:hover{color:var(--black)}
.crumbs svg{width:12px;height:12px;opacity:.6}

.profile-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:center;}
.profile-photo{
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);
  background:var(--gray-100);
  aspect-ratio:4/5;
}
.profile-photo img{width:100%;height:100%;object-fit:cover;display:block}
.profile-info .role{
  display:inline-block;
  font-family:"Inter",sans-serif;
  font-size:12px;font-weight:700;letter-spacing:.15em;
  color:var(--black);background:var(--yellow);
  padding:6px 14px;border-radius:999px;margin-bottom:18px;
}
.profile-info .name{
  font-size:clamp(36px,5vw,52px);
  font-weight:900;line-height:1.2;letter-spacing:-.01em;
  margin-bottom:18px;
}
.profile-info .name .hl{position:relative;display:inline-block;padding-bottom:10px}
.profile-info .name .hl::after{content:"";position:absolute;left:-4px;right:-4px;bottom:-2px;height:14px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 600 26' preserveAspectRatio='none'><path d='M3 17 C 80 8, 160 22, 240 14 S 380 6, 460 16 S 560 12, 596 10' fill='none' stroke='%23FF5CA8' stroke-width='9' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-size:100% 100%;}
.profile-bio{font-size:14px;color:var(--gray-700);line-height:2;margin-bottom:28px}
.profile-bio.empty{color:var(--gray-500);font-style:italic;font-size:13px}

/* Achievements */
.achievements{
  background:#fff;border:1.5px solid var(--gray-200);
  border-radius:18px;padding:22px 26px;
  margin-bottom:28px;box-shadow:var(--shadow-sm);
}
.achievements-title{
  font-size:14px;font-weight:900;letter-spacing:.05em;
  color:var(--black);margin-bottom:14px;
  display:flex;align-items:center;gap:8px;
}
.achievements-title::before{
  content:"";display:inline-block;width:18px;height:18px;
  background:var(--yellow);border-radius:50%;
  box-shadow:0 0 0 3px rgba(255,214,0,.25);
}
.achievements-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.achievements-list li{
  position:relative;padding-left:22px;
  font-size:14px;color:var(--gray-700);line-height:1.7;font-weight:500;
}
.achievements-list li::before{
  content:"";position:absolute;left:0;top:8px;
  width:8px;height:8px;border-radius:50%;
  background:var(--pink);
  box-shadow:0 0 0 3px rgba(255,92,168,.18);
}
@media (max-width:768px){
  .achievements{padding:18px 20px}
  .achievements-list li{font-size:13px}
}

/* SNS Links */
.sns-list{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.sns{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 18px;border-radius:12px;
  background:#fff;border:1.5px solid var(--gray-300);
  font-size:13px;font-weight:700;color:var(--black);
  transition:transform .25s,border-color .25s,background .25s,color .25s,box-shadow .25s;
}
.sns:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.sns.instagram:hover{background:linear-gradient(45deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);color:#fff;border-color:transparent}
.sns.youtube:hover{background:#FF0000;color:#fff;border-color:transparent}
.sns.tiktok:hover{background:#000;color:#fff;border-color:transparent}
.sns.x:hover{background:#000;color:#fff;border-color:transparent}
.sns svg{width:18px;height:18px;flex-shrink:0}
.sns-empty{font-size:12px;color:var(--gray-500);font-style:italic;padding:16px 0}

.profile-back{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;color:var(--gray-700);
  letter-spacing:.05em;
}
.profile-back:hover{color:var(--black)}
.profile-back svg{width:14px;height:14px}

@media (max-width:960px){
  .profile-grid{grid-template-columns:1fr;gap:30px}
  .profile-hero{padding:100px 0 50px}
  .profile-photo{max-width:380px;margin:0 auto}
}

/* CTA banner */
.cta-section{padding:0 0 100px;background:#fff}
.cta-banner{
  background:var(--yellow);border-radius:24px;padding:40px 32px;text-align:center;
  position:relative;overflow:hidden;
}
.cta-banner::before{content:"";position:absolute;top:-30px;right:-30px;
  width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,.25);}
.cta-banner::after{content:"";position:absolute;bottom:-50px;left:-30px;
  width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.2);}
.cta-banner > *{position:relative;z-index:1}
.cta-banner .eyebrow{font-family:"Inter",sans-serif;font-weight:700;font-size:11px;
  letter-spacing:.2em;color:var(--black);margin-bottom:12px}
.cta-banner h3{font-size:22px;font-weight:900;margin-bottom:10px}
.cta-banner p{font-size:13px;color:var(--gray-700);margin-bottom:22px;line-height:1.7}
.cta-banner .btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--black);color:#fff;padding:18px 40px;border-radius:12px;
  font-weight:800;font-size:15px;box-shadow:0 8px 18px rgba(0,0,0,.18);
  transition:transform .25s,box-shadow .25s;}
.cta-banner .btn:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,.25)}
.cta-banner .btn svg{width:18px;height:18px}

/* Other casts */
.other-casts{padding:60px 0;background:var(--gray-50)}
.other-casts h2{font-size:22px;font-weight:900;margin-bottom:6px}
.other-casts .lead{font-size:13px;color:var(--gray-500);margin-bottom:28px}
.other-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.other-grid .cast{background:#fff;border-radius:14px;overflow:hidden;
  box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;}
.other-grid .cast:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.other-grid .cast-img{aspect-ratio:1/1.05;overflow:hidden;background:var(--gray-100)}
.other-grid .cast-img img{width:100%;height:100%;object-fit:cover}
.other-grid .cast-info{padding:10px 8px;text-align:center}
.other-grid .cast-info h4{font-size:12px;font-weight:800;color:var(--black);margin-bottom:3px;line-height:1.3}
.other-grid .cast-info p{font-size:10px;color:var(--pink);font-weight:700}

@media (max-width:1100px){.other-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:680px){.other-grid{grid-template-columns:repeat(2,1fr)}}

/* Footer */
footer{background:#fff;border-top:1px solid var(--gray-300);padding:30px 0;}
.foot{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px;}
.foot-nav{display:flex;gap:24px;flex-wrap:wrap}
.foot-nav a{font-size:11px;font-weight:700;color:var(--gray-700);letter-spacing:.05em}
.foot-nav a:hover{color:var(--black)}
.copy{font-size:11px;color:var(--gray-500)}
@media (max-width:768px){
  .foot{justify-content:center;text-align:center}
  .foot-nav{justify-content:center}
}

/* Reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:translateY(0)}
