*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
:root{
  --pink:#f5a0c0; --pink-deep:#c85888; --pink-pale:#fde8f2; --pink-mid:#f0b8d0;
  --white-dango:#faf6f0; --green:#8fc87a; --green-deep:#4e8a3e;
  --green-pale:#e8f5e2; --green-mid:#b3dba6;
  --bg:#fdf8f0; --bg2:#faf2e8; --card:#ffffff;
  --dark:#2a1520; --mid:#6b3d58; --dim:#a87090;
  --parchment:#fdf6e8;
  --shadow:0 4px 24px rgba(200,88,136,.10);
  --manga-shadow:4px 4px 0 #2a1520;
  --shadow-lg:0 8px 40px rgba(200,88,136,.14);
  --ff:'Zen Maru Gothic',sans-serif;
  --ff-alt:'Zen Maru Gothic',sans-serif;
}
body{font-family:var(--ff);background:var(--bg);color:var(--dark);overflow-x:hidden;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{cursor:pointer;font-family:inherit;}

/* ═══════════ SPLASH ═══════════ */
#splash{
  position:fixed;inset:0;z-index:9999;
  background:var(--parchment);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  overflow:hidden;
}
#splash.exiting{animation:splashOut .65s cubic-bezier(.4,0,1,1) forwards;}
@keyframes splashOut{to{opacity:0;pointer-events:none;}}
#splash::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(200,88,136,.12) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none;
}
#splash-petals{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;}

.splash-dango-wrap{
  position:relative;display:flex;flex-direction:column;align-items:center;
  margin-bottom:2rem;height:286px;width:80px;
}
#dango-balls{
  display:flex;flex-direction:column;align-items:center;
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  z-index:2;gap:0;
  filter:drop-shadow(-5px 5px 0 rgba(160,80,100,.28));
}
#dango-stick{
  width:9px;height:100%;
  background:linear-gradient(180deg,#d4b07a 0%,#c09050 50%,#9a7030 100%);
  border-radius:4px 4px 5px 5px;
  box-shadow:2px 0 6px rgba(0,0,0,.18),-1px 0 2px rgba(255,255,255,.12);filter:drop-shadow(-5px 5px 0 rgba(120,80,20,.3));
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  z-index:1;
}
.dango-ball{
  width:72px;height:72px;border-radius:50%;
  opacity:0;transform:translateY(-140px);flex-shrink:0;position:relative;
  box-shadow:0 4px 16px rgba(0,0,0,.12),inset 0 -4px 8px rgba(0,0,0,.08),inset 0 4px 8px rgba(255,255,255,.3);
}
.dango-ball::after{
  content:'';position:absolute;top:13px;left:17px;
  width:15px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.55);transform:rotate(-30deg);
}
.dango-ball.b1{background:radial-gradient(circle at 35% 30%,#fab8d2,#f5a0c0 55%,#e07098);}
.dango-ball.b2{background:radial-gradient(circle at 35% 30%,#ffffff,#faf6f0 55%,#e0d8d0);}
.dango-ball.b3{background:radial-gradient(circle at 35% 30%,#b0e098,#8fc87a 55%,#5ea84a);}
.dango-ball.landed{opacity:1;transform:translateY(0);}
.dango-ball.bounce{animation:dangoBounce .6s cubic-bezier(.36,.07,.19,.97) forwards;}
@keyframes dangoBounce{
  0%{opacity:0;transform:translateY(-140px) scale(1,1);}
  58%{opacity:1;transform:translateY(5px) scale(1.14,.86);}
  74%{transform:translateY(-8px) scale(.96,1.04);}
  88%{transform:translateY(3px) scale(1.04,.96);}
  100%{opacity:1;transform:translateY(0) scale(1,1);}
}
.land-ripple{
  position:absolute;width:72px;height:16px;border-radius:50%;
  background:rgba(200,88,136,.15);
  animation:rippleOut .5s ease-out forwards;pointer-events:none;
}
@keyframes rippleOut{0%{transform:scale(.4);opacity:.6;}100%{transform:scale(2.2);opacity:0;}}
@keyframes dangoBobble{0%,100%{transform:translateY(0) scale(1,1);}50%{transform:translateY(-4px) scale(1.02,.98);}}
.splash-title{
  text-align:center;margin-bottom:1.4rem;
  opacity:0;transform:translateY(12px);
  transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1);
}
.splash-title.show{opacity:1;transform:none;}
.splash-title p{font-family:var(--ff-alt);font-size:.88rem;color:var(--dim);margin-top:.4rem;letter-spacing:.14em;}
.splash-dots{display:flex;gap:6px;align-items:center;margin-bottom:1.5rem;opacity:0;transition:opacity .5s ease;}
.splash-dots.show{opacity:1;}
.splash-dot{width:9px;height:9px;border-radius:50%;}
.splash-dot.p{background:var(--pink);}
.splash-dot.w{background:var(--white-dango);border:1.5px solid #e0d8d0;}
.splash-dot.g{background:var(--green);}
.splash-enter-wrap{opacity:0;pointer-events:none;transition:opacity .8s ease;}
.splash-enter-wrap.show{opacity:1;pointer-events:auto;}
.splash-enter{
  background:linear-gradient(135deg,var(--pink) 0%,var(--pink-deep) 100%);
  border:none;color:#fff;font-family:var(--ff);font-weight:800;
  font-size:.9rem;letter-spacing:.18em;text-transform:uppercase;
  padding:.9rem 3rem;border-radius:100px;
  box-shadow:0 4px 20px rgba(200,88,136,.3);
  transition:transform .2s,box-shadow .2s;
}
.splash-enter:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(200,88,136,.38);}

/* ═══════════ PARTICLES ═══════════ */
#particle-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity 2s ease;}
#particle-canvas.show{opacity:1;}

/* ═══════════ NAV ═══════════ */
#main-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:10px clamp(1rem,3vw,2rem);
  display:flex;align-items:center;justify-content:space-between;
  transform:translateY(-100%);opacity:0;
  transition:transform .6s cubic-bezier(.16,1,.3,1),opacity .5s ease;
}
#main-nav.show{transform:none;opacity:1;}
.nav-pill{
  background:rgba(253,248,240,.92);backdrop-filter:blur(14px);
  border:1.5px solid var(--pink-mid);border-radius:100px;
  display:flex;align-items:center;gap:.5rem;padding:.45rem 1.1rem;
}
.nav-dots{display:flex;gap:2px;}
.nav-dots span{width:7px;height:7px;border-radius:50%;transition:transform .25s ease;}
.nav-dots span:nth-child(1){background:var(--pink);}
.nav-dots span:nth-child(2){background:#d4ccc4;}
.nav-dots span:nth-child(3){background:var(--green);}
.nav-pill:hover .nav-dots span:nth-child(1){transform:translateY(-3px);}
.nav-pill:hover .nav-dots span:nth-child(2){transform:translateY(-3px);transition-delay:.06s;}
.nav-pill:hover .nav-dots span:nth-child(3){transform:translateY(-3px);transition-delay:.12s;}
.nav-links-pill{
  background:rgba(253,248,240,.92);backdrop-filter:blur(14px);
  border:1.5px solid var(--pink-mid);border-radius:100px;
  display:flex;align-items:center;gap:.2rem;padding:.35rem .5rem;
}
.nav-links-pill a{
  font-family:var(--ff);font-size:.8rem;font-weight:700;color:var(--mid);
  padding:.3rem .75rem;border-radius:100px;transition:background .2s,color .2s;
}
.nav-links-pill a:hover,.nav-links-pill a.active{background:var(--pink-pale);color:var(--pink-deep);}
/* Hamburger always visible on mobile */
.nav-ham{
  display:none;background:rgba(253,248,240,.92);backdrop-filter:blur(14px);
  border:1.5px solid #e8a8c0;border-radius:10px;
  box-shadow:2px 2px 0 #d4789a;
  padding:8px 10px;cursor:pointer;z-index:200;
  flex-direction:column;gap:5px;align-items:center;justify-content:center;
}
.nav-ham span{
  display:block;width:20px;height:2.5px;
  background:var(--mid);border-radius:2px;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1),opacity .2s ease;
  transform-origin:center;
}
.nav-ham.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.nav-ham.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.nav-ham.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}
@media(max-width:680px){
  .nav-links-pill{
    display:none;opacity:0;pointer-events:none;
    flex-direction:column;align-items:stretch;
    position:fixed;top:62px;right:1rem;
    background:rgba(253,248,240,.97);backdrop-filter:blur(18px);
    border:1.5px solid #e8a8c0;box-shadow:4px 4px 0 #d4789a;
    border-radius:18px;padding:.6rem .5rem;gap:.15rem;min-width:170px;
    transform:translateY(-8px) scale(.97);
    transition:opacity .25s ease,transform .3s cubic-bezier(.34,1.56,.64,1);
    z-index:150;
  }
  .nav-links-pill.open{
    display:flex;opacity:1;pointer-events:auto;
    transform:translateY(0) scale(1);
  }
  .nav-links-pill a{text-align:center;padding:.5rem .75rem;}
  .nav-ham{display:flex;}
}

/* ═══ MOBILE LAYOUT ═══ */
@media(max-width:700px){

  /* ── Hero ── */
  #page-hero{ padding-top:58px; min-height:100svh; position:relative; }
  .hero-slide-wrap{
    position:absolute;
    top:58px; right:0; left:auto; bottom:0;
    width:58%;
    height:auto;
    opacity:1;
    pointer-events:none;
  }
  .hero-slide{
    position:absolute;
    top:0; right:0; bottom:0; left:0;
    width:100%; height:100%;
    object-fit:contain;
    object-position:right top;
    transform:none !important; opacity:1 !important;
    filter:none;
  }
  .hero-slide.slide-in{ animation:none; }
  .hero-text{
    width:52%;
    max-width:52%;
    padding:2rem 0 2rem 1.2rem;
    position:relative; z-index:3;
  }
  .hero-logo{ width:clamp(180px,65vw,320px); }
  .hero-tagline{ font-size:.85rem; max-width:260px; }
  .hero-pills{ flex-wrap:wrap; }
  .page-down-hint{ bottom:1rem; }

  /* ── Character ── */
  .char-layout{ grid-template-columns:1fr; }
  .profile-card{ max-width:340px; margin:0 auto; width:100%; }

  /* ── VB Panels ── */
  .vb-panel-art{ display:none; }
  .vb-content{
    max-width:100%;
    width:100%;
    margin:0 !important;
    padding:5rem 1.4rem 3rem !important;
    min-height:100svh;
  }

  /* ── VB Banners ── */
  .vb-banner{ padding:.85rem 1rem; }
  .vb-banner-title{ font-size:1rem; }

  /* ── Gallery ── */
  .gallery-grid{ grid-template-columns:repeat(2,1fr); gap:.75rem; }

  /* ── Terms ── */
  .terms-cols{ grid-template-columns:1fr; }

  /* ── Links ── */
  .link-grid{ grid-template-columns:1fr; }
  .link-card{ max-width:100%; }

  /* ── Dango widget ── */
  #dango-widget{
    position:fixed;
    inset:0;
    bottom:auto; left:auto; right:auto; top:auto;
    width:260px;
    max-width:88vw;
    top:50%; left:50%;
    transform:translate(-50%,-50%) scale(.92);
    opacity:0;
    pointer-events:none;
    transition:opacity .25s ease, transform .25s cubic-bezier(.16,1,.3,1);
    z-index:8000;
    animation:none !important;
  }
  #dango-widget.mobile-open{
    opacity:1;
    transform:translate(-50%,-50%) scale(1);
    pointer-events:auto;
  }
  #dango-mobile-backdrop{
    display:block;
    position:fixed; inset:0;
    background:rgba(30,10,20,.5);
    backdrop-filter:blur(3px);
    z-index:7999;
    opacity:0; pointer-events:none;
    transition:opacity .25s ease;
  }
  #dango-mobile-backdrop.open{ opacity:1; pointer-events:auto; }
  #dango-mobile-btn{ display:flex; }

  /* ── Secret panel ── */
  .secret-art{ display:none; }
  .secret-content{
    max-width:100% !important;
    width:100% !important;
    margin:0 !important;
    padding:5rem 1.4rem 3rem !important;
  }

  /* ── Milestone popup ── */
  #dango-milestone-card{ padding:1.5rem 1.2rem; }
  #dango-milestone-bust{ width:110px; height:110px; }

  /* ── Footer ── */
  footer{ padding:1.5rem 1rem; }
  .footer-logo{ font-size:.82rem; }
  .footer-copy{ font-size:.65rem; }
}

/* ═══════════ PAGE SYSTEM ═══════════ */
.page{
  min-height:100vh;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}

/* ═══════════ PAGE 1 — HERO ═══════════ */
#page-hero{
  background:linear-gradient(165deg,#fff0f6 0%,#fde8f2 30%,#f4faf0 100%);
  align-items:stretch;justify-content:flex-start;
  padding-top:58px;
}
#page-hero::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(245,160,192,.16) 1.5px,transparent 1.5px);
  background-size:26px 26px;pointer-events:none;
}
/* Giant faint dango circles in bg */
#page-hero::after{
  content:'● ● ●';position:absolute;
  bottom:-8vh;right:-5vw;
  font-size:clamp(180px,30vw,400px);line-height:1.2;letter-spacing:-.2em;
  color:rgba(245,160,192,.04);pointer-events:none;user-select:none;white-space:nowrap;
}

/* Hero single art */
.hero-slide-wrap{
  position:absolute;
  top:58px; right:0; bottom:0;
  width:55%;
  z-index:2; overflow:hidden;
}
.hero-slide{
  position:absolute;top:0;right:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center 0%;
  filter:drop-shadow(-28px 0 0 rgba(245,160,192,.22));
  transform:translateX(110%);opacity:0;
}
.hero-slide.slide-in{
  animation:heroSlideIn .9s cubic-bezier(.16,1,.3,1) forwards;
}
@keyframes heroSlideIn{
  from{transform:translateX(110%);opacity:0;}
  to{transform:translateX(0);opacity:1;}
}
.hero-art-main{
  position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  height:min(90vh,900px);width:auto;
  object-fit:contain;object-position:bottom center;
  filter:drop-shadow(0 0 50px rgba(245,160,192,.28)) drop-shadow(0 30px 50px rgba(200,88,136,.12));
  z-index:2;
  opacity:0;transform:translateX(-50%) translateY(20px);
  transition:opacity 1.1s ease .3s,transform 1.1s cubic-bezier(.16,1,.3,1) .3s;
}
.hero-art-main.show{opacity:1;transform:translateX(-50%) translateY(0);}
/* Text overlay — left side */
.hero-text{
  position:relative;z-index:3;
  padding:clamp(3rem,7vw,6rem) clamp(2rem,5vw,4.5rem);
  align-self:flex-start;max-width:660px;
  width:52%;
  margin-bottom:auto;
}
.hero-tag{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;border:1.5px solid var(--pink-mid);
  border-radius:100px;padding:.4rem 1.2rem;
  font-family:var(--ff);font-size:.78rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--pink-deep);
  margin-bottom:1.5rem;box-shadow:0 2px 12px rgba(200,88,136,.1);
}
.tag-dots span{width:5px;height:5px;border-radius:50%;animation:tagBounce 1.4s ease-in-out infinite;}
.tag-dots span:nth-child(1){background:var(--pink);animation-delay:0s;}
.tag-dots span:nth-child(2){background:#d4ccc4;animation-delay:.15s;}
.tag-dots span:nth-child(3){background:var(--green);animation-delay:.30s;}
@keyframes tagBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.hero-logo{width:clamp(300px,44vw,600px);height:auto;margin-bottom:1.4rem;filter:drop-shadow(0 2px 10px rgba(200,88,136,.2));}
.hero-tagline{
  font-family:var(--ff-alt);font-size:clamp(1.1rem,2.2vw,1.5rem);
  color:var(--mid);line-height:1.85;margin-bottom:2.2rem;max-width:560px;
}
.hero-pills{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.4rem;}
.hero-pill{
  border-radius:100px;padding:.45rem 1.2rem;
  font-family:var(--ff);font-size:.95rem;font-weight:700;
  background:#fff;border:1.5px solid var(--pink-mid);color:var(--mid);
  transition:transform .2s;
}
.hero-pill:hover{transform:translateY(-2px);}
.hero-pill.pink{background:var(--pink-pale);border-color:var(--pink);color:var(--pink-deep);}
.hero-pill.green{background:var(--green-pale);border-color:var(--green-mid);color:var(--green-deep);}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;}
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--ff);font-size:1rem;font-weight:800;
  padding:.85rem 2rem;border-radius:100px;border:none;
  transition:transform .2s,box-shadow .2s;text-decoration:none;
}
.btn.pink{background:linear-gradient(135deg,var(--pink),var(--pink-deep));color:#fff;box-shadow:0 4px 18px rgba(200,88,136,.28);}
.btn.green{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;box-shadow:0 4px 18px rgba(78,138,62,.22);}
.btn:hover{transform:translateY(-2px);}
/* Down hint */
.page-down-hint{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  z-index:4;display:flex;flex-direction:column;align-items:center;gap:.35rem;
  font-family:var(--ff);font-size:.62rem;font-weight:700;letter-spacing:.28em;
  text-transform:uppercase;color:var(--dim);
  opacity:0;transition:opacity .6s ease .8s;
}
.page-down-hint.show{opacity:.55;}
.page-down-hint svg{width:18px;height:18px;fill:var(--pink);animation:bounce 1.8s ease-in-out infinite;}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* Stagger hero text */
.hero-text>*{opacity:0;transform:translateY(14px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1);}
.hero-text.show>*:nth-child(1){opacity:1;transform:none;transition-delay:.06s;}
.hero-text.show>*:nth-child(2){opacity:1;transform:none;transition-delay:.14s;}
.hero-text.show>*:nth-child(3){opacity:1;transform:none;transition-delay:.22s;}
.hero-text.show>*:nth-child(4){opacity:1;transform:none;transition-delay:.30s;}
.hero-text.show>*:nth-child(5){opacity:1;transform:none;transition-delay:.38s;}

/* ═══════════ PAGE 2 — CHARACTER ═══════════ */
#page-character{background:var(--bg);min-height:unset;align-items:center;}
#page-character>.sec-header{max-width:900px;padding-left:clamp(1.5rem,4vw,3rem);padding-right:clamp(1.5rem,4vw,3rem);}
.char-layout{
  display:grid;grid-template-columns:260px 1fr;
  gap:clamp(1.5rem,4vw,3rem);
  padding:0 clamp(1.5rem,4vw,3rem) clamp(2rem,4vw,3rem);
  align-items:start;
  max-width:900px;
  margin:0 auto;
  width:100%;
}
@media(max-width:760px){.char-layout{grid-template-columns:1fr;}}
/* Profile card */
.profile-card{
  background:var(--card);border-radius:24px;
  border:2px solid var(--pink-mid);box-shadow:var(--shadow-lg);overflow:hidden;
  position:sticky;top:80px;
}
.profile-card-top{
  background:linear-gradient(150deg,var(--pink) 0%,var(--pink-deep) 100%);
  padding:1.5rem;text-align:center;position:relative;overflow:hidden;
}
.profile-card-top::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.2) 1px,transparent 1px);
  background-size:14px 14px;
}
.profile-icon-crop{
  width:90px;height:90px;border-radius:50%;
  border:3px solid rgba(255,255,255,.85);
  box-shadow:0 4px 18px rgba(0,0,0,.15);
  margin:0 auto 1rem;overflow:hidden;
  background:var(--pink-pale);position:relative;z-index:1;
}
/* Zoom in on face — push image up and scale */
.profile-icon-crop img{
  width:100%;height:100%;object-fit:cover;
  object-position:center 10%;transform:scale(1.35);transform-origin:center 30%;
}
.profile-card-name{font-family:var(--ff);font-size:1.1rem;font-weight:900;color:#fff;position:relative;z-index:1;}
.profile-card-jp{font-family:var(--ff-alt);font-size:.82rem;color:rgba(255,255,255,.75);margin-top:.15rem;position:relative;z-index:1;}
.profile-badge{
  display:inline-flex;align-items:center;gap:.3rem;margin-top:.7rem;position:relative;z-index:1;
  background:rgba(255,255,255,.95);border-radius:100px;
  padding:.2rem .8rem;font-family:var(--ff);font-size:.62rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;color:var(--pink-deep);
}
.profile-stats{padding:1.1rem 1.3rem;}
.stat-row{display:flex;justify-content:space-between;align-items:baseline;gap:.5rem;padding:.42rem 0;border-bottom:1.5px dashed var(--pink-pale);}
.stat-row:last-child{border-bottom:none;}
.stat-k{font-family:var(--ff);font-size:.58rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--dim);flex-shrink:0;white-space:nowrap;}
.stat-v{font-family:var(--ff);font-size:.8rem;font-weight:700;color:var(--dark);text-align:right;white-space:nowrap;}
.stat-v.pink{color:var(--pink-deep);}
.stat-v.green{color:var(--green-deep);}
/* Tabbed journal */
.journal-card{background:var(--card);border-radius:24px;border:2px solid var(--pink-mid);box-shadow:var(--shadow);overflow:hidden;}
.journal-tabs{display:flex;border-bottom:2px solid var(--pink-pale);}
.journal-tab{
  flex:1;padding:.7rem;text-align:center;
  font-family:var(--ff);font-size:.75rem;font-weight:800;color:var(--dim);
  cursor:pointer;border:none;background:none;
  border-right:1px solid var(--pink-pale);transition:background .2s,color .2s;
}
.journal-tab:last-child{border-right:none;}
.journal-tab.active{background:var(--pink-pale);color:var(--pink-deep);}
.journal-tab:hover:not(.active){background:var(--bg);}
.journal-body{padding:1.6rem;}
.journal-panel{display:none;opacity:0;}
.journal-panel.active{display:block;opacity:0;animation:tabFadeUp .28s cubic-bezier(.16,1,.3,1) forwards;}
.journal-panel.tab-out{animation:tabFadeOut .18s ease forwards;}
@keyframes tabFadeUp{
  from{opacity:0;transform:translateY(8px);}
  to{opacity:1;transform:translateY(0);}
}
@keyframes tabFadeOut{
  from{opacity:1;transform:translateY(0);}
  to{opacity:0;transform:translateY(-6px);}
}
.journal-text{font-family:var(--ff-alt);font-size:.97rem;line-height:1.9;color:var(--mid);}
.journal-text p+p{margin-top:.8rem;}
.journal-text strong{color:var(--dark);font-family:var(--ff);}
.chip-cloud{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem;}
.chip{border-radius:100px;padding:.28rem .85rem;font-family:var(--ff);font-size:.78rem;font-weight:700;transition:transform .18s;}
.chip:hover{transform:scale(1.05);}
.chip.like{background:var(--pink-pale);border:1.5px solid var(--pink-mid);color:var(--pink-deep);}
.chip.dislike{background:var(--green-pale);border:1.5px solid var(--green-mid);color:var(--green-deep);}
.chip.rel{background:#fffbe8;border:1.5px solid #e8d888;color:#886a10;}
.quote-block{
  margin-top:1.2rem;padding:1rem 1.2rem;
  background:linear-gradient(135deg,var(--pink-pale),var(--green-pale));
  border-radius:14px;border-left:3px solid var(--pink);
  font-family:var(--ff-alt);font-style:italic;font-size:.94rem;color:var(--mid);line-height:1.75;
}
.quote-block cite{display:block;margin-top:.5rem;font-family:var(--ff);font-size:.64rem;font-weight:700;letter-spacing:.14em;color:var(--dim);font-style:normal;text-transform:uppercase;}

/* ═══════════ VOICEBANKS HUB + PANELS ═══════════ */
#page-voicebanks{background:linear-gradient(155deg,#fff5f8 0%,#fdf6f0 50%,#f4faf0 100%);min-height:unset;}
.vb-hub-inner{padding:0 clamp(1.5rem,4vw,3rem) clamp(2rem,4vw,3.5rem);width:100%;}
.vb-banners{display:flex;flex-direction:column;gap:1rem;max-width:640px;margin:0 auto;}

/* Banner button */
.vb-banner{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:rgba(255,255,255,.85);backdrop-filter:blur(10px);
  border-radius:20px;padding:1.2rem 1.6rem;cursor:pointer;
  border:2px solid var(--pink-mid);box-shadow:var(--shadow);
  transition:transform .2s,box-shadow .2s,border-color .2s;
  width:100%;text-align:left;font-family:var(--ff);
}
.vb-banner:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.vb-banner.cv{border-color:var(--pink-mid);}
.vb-banner.natural{border-color:#e0d4c0;}
.vb-banner.takoyaki{border-color:var(--green-mid);}
.vb-banner:hover.cv{border-color:var(--pink);}
.vb-banner:hover.natural{border-color:#c8b898;}
.vb-banner:hover.takoyaki{border-color:var(--green);}

.vb-banner-left{display:flex;align-items:center;gap:.9rem;}
.vb-banner-dots{display:flex;gap:3px;flex-shrink:0;}
.vb-banner-dots span{width:8px;height:8px;border-radius:50%;}
.vb-banner.cv .vb-banner-dots span:nth-child(1){background:var(--pink);}
.vb-banner.cv .vb-banner-dots span:nth-child(2){background:#d4ccc4;}
.vb-banner.cv .vb-banner-dots span:nth-child(3){background:var(--green);}
.vb-banner.natural .vb-banner-dots span:nth-child(1){background:#e0c8a0;}
.vb-banner.natural .vb-banner-dots span:nth-child(2){background:#d4ccc4;}
.vb-banner.natural .vb-banner-dots span:nth-child(3){background:#b8a880;}
.vb-banner.takoyaki .vb-banner-dots span:nth-child(1){background:var(--green);}
.vb-banner.takoyaki .vb-banner-dots span:nth-child(2){background:#d4ccc4;}
.vb-banner.takoyaki .vb-banner-dots span:nth-child(3){background:var(--pink);}

.vb-banner-name{font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);}
.vb-banner-flavor{font-size:1.15rem;font-weight:900;line-height:1.1;margin-top:.1rem;}
.vb-banner.cv .vb-banner-flavor{color:var(--pink-deep);}
.vb-banner.natural .vb-banner-flavor{color:#7a6040;}
.vb-banner.takoyaki .vb-banner-flavor{color:var(--green-deep);}

.vb-banner-right{display:flex;align-items:center;gap:.8rem;flex-shrink:0;}
.vb-banner-arrow{
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  transition:transform .25s,background .2s;flex-shrink:0;
}
.vb-banner.cv .vb-banner-arrow{background:var(--pink-pale);}
.vb-banner.natural .vb-banner-arrow{background:#f0e8d4;}
.vb-banner.takoyaki .vb-banner-arrow{background:var(--green-pale);}
.vb-banner:hover .vb-banner-arrow{transform:translateX(3px);}
.vb-banner-arrow svg{width:14px;height:14px;}
.vb-banner.cv .vb-banner-arrow svg{fill:var(--pink-deep);}
.vb-banner.natural .vb-banner-arrow svg{fill:#7a6040;}
.vb-banner.takoyaki .vb-banner-arrow svg{fill:var(--green-deep);}

/* Full-screen VB overlay panel */
.vb-panel{
  position:fixed;inset:0;z-index:500;
  display:none;overflow-y:auto;
}
.vb-panel.open{display:block;animation:panelIn .4s cubic-bezier(.16,1,.3,1);}
.vb-panel.closing{display:block;animation:panelOut .35s ease forwards;}
@keyframes panelIn{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes panelOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}
.vb-panel.cv{background:linear-gradient(155deg,#fff5f8 0%,#fde8f2 50%,#fff0f5 100%);}
.vb-panel.natural{background:linear-gradient(155deg,#fdf8f0 0%,#faf4e8 50%,#fdf6e8 100%);}
.vb-panel.takoyaki{background:linear-gradient(155deg,#f0faf0 0%,#e4f5e0 50%,#f0faf2 100%);}

/* ── Option D: Washi Paper Diamond/Crosshatch ── */
.vb-panel.cv .vb-panel-inner::before,
.vb-panel.natural .vb-panel-inner::before,
.vb-panel.takoyaki .vb-panel-inner::before,
.secret-panel-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.vb-panel.cv .vb-panel-inner::before {
  background-image:
    repeating-linear-gradient(45deg,  rgba(245,160,192,.10) 0, rgba(245,160,192,.10) 1px, transparent 0, transparent 50%),
    repeating-linear-gradient(-45deg, rgba(245,160,192,.10) 0, rgba(245,160,192,.10) 1px, transparent 0, transparent 50%);
  background-size: 24px 24px;
}
.vb-panel.natural .vb-panel-inner::before {
  background-image:
    repeating-linear-gradient(45deg,  rgba(180,150,100,.09) 0, rgba(180,150,100,.09) 1px, transparent 0, transparent 50%),
    repeating-linear-gradient(-45deg, rgba(180,150,100,.09) 0, rgba(180,150,100,.09) 1px, transparent 0, transparent 50%);
  background-size: 24px 24px;
}
.vb-panel.takoyaki .vb-panel-inner::before {
  background-image:
    repeating-linear-gradient(45deg,  rgba(100,180,80,.10) 0, rgba(100,180,80,.10) 1px, transparent 0, transparent 50%),
    repeating-linear-gradient(-45deg, rgba(100,180,80,.10) 0, rgba(100,180,80,.10) 1px, transparent 0, transparent 50%);
  background-size: 24px 24px;
}
.secret-panel-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    repeating-linear-gradient(45deg,  rgba(100,130,200,.09) 0, rgba(100,130,200,.09) 1px, transparent 0, transparent 50%),
    repeating-linear-gradient(-45deg, rgba(100,130,200,.09) 0, rgba(100,130,200,.09) 1px, transparent 0, transparent 50%);
  background-size: 24px 24px;
}
.vb-panel-inner{position:relative;min-height:100vh;overflow:hidden;}

/* Close button */
.vb-close{
  position:fixed;top:1.2rem;right:1.4rem;z-index:600;
  background:rgba(255,255,255,.9);backdrop-filter:blur(8px);
  border:1.5px solid var(--pink-mid);border-radius:100px;
  display:flex;align-items:center;gap:.4rem;
  padding:.4rem 1rem;cursor:pointer;
  font-family:var(--ff);font-size:.72rem;font-weight:800;
  color:var(--mid);letter-spacing:.12em;text-transform:uppercase;
  transition:background .2s,transform .2s;
}
.vb-close:hover{background:#fff;transform:scale(1.04);}
.vb-close svg{width:12px;height:12px;fill:currentColor;}

/* Panel bg art */
.vb-panel-art{
  position:absolute;bottom:0;
  height:min(95vh,920px);width:auto;object-fit:contain;
  opacity:1;filter:saturate(1);
  z-index:1;cursor:pointer;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.vb-panel-art:hover{transform:translateY(-12px);}
.vb-panel.natural .vb-panel-art{right:8%;object-position:bottom right;}
/* CV and takoyaki: art on left */
.vb-panel.cv .vb-panel-art{left:8%;object-position:bottom left;}
.vb-panel.takoyaki .vb-panel-art{left:8%;object-position:bottom left;height:min(110vh,1100px);}

.vb-panel-art-label{
  position:absolute;bottom:1.5rem;z-index:2;
  font-family:var(--ff);font-size:.62rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--dim);
  opacity:0;transition:opacity .3s ease;pointer-events:none;
}
.vb-panel.natural .vb-panel-art-label{right:2%;}
.vb-panel.cv .vb-panel-art-label,.vb-panel.takoyaki .vb-panel-art-label{left:2%;}
.vb-panel-inner:hover .vb-panel-art-label{opacity:.7;}

/* Panel content */
.vb-content{
  position:relative;z-index:3;
  padding:clamp(4rem,8vw,6rem) clamp(1.5rem,3vw,3rem) clamp(2rem,5vw,5rem);
  max-width:520px;
  display:flex;flex-direction:column;justify-content:center;min-height:100vh;
}
/* cv + takoyaki: content on right side */
.vb-panel.cv .vb-content,.vb-panel.takoyaki .vb-content{margin-left:auto;margin-right:clamp(2rem,6vw,8rem);}
/* natural: content on left (default) */
.vb-panel.natural .vb-content{margin-right:auto;margin-left:clamp(2rem,6vw,8rem);}

.vb-eyebrow{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;}
.vb-eyebrow-dots{display:flex;gap:2px;}
.vb-eyebrow-dots span{width:6px;height:6px;border-radius:50%;}
.vb-eyebrow span.label{font-family:var(--ff);font-size:.66rem;font-weight:700;letter-spacing:.28em;text-transform:uppercase;}
.vb-panel.cv .vb-eyebrow-dots span:nth-child(1){background:var(--pink);}
.vb-panel.cv .vb-eyebrow-dots span:nth-child(2){background:#d4ccc4;}
.vb-panel.cv .vb-eyebrow-dots span:nth-child(3){background:var(--green);}
.vb-panel.cv span.label{color:var(--pink-deep);}
.vb-panel.natural .vb-eyebrow-dots span:nth-child(1){background:#e0c8a0;}
.vb-panel.natural .vb-eyebrow-dots span:nth-child(2){background:#d4ccc4;}
.vb-panel.natural .vb-eyebrow-dots span:nth-child(3){background:var(--green);}
.vb-panel.natural span.label{color:#7a6040;}
.vb-panel.takoyaki .vb-eyebrow-dots span:nth-child(1){background:var(--green);}
.vb-panel.takoyaki .vb-eyebrow-dots span:nth-child(2){background:#d4ccc4;}
.vb-panel.takoyaki .vb-eyebrow-dots span:nth-child(3){background:var(--pink);}
.vb-panel.takoyaki span.label{color:var(--green-deep);}

.vb-name-big{font-family:var(--ff);font-weight:900;font-size:clamp(2rem,4.5vw,3.4rem);color:var(--dark);line-height:1.1;margin-bottom:.2rem;}
.vb-flavor-big{font-family:var(--ff);font-weight:800;font-size:clamp(1.5rem,3.5vw,2.5rem);margin-bottom:1.5rem;}
.vb-panel.cv .vb-flavor-big{color:var(--pink-deep);}
.vb-panel.natural .vb-flavor-big{color:#7a6040;}
.vb-panel.takoyaki .vb-flavor-big{color:var(--green-deep);}
.vb-desc-main{font-family:var(--ff-alt);font-size:clamp(1rem,1.6vw,1.15rem);color:var(--mid);line-height:1.85;margin-bottom:2rem;max-width:500px;}
.vb-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:2rem;}
.vb-info-cell{background:rgba(255,255,255,.75);backdrop-filter:blur(6px);border-radius:14px;padding:1rem 1.2rem;}
.vb-panel.cv .vb-info-cell{border:1.5px solid var(--pink-mid);}
.vb-panel.natural .vb-info-cell{border:1.5px solid var(--pink-mid);}
.vb-panel.takoyaki .vb-info-cell{border:1.5px solid var(--green-mid);}
.vb-info-label{font-family:var(--ff);font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-bottom:.25rem;}
.vb-info-value{font-family:var(--ff);font-size:1rem;font-weight:700;color:var(--dark);}
.vb-action-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;}
.vb-status{border-radius:100px;padding:.32rem .9rem;font-family:var(--ff);font-size:.65rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;}
.vb-status.coming{background:var(--bg2);border:1.5px solid #ddd4c8;color:var(--dim);}
.vb-status.out{background:var(--green-pale);border:1.5px solid var(--green-mid);color:var(--green-deep);}
.vb-art-hint{font-family:var(--ff);font-size:.68rem;font-weight:700;letter-spacing:.12em;color:var(--dim);display:flex;align-items:center;gap:.4rem;margin-top:1.2rem;opacity:.6;}
.vb-art-hint::before{content:"";}

/* ═══════════ PAGE 5 — TERMS ═══════════ */
#page-terms{background:var(--bg);}
.terms-inner{padding:clamp(2rem,5vw,4rem) clamp(1.5rem,4vw,3rem);flex:1;}
.terms-card{
  background:var(--card);border-radius:24px;
  border:2px solid var(--pink-mid);box-shadow:var(--shadow);overflow:hidden;
  max-width:800px;margin:0 auto;
}
.terms-banner{
  background:linear-gradient(135deg,var(--pink) 0%,var(--pink-deep) 100%);
  padding:1.3rem 1.8rem;text-align:center;
}
.terms-banner-title{font-family:var(--ff);font-size:1rem;font-weight:900;color:#fff;}
.terms-banner-sub{font-family:var(--ff-alt);font-size:.75rem;color:rgba(255,255,255,.7);margin-top:.25rem;}
.terms-body{padding:2rem clamp(1.2rem,4vw,2.5rem);}
.terms-cols{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
@media(max-width:600px){.terms-cols{grid-template-columns:1fr;}}
.terms-col-head{font-family:var(--ff);font-size:.8rem;font-weight:900;color:var(--dark);margin-bottom:.9rem;display:flex;align-items:center;gap:.5rem;}
.terms-col-head svg{width:15px;height:15px;}
.terms-col-head.allow{color:var(--green-deep);}
.terms-col-head.deny{color:var(--pink-deep);}
.term-row{display:flex;align-items:flex-start;gap:.6rem;padding:.55rem .75rem;border-radius:10px;margin-bottom:.35rem;font-family:var(--ff-alt);font-size:.88rem;color:var(--mid);transition:background .15s;}
.term-row:hover{background:var(--bg);}
.term-row svg{width:14px;height:14px;flex-shrink:0;margin-top:2px;}
.term-row.allow svg{fill:var(--green-deep);}
.term-row.deny svg{fill:var(--pink-deep);}
.terms-note{margin-top:1.6rem;padding:.9rem 1.3rem;background:linear-gradient(135deg,var(--pink-pale),var(--green-pale));border-radius:12px;font-family:var(--ff);font-size:.78rem;font-weight:600;color:var(--mid);text-align:center;line-height:1.7;}

/* ═══════════ PAGE 6 — LINKS ═══════════ */
#page-links{background:var(--bg2);align-items:center;justify-content:center;min-height:unset;}
.links-center{display:flex;flex-wrap:wrap;justify-content:center;gap:.7rem;margin-top:1.2rem;}
.link-card{
  display:flex;align-items:center;gap:.5rem;
  background:var(--card);border-radius:14px;padding:.6rem 1.1rem;min-width:0;
  box-shadow:var(--shadow);border:1.5px solid var(--pink-mid);
  font-family:var(--ff);font-size:.8rem;font-weight:800;color:var(--mid);
  transition:transform .2s,box-shadow .2s,color .2s,border-color .2s;
}
.link-card svg{width:15px;height:15px;fill:currentColor;flex-shrink:0;}
.link-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);color:var(--pink-deep);border-color:var(--pink);}
.links-page-inner{text-align:center;padding:2rem clamp(1.5rem,4vw,3rem);flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}

/* ═══════════ SHARED SECTION HEADER ═══════════ */
.sec-header{text-align:center;margin-bottom:clamp(1.5rem,3vw,2.5rem);padding-top:clamp(1.5rem,4vw,3rem);width:100%;}
.eyebrow{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:.6rem;}
.eyebrow-dango{display:flex;gap:2px;}
.eyebrow-dango span{width:6px;height:6px;border-radius:50%;}
.eyebrow-dango span:nth-child(1){background:var(--pink);}
.eyebrow-dango span:nth-child(2){background:#d4ccc4;}
.eyebrow-dango span:nth-child(3){background:var(--green);}
.eyebrow .label{font-family:var(--ff);font-size:.66rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--pink-deep);}
.sec-title{font-family:var(--ff);font-weight:900;font-size:clamp(1.8rem,4vw,2.6rem);color:var(--dark);line-height:1.15;}
.dango-row{display:flex;align-items:center;justify-content:center;gap:0;overflow:hidden;padding:.8rem 0;}
.dango-row-line{flex:1;max-width:160px;height:1.5px;background:linear-gradient(90deg,transparent,var(--pink-mid) 70%);border-radius:1px;}
.dango-row-line.r{transform:scaleX(-1);}
.dango-row-set{display:flex;gap:3px;margin:0 .7rem;}
.dango-row-set span{width:8px;height:8px;border-radius:50%;}
.dango-row-set span:nth-child(1){background:var(--pink);}
.dango-row-set span:nth-child(2){background:var(--white-dango);border:1px solid #e0d8d0;}
.dango-row-set span:nth-child(3){background:var(--green);}

/* ═══════════ FOOTER ═══════════ */


/* Relations list */
.rel-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem;}
.rel-row{display:flex;align-items:center;gap:.75rem;padding:.5rem .6rem;border-radius:10px;transition:background .15s;}
.rel-row:hover{background:var(--bg);}
.rel-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;}
.rel-icon img{width:100%;height:100%;object-fit:cover;display:block;}
.rel-icon.rel-teal{background:#e0f8f4;color:#00897b;}
.rel-icon.rel-pink{background:#fce8f3;color:#d81b60;}
.rel-icon.rel-hotpink{background:#ffe0f0;color:#e91e8c;}
.rel-icon.rel-apple{background:#e8f5e2;color:#c62828;}
.rel-icon.rel-fire{background:#fff0e0;color:#e64a19;}
.rel-icon.rel-skyblue{background:#e3f2fd;color:#0288d1;}
.rel-icon.rel-purple{background:#f3e8ff;color:#7c3aed;}

.rel-quote{border-radius:14px;padding:.75rem 1rem;border-left:3px solid var(--pink-mid);background:rgba(255,255,255,.6);margin-bottom:0;}
.rel-quote.kyomei-q{border-left-color:#e64a19;background:rgba(255,240,230,.5);}
.rel-quote.kenta-q{border-left-color:#0288d1;background:rgba(227,242,253,.5);}
.rel-quote.octo-q{border-left-color:#e91e8c;background:rgba(255,224,245,.5);}
.rel-quote.ringo-q{border-left-color:#c62828;background:rgba(232,245,226,.5);}
.rel-quote.nono-q{border-left-color:#7c3aed;background:rgba(243,232,255,.5);}
.rel-q-speaker{font-family:var(--ff);font-size:.62rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);margin-bottom:.3rem;}
.rel-q-text{font-family:var(--ff-alt);font-size:.83rem;color:var(--mid);line-height:1.65;font-style:italic;}
.rel-name{font-family:var(--ff);font-size:.85rem;font-weight:800;color:var(--dark);}
.rel-note{font-family:var(--ff-alt);font-size:.78rem;color:var(--dim);line-height:1.4;}

/* Gallery */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  max-width:900px;margin:0 auto;
}
.gallery-item{
  border-radius:18px;overflow:hidden;
  border:2px solid var(--pink-mid);
  box-shadow:var(--shadow);
  cursor:zoom-in;position:relative;
  background:var(--card);
  transition:transform .22s,box-shadow .22s;
}
.gallery-item:hover{transform:translateY(-4px) scale(1.01);box-shadow:var(--shadow-lg);}
.gallery-item img{
  width:100%;aspect-ratio:1/1;
  object-fit:cover;object-position:center top;
  display:block;transition:opacity .3s;
}
.gallery-credit{
  padding:.55rem .9rem;
  font-family:var(--ff);font-size:.68rem;font-weight:700;
  letter-spacing:.12em;color:var(--dim);
  border-top:1.5px solid var(--pink-pale);
  background:var(--card);
}
/* Download buttons */
.btn-dl{
  display:inline-flex;align-items:center;
  font-family:var(--ff);font-size:.8rem;font-weight:800;letter-spacing:.06em;
  padding:.6rem 1.5rem;border-radius:100px;border:none;
  transition:transform .2s,box-shadow .2s;text-decoration:none;cursor:pointer;
}
.btn-dl:hover{transform:translateY(-2px);}
.btn-dl.pink{background:linear-gradient(135deg,var(--pink),var(--pink-deep));color:#fff;box-shadow:0 3px 14px rgba(200,88,136,.28);}
.btn-dl.green{background:linear-gradient(135deg,var(--green),var(--green-deep));color:#fff;box-shadow:0 3px 14px rgba(78,138,62,.25);}
.btn-dl.offwhite{background:var(--white-dango);color:var(--mid);border:1.5px solid #ddd4c8;box-shadow:0 2px 8px rgba(0,0,0,.06);cursor:default;}
.btn-dl.offwhite:hover{transform:none;}
footer{background:var(--dark);color:rgba(255,255,255,.45);padding:2.2rem clamp(1.5rem,4vw,3rem);display:flex;flex-direction:column;align-items:center;justify-content:center;flex-wrap:wrap;gap:.6rem;text-align:center;}
.footer-logo{font-family:var(--ff);font-size:.95rem;font-weight:900;color:rgba(255,255,255,.8);display:flex;align-items:center;gap:.5rem;}
.footer-dango{display:flex;gap:2px;}
.footer-dango span{width:7px;height:7px;border-radius:50%;opacity:.65;}
.footer-dango span:nth-child(1){background:var(--pink);}
.footer-dango span:nth-child(2){background:var(--white-dango);}
.footer-dango span:nth-child(3){background:var(--green);}
.footer-copy{font-family:var(--ff);font-size:.7rem;font-weight:500;letter-spacing:.06em;text-align:center;line-height:1.8;}

/* ═══════════ BACK TO TOP ═══════════ */
#back-to-top{
  position:fixed;bottom:2rem;right:2rem;z-index:200;
  background:linear-gradient(135deg,var(--pink),var(--pink-deep));
  color:#fff;border:none;border-radius:50%;
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 14px rgba(200,88,136,.35);
  opacity:0;pointer-events:none;transform:scale(.8);
  transition:opacity .3s,transform .3s;
}
#back-to-top.visible{opacity:1;pointer-events:auto;transform:none;}
#back-to-top svg{width:18px;height:18px;fill:currentColor;}

/* ═══════════ LIGHTBOX ═══════════ */
#lightbox{
  position:fixed;inset:0;z-index:8888;
  background:rgba(30,10,20,.88);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  cursor:zoom-out;
  opacity:0;transition:opacity .3s ease;
}
#lightbox.open{display:flex;}
#lightbox.lb-visible{opacity:1;}
#lightbox.lb-closing{opacity:0;transition:opacity .25s ease;}
#lightbox img{
  max-width:88vw;max-height:84vh;
  object-fit:contain;border-radius:12px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);
  cursor:default;
  transition:opacity .18s ease, transform .22s cubic-bezier(.16,1,.3,1);
}
#lightbox img.lb-img-out{opacity:0;transform:scale(.96);}
#lightbox img.lb-img-in{animation:lbImgIn .25s cubic-bezier(.16,1,.3,1) forwards;}
@keyframes lbImgIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
#lightbox-close{
  position:absolute;top:1.5rem;right:1.5rem;
  background:rgba(255,255,255,.15);border:none;color:#fff;
  border-radius:50%;width:42px;height:42px;
  font-size:1.3rem;font-family:var(--ff);font-weight:700;
  transition:background .2s;cursor:pointer;z-index:2;
}
#lightbox-close:hover{background:rgba(255,255,255,.28);}
#lightbox-credit{
  position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%);
  font-family:var(--ff);font-size:.72rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.55);
  white-space:nowrap;transition:opacity .2s;
}
/* Nav arrows */
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.2);
  border-radius:50%;width:46px;height:46px;
  color:#fff;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;z-index:2;
}
.lb-nav:hover{background:rgba(255,255,255,.25);transform:translateY(-50%) scale(1.08);}
.lb-nav.lb-prev{left:1.2rem;}
.lb-nav.lb-next{right:1.2rem;}
.lb-nav svg{width:18px;height:18px;fill:currentColor;}
.lb-counter{
  position:absolute;top:1.5rem;left:50%;transform:translateX(-50%);
  font-family:var(--ff);font-size:.68rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);
}

/* ═══════════ FADE IN ═══════════ */
.fade-in{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s cubic-bezier(.16,1,.3,1);}
.fade-in.visible{opacity:1;transform:none;}

/* ═══════════ MANGA OVERHAUL ═══════════ */

/* Halftone helpers */
.halftone-pink{background-image:radial-gradient(circle,rgba(245,160,192,.28) 1.5px,transparent 1.5px);background-size:14px 14px;}
.halftone-green{background-image:radial-gradient(circle,rgba(143,200,122,.22) 1.5px,transparent 1.5px);background-size:14px 14px;}

/* ── SECTION TITLES ── */
.sec-title{
  font-family:var(--ff);font-weight:900;font-size:clamp(1.8rem,4vw,2.8rem);
  color:var(--dark);line-height:1.2;letter-spacing:-.01em;
}
.eyebrow .label{
  font-weight:900;letter-spacing:.22em;
  background:var(--pink-deep);color:#fff;
  padding:.15rem .7rem;border-radius:4px;
  box-shadow:2px 2px 0 #a04468;
  font-size:.68rem;
}

/* ── CARDS ── */
.profile-card{
  border:2px solid #e8a8c0 !important;
  box-shadow:3px 3px 0 #d4789a !important;
  border-radius:20px !important;
}
.journal-card{
  border:2px solid #e8a8c0 !important;
  box-shadow:3px 3px 0 #d4789a !important;
  border-radius:20px !important;
}
.terms-card{
  border:2px solid #e8a8c0 !important;
  box-shadow:3px 3px 0 #d4789a !important;
}

/* ── VB BANNERS — color per variant ── */
.vb-banner{
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease !important;
}
.vb-banner.cv{
  border:2px solid #f0b8d0 !important;
  box-shadow:3px 3px 0 #d4789a !important;
}
.vb-banner.cv:hover{
  transform:translate(-2px,-2px) !important;
  box-shadow:4px 4px 0 #c85888 !important;
}
.vb-banner.natural{
  border:2px solid #d4b888 !important;
  box-shadow:3px 3px 0 #b89870 !important;
}
.vb-banner.natural:hover{
  transform:translate(-2px,-2px) !important;
  box-shadow:4px 4px 0 #a08050 !important;
}
.vb-banner.takoyaki{
  border:2px solid #a8d898 !important;
  box-shadow:3px 3px 0 #6aaa56 !important;
}
.vb-banner.takoyaki:hover{
  transform:translate(-2px,-2px) !important;
  box-shadow:4px 4px 0 #4e8a3e !important;
}

/* ── GALLERY ── */
.gallery-item{
  border:2px solid #e8a8c0 !important;
  box-shadow:3px 3px 0 #d4789a !important;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .15s ease !important;
}
.gallery-item:hover{
  transform:translate(-3px,-3px) rotate(-1.5deg) !important;
  box-shadow:5px 5px 0 #c85888 !important;
}

/* ── BUTTONS ── */
.btn{
  border-radius:14px !important;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .12s ease !important;
  letter-spacing:.08em;
}
.btn.pink{
  border:2px solid #c05888 !important;
  box-shadow:3px 3px 0 #a04468 !important;
}
.btn.pink:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #a04468 !important;}
.btn.green{
  border:2px solid #5a9650 !important;
  box-shadow:3px 3px 0 #3a7a30 !important;
}
.btn.green:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #3a7a30 !important;}

.btn-dl{
  border-radius:14px !important;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .12s ease !important;
}
.btn-dl.pink{
  border:2px solid #c05888 !important;
  box-shadow:3px 3px 0 #a04468 !important;
}
.btn-dl.pink:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #a04468 !important;}
.btn-dl.green{
  border:2px solid #5a9650 !important;
  box-shadow:3px 3px 0 #3a7a30 !important;
}
.btn-dl.green:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #3a7a30 !important;}
.btn-dl.offwhite{
  border:2px solid #c8a878 !important;
  box-shadow:3px 3px 0 #a08858 !important;
}
.btn-dl.offwhite:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #a08858 !important;}

/* ── SPLASH ENTER ── */
.splash-enter{
  border:2px solid #c05888 !important;
  box-shadow:3px 3px 0 #a04468 !important;
  border-radius:14px !important;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .12s !important;
}
.splash-enter:hover{
  transform:translate(-2px,-2px) !important;
  box-shadow:4px 4px 0 #a04468 !important;
}

/* ── STATUS BADGES ── */
.vb-status{
  border-radius:6px !important;
  font-weight:900 !important;
}
.vb-status.out{
  border:1.5px solid #5a9650 !important;
  box-shadow:2px 2px 0 #5a9650 !important;
}
.vb-status.coming{
  border:1.5px solid #c8b898 !important;
  box-shadow:2px 2px 0 #b8a880 !important;
}
.vb-status.cv-avail{
  background:var(--pink-pale) !important;
  border:1.5px solid #d4789a !important;
  color:var(--pink-deep) !important;
  box-shadow:2px 2px 0 #c85888 !important;
}

/* ── CHIPS ── */
.chip{
  border-radius:8px !important;
  transition:transform .12s cubic-bezier(.34,1.56,.64,1),box-shadow .1s !important;
}
.chip.like{
  border:1.5px solid #d4789a !important;
  box-shadow:2px 2px 0 #c85888 !important;
}
.chip.like:hover{
  transform:translate(-1px,-1px) scale(1.04) rotate(-1.5deg) !important;
  box-shadow:3px 3px 0 #c85888 !important;
}
.chip.dislike{
  border:1.5px solid #6aaa56 !important;
  box-shadow:2px 2px 0 #4e8a3e !important;
}
.chip.dislike:hover{
  transform:translate(-1px,-1px) scale(1.04) rotate(-1.5deg) !important;
  box-shadow:3px 3px 0 #4e8a3e !important;
}
.chip.rel{
  border:1.5px solid #d4b878 !important;
  box-shadow:2px 2px 0 #b89850 !important;
}

/* ── HERO TAG ── */
.hero-tag{
  border:1.5px solid #e8a8c0 !important;
  box-shadow:2px 2px 0 #d4789a !important;
  border-radius:8px !important;
}

/* ── HERO PILLS ── */
.hero-pill{
  border-radius:8px !important;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .12s !important;
}
.hero-pill.pink{
  border:1.5px solid #d4789a !important;
  box-shadow:2px 2px 0 #c85888 !important;
}
.hero-pill.pink:hover{transform:translate(-2px,-2px) !important;box-shadow:3px 3px 0 #c85888 !important;}
.hero-pill.green{
  border:1.5px solid #6aaa56 !important;
  box-shadow:2px 2px 0 #4e8a3e !important;
}
.hero-pill.green:hover{transform:translate(-2px,-2px) !important;box-shadow:3px 3px 0 #4e8a3e !important;}
.hero-pill{
  border:1.5px solid #e8a8c0 !important;
  box-shadow:2px 2px 0 #d4789a !important;
}
.hero-pill:hover{transform:translate(-2px,-2px) !important;box-shadow:3px 3px 0 #c85888 !important;}

/* ── NAV ── */
.nav-pill,.nav-links-pill{
  border:1.5px solid #e8a8c0 !important;
  box-shadow:2px 2px 0 #d4789a !important;
  border-radius:10px !important;
}

/* ── HALFTONE SECTION BACKGROUNDS ── */
#page-hero::before{
  background-image:radial-gradient(circle,rgba(245,160,192,.22) 1.5px,transparent 1.5px) !important;
  background-size:18px 18px !important;
}
#page-character{position:relative;}
#page-character::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(245,160,192,.14) 1.5px,transparent 1.5px);
  background-size:18px 18px;
}
#page-voicebanks::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(143,200,122,.14) 1.5px,transparent 1.5px);
  background-size:20px 20px;
}
#page-terms::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(200,88,136,.1) 1.5px,transparent 1.5px);
  background-size:16px 16px;
}
#page-gallery::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(245,160,192,.18) 2px,transparent 2px);
  background-size:22px 22px;
}

/* ── QUOTE BLOCKS ── */
.quote-block{
  border:1.5px solid #e8a8c0 !important;
  border-left:2px solid #d4789a !important;
  box-shadow:2px 2px 0 #d4789a !important;
  border-radius:18px !important;
  position:relative;
}
.quote-block::before{
  content:'';position:absolute;bottom:-14px;left:28px;
  border:7px solid transparent;
  border-top:8px solid #d4789a;
  border-bottom:none;
}
.quote-block::after{
  content:'';position:absolute;bottom:-11px;left:29px;
  border:6px solid transparent;
  border-top:7px solid var(--pink-pale);
  border-bottom:none;
}

/* ── REL QUOTES — per character color ── */
.rel-quote{
  border-radius:16px !important;
  position:relative;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1) !important;
}
.rel-quote:hover{transform:translate(-2px,-2px) !important;}
.rel-quote.octo-q{
  border:1.5px solid #f090c8 !important;
  box-shadow:2px 2px 0 #c0156e !important;
}
.rel-quote.ringo-q{
  border:1.5px solid #d07070 !important;
  box-shadow:2px 2px 0 #b71c1c !important;
}
.rel-quote.kyomei-q{
  border:1.5px solid #f09060 !important;
  box-shadow:2px 2px 0 #bf360c !important;
}
.rel-quote.kenta-q{
  border:1.5px solid #80b8e8 !important;
  box-shadow:2px 2px 0 #0277bd !important;
}
.rel-quote.nono-q{
  border:1.5px solid #b898f0 !important;
  box-shadow:2px 2px 0 #7c3aed !important;
}
.rel-q-speaker{font-size:.65rem !important;}

/* ── PROFILE BADGE ── */
.profile-badge{
  border:1.5px solid rgba(255,255,255,.6) !important;
  box-shadow:2px 2px 0 #a04468 !important;
  border-radius:6px !important;
}

/* ── JOURNAL TABS ── */
.journal-tab.active{
  background:var(--pink) !important;
  color:var(--dark) !important;
  font-weight:900 !important;
  box-shadow:inset 0 -3px 0 #c85888;
}
.journal-tab{
  border-right:1.5px solid #f0c8d8 !important;
  font-weight:800 !important;
}
.journal-tabs{border-bottom:2px solid #e8a8c0 !important;}

/* ── VB CLOSE ── */
.vb-close{
  border:1.5px solid #e8a8c0 !important;
  box-shadow:2px 2px 0 #d4789a !important;
  border-radius:8px !important;
}

/* ── REL ROWS ── */
.rel-row{
  border-radius:12px !important;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1),background .1s !important;
}
.rel-row:hover{
  transform:translateX(4px) !important;
  background:var(--pink-pale) !important;
}

/* ── REL ICONS — color matched ── */
.rel-icon{width:36px !important;height:36px !important;}
.rel-icon.rel-teal{border:1.5px solid #4db6ac !important;box-shadow:2px 2px 0 #00796b !important;}
.rel-icon.rel-pink{border:1.5px solid #f06292 !important;box-shadow:2px 2px 0 #c2185b !important;}
.rel-icon.rel-hotpink{border:1.5px solid #f48fb1 !important;box-shadow:2px 2px 0 #c0156e !important;}
.rel-icon.rel-apple{border:1.5px solid #e57373 !important;box-shadow:2px 2px 0 #b71c1c !important;}
.rel-icon.rel-fire{border:1.5px solid #ff8a65 !important;box-shadow:2px 2px 0 #bf360c !important;}
.rel-icon.rel-skyblue{border:1.5px solid #64b5f6 !important;box-shadow:2px 2px 0 #0277bd !important;}
.rel-icon.rel-purple{border:1.5px solid #b39ddb !important;box-shadow:2px 2px 0 #7c3aed !important;}

/* ── DANGO ROW DIVIDER ── */
.dango-row-line{
  height:2px !important;
  background:var(--pink-mid) !important;
  opacity:.6 !important;
}

/* ── GALLERY CREDIT ── */
.gallery-credit{
  border-top:1.5px solid #e8a8c0 !important;
  font-weight:800 !important;
}

/* ── BUBBLY SCROLL FADE IN ── */
@keyframes popIn{
  0%{opacity:0;transform:scale(.8) translateY(16px);}
  60%{opacity:1;transform:scale(1.04) translateY(-3px);}
  80%{transform:scale(.98) translateY(1px);}
  100%{opacity:1;transform:scale(1) translateY(0);}
}
@keyframes wobble{
  0%,100%{transform:rotate(0deg);}
  15%{transform:rotate(-2deg);}
  30%{transform:rotate(2deg);}
  45%{transform:rotate(-1.5deg);}
  60%{transform:rotate(1deg);}
}
.fade-in.visible{animation:popIn .5s cubic-bezier(.34,1.56,.64,1) both !important;}

/* ── SPARKLE STARS ── */
.sec-header{position:relative;}
.sec-header::before,.sec-header::after{
  content:'✦';
  position:absolute;top:50%;
  font-size:1.2rem;color:var(--pink);
  animation:sparkSpin 3s linear infinite;
  opacity:.7;
}
.sec-header::before{left:clamp(.5rem,3vw,3rem);transform:translateY(-50%);}
.sec-header::after{right:clamp(.5rem,3vw,3rem);transform:translateY(-50%) rotate(45deg);animation-direction:reverse;}
@keyframes sparkSpin{0%{transform:translateY(-50%) rotate(0deg) scale(1);}50%{transform:translateY(-50%) rotate(180deg) scale(1.3);}100%{transform:translateY(-50%) rotate(360deg) scale(1);}}


/* ── HERO ART ── */
.hero-slide{filter:drop-shadow(-28px 0 0 rgba(245,160,192,.22)) !important;}

/* ── SPLASH TITLE ── */
.splash-title p{
  font-weight:900 !important;
  color:var(--pink-deep) !important;
  font-size:1rem !important;
}
.splash-enter{font-size:1rem !important;letter-spacing:.22em !important;}

/* ── VB CONTENT TITLES ── */
.vb-name-big{color:var(--dark) !important;}
.vb-panel.cv .vb-flavor-big{color:var(--pink-deep);}
.vb-panel.natural .vb-flavor-big{color:#7a6040;}
.vb-panel.takoyaki .vb-flavor-big{color:var(--green-deep);}


/* ── THEMED AUDIO PLAYERS ── */
.vb-demo{margin-top:1.2rem;margin-bottom:.8rem;width:100%;}
.vb-demo-label{font-family:var(--ff);font-size:.6rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:.5rem;}
.vb-player{
  display:flex;align-items:center;gap:.75rem;
  border-radius:14px;padding:.7rem 1rem;
  backdrop-filter:blur(10px);
}
.vb-player.pink{background:rgba(253,232,242,.9);border:1.5px solid #d4789a;box-shadow:2px 2px 0 #c85888;}
.vb-player.cream{background:rgba(253,248,232,.9);border:1.5px solid #d4b888;box-shadow:2px 2px 0 #b89870;}
.vb-player.green{background:rgba(232,245,226,.9);border:1.5px solid #6aaa56;box-shadow:2px 2px 0 #4e8a3e;}
.vb-play-btn{
  width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .15s cubic-bezier(.34,1.56,.64,1);
}
.vb-play-btn:hover{transform:scale(1.12);}
.vb-player.pink .vb-play-btn{background:linear-gradient(135deg,var(--pink),var(--pink-deep));box-shadow:2px 2px 0 #a04468;}
.vb-player.cream .vb-play-btn{background:linear-gradient(135deg,#e8c888,#b89050);box-shadow:2px 2px 0 #a07830;}
.vb-player.green .vb-play-btn{background:linear-gradient(135deg,var(--green),var(--green-deep));box-shadow:2px 2px 0 #3a7a30;}
.vb-play-btn svg{width:14px;height:14px;fill:#fff;margin-left:2px;}
.vb-play-btn.playing svg{margin-left:0;}
.vb-progress-wrap{flex:1;display:flex;flex-direction:column;gap:.3rem;}
.vb-progress{width:100%;height:5px;border-radius:3px;cursor:pointer;appearance:none;background:rgba(0,0,0,.08);}
.vb-player.pink .vb-progress{accent-color:var(--pink-deep);}
.vb-player.cream .vb-progress{accent-color:#b89050;}
.vb-player.green .vb-progress{accent-color:var(--green-deep);}
.vb-progress::-webkit-slider-thumb{appearance:none;width:13px;height:13px;border-radius:50%;cursor:pointer;border:2px solid #fff;}
.vb-player.pink .vb-progress::-webkit-slider-thumb{background:var(--pink-deep);}
.vb-player.cream .vb-progress::-webkit-slider-thumb{background:#b89050;}
.vb-player.green .vb-progress::-webkit-slider-thumb{background:var(--green-deep);}
.vb-time{font-family:var(--ff);font-size:.62rem;font-weight:700;color:var(--dim);letter-spacing:.06em;white-space:nowrap;}

/* ── SECRET DANGO BUTTON ── */
.secret-dango-btn{
  display:flex;align-items:center;justify-content:center;gap:3px;
  margin:1.4rem auto 0;
  background:none;border:none;cursor:pointer;
  opacity:.28;transition:opacity .4s ease;
  padding:.3rem .6rem;border-radius:100px;
}
.secret-dango-btn:hover{opacity:.7;}
.secret-dango-btn span{
  width:9px;height:9px;border-radius:50%;display:block;
  border:1px solid rgba(42,21,32,.15);
}
.secret-dango-btn span:nth-child(1){background:var(--pink);}
.secret-dango-btn span:nth-child(2){background:var(--white-dango);}
.secret-dango-btn span:nth-child(3){background:var(--green);}

/* ── SECRET PANEL ── */
#panel-secret{
  background:linear-gradient(155deg,#f0f4f8 0%,#e8eef6 50%,#f2f6fa 100%);
}
.secret-panel-inner{position:relative;min-height:100vh;overflow:hidden;display:flex;align-items:stretch;}
/* secret panel pattern handled by .secret-panel-inner::before */

/* art side */
.secret-art{
  position:absolute;bottom:0;right:8%;
  height:min(95vh,920px);width:auto;object-fit:contain;
  opacity:1;z-index:1;
  transition:transform .4s cubic-bezier(.34,1.56,.64,1);
}
.secret-art:hover{transform:translateY(-12px);}

/* content */
.secret-content{
  position:relative;z-index:3;
  padding:clamp(4rem,8vw,6rem) clamp(1.5rem,3vw,3rem) clamp(2rem,5vw,5rem);
  max-width:520px;
  display:flex;flex-direction:column;justify-content:center;min-height:100vh;
  margin-right:auto;margin-left:clamp(2rem,6vw,8rem);
}

/* eyebrow */
.secret-eyebrow{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;}
.secret-eyebrow-dots{display:flex;gap:2px;}
.secret-eyebrow-dots span{width:6px;height:6px;border-radius:50%;}
.secret-eyebrow-dots span:nth-child(1){background:#7888d0;}
.secret-eyebrow-dots span:nth-child(2){background:#b8c0e0;}
.secret-eyebrow-dots span:nth-child(3){background:#9890c8;}
.secret-eyebrow .label{font-family:var(--ff);font-size:.66rem;font-weight:800;letter-spacing:.28em;text-transform:uppercase;color:#5060a0;}

.secret-name{font-family:var(--ff);font-weight:900;font-size:clamp(2rem,4.5vw,3.4rem);color:#3040a0;line-height:1.1;margin-bottom:.2rem;}
.secret-flavor{font-family:var(--ff);font-weight:800;font-size:clamp(1.4rem,3vw,2.2rem);color:#6878c0;margin-bottom:.8rem;}
.secret-desc{font-family:var(--ff-alt);font-size:1rem;color:#5060a0;line-height:1.8;margin-bottom:1.5rem;max-width:460px;}

/* warning box */
.secret-warning{
  background:rgba(255,248,220,.9);
  border:1.5px solid #e0b840;
  border-left:3px solid #c89820;
  box-shadow:2px 2px 0 #c89820;
  border-radius:12px;padding:.8rem 1.1rem;
  margin-bottom:1.5rem;
  font-family:var(--ff);font-size:.82rem;color:#806010;line-height:1.6;
}
.secret-warning strong{color:#604000;display:block;margin-bottom:.2rem;letter-spacing:.06em;}

/* info grid */
.secret-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1.8rem;}
.secret-info-cell{background:rgba(255,255,255,.7);backdrop-filter:blur(6px);border-radius:14px;padding:.9rem 1.1rem;border:1.5px solid #a8b8d8;box-shadow:2px 2px 0 #8898b8;}
.secret-info-label{font-family:var(--ff);font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#8898c0;margin-bottom:.25rem;}
.secret-info-value{font-family:var(--ff);font-size:.88rem;font-weight:700;color:#3040a0;}

/* action */
.secret-action-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;}
.btn-dl.blue{
  background:linear-gradient(135deg,#7888d8,#4050b8);color:#fff;
  border:2px solid #3040a0;box-shadow:3px 3px 0 #2030a0;
}
.btn-dl.blue:hover{transform:translate(-2px,-2px) !important;box-shadow:4px 4px 0 #2030a0 !important;}

/* demo player blue */
.vb-player.blue{background:rgba(224,232,248,.9);border:1.5px solid #8898c8;box-shadow:2px 2px 0 #6070b8;}
.vb-player.blue .vb-play-btn{background:linear-gradient(135deg,#7888d8,#4050b8);box-shadow:2px 2px 0 #2030a0;}
.vb-player.blue .vb-progress{accent-color:#4050b8;}
.vb-player.blue .vb-progress::-webkit-slider-thumb{background:#4050b8;}

.secret-art-hint{font-family:var(--ff);font-size:.68rem;font-weight:700;letter-spacing:.12em;color:#8898c0;display:flex;align-items:center;gap:.4rem;margin-top:1.2rem;opacity:.6;}

/* ── REF SHEET BUTTON ── */
.ref-sheet-btn{
  display:flex;align-items:center;gap:.8rem;
  margin:1.8rem auto 0;
  background:linear-gradient(135deg,var(--pink-pale),#f0faf0);
  border:2px solid #e0a8c0;
  box-shadow:3px 3px 0 #d4789a;
  border-radius:16px;padding:1rem 1.8rem;cursor:pointer;
  font-family:var(--ff);transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .12s;
  width:fit-content;text-align:left;
}
.ref-sheet-btn:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 #c85888;}
.ref-sheet-btn-dots{display:flex;gap:3px;flex-shrink:0;}
.ref-sheet-btn-dots span{width:9px;height:9px;border-radius:50%;}
.ref-sheet-btn-dots span:nth-child(1){background:var(--pink);}
.ref-sheet-btn-dots span:nth-child(2){background:var(--white-dango);border:1px solid #e0d8d0;}
.ref-sheet-btn-dots span:nth-child(3){background:var(--green);}
.ref-sheet-btn-text{display:flex;flex-direction:column;gap:.1rem;}
.ref-sheet-btn-label{font-size:.6rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);}
.ref-sheet-btn-title{font-size:.95rem;font-weight:900;color:var(--pink-deep);}
.ref-sheet-btn-arrow{margin-left:.4rem;color:var(--pink-deep);font-size:1.1rem;}

/* ══════ DANGO WIDGET ══════ */
#dango-widget {
  position: fixed;
  bottom: 1.5rem;
  left: 1.5rem;
  z-index: 500;
  width: 230px;
  background: var(--white-dango, #faf6f0);
  border: 2.5px solid #e8a8c0;
  box-shadow: 5px 5px 0 #d4789a;
  border-radius: 18px;
  overflow: hidden;
  font-family: var(--ff, 'Zen Maru Gothic', sans-serif);
  animation: dangoWidgetIn .7s cubic-bezier(.16,1,.3,1) .8s both;
}
@keyframes dangoWidgetIn {
  from { opacity: 0; transform: translateY(120%) scale(.9); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ── Titlebar ── */
#dango-titlebar {
  background: linear-gradient(90deg, #f5a0c0 0%, #e87aaa 50%, #c85888 100%);
  padding: .5rem .9rem;
  display: flex;
  align-items: center;
  gap: .55rem;
}
/* CSS dango skewer in titlebar */
.dango-skewer {
  display: flex;
  align-items: center;
  gap: 0;
  position: relative;
  flex-shrink: 0;
}
.dango-skewer::before {
  content: '';
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 34px; height: 3px;
  background: #c09050;
  border-radius: 2px;
  box-shadow: 1px 1px 0 rgba(0,0,0,.2);
  z-index: 0;
}
.dango-skewer span {
  width: 13px; height: 13px;
  border-radius: 50%;
  display: block;
  position: relative; z-index: 1;
  box-shadow: 0 2px 3px rgba(0,0,0,.18), inset 0 -2px 4px rgba(0,0,0,.1);
}
.dango-skewer span:nth-child(1) { background: #f5a0c0; margin-right: -1px; }
.dango-skewer span:nth-child(2) { background: #faf6f0; margin-right: -1px; }
.dango-skewer span:nth-child(3) { background: #8fc87a; }

#dango-tb-title {
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 1px 3px rgba(0,0,0,.2);
  line-height: 1.2;
}

/* ── Body ── */
#dango-body {
  padding: .9rem 1rem 1.1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .7rem;
  background: repeating-linear-gradient(
    45deg,
    transparent,
    transparent 8px,
    rgba(245,160,192,.04) 8px,
    rgba(245,160,192,.04) 9px
  );
}

/* ── Counter with dango stack decoration ── */
#dango-count-wrap {
  background: #fff8fc;
  border: 2px solid #e8a8c0;
  box-shadow: 3px 3px 0 #d4789a;
  border-radius: 14px;
  padding: .6rem .9rem .5rem;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  position: relative;
}
#dango-count-label {
  font-size: .5rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #c07090;
  margin-bottom: .15rem;
}
#dango-count-num {
  font-size: 2rem;
  font-weight: 900;
  color: #c85888;
  line-height: 1;
}
#dango-count-unit {
  font-size: .58rem;
  font-weight: 700;
  color: #b09090;
  margin-top: .15rem;
  letter-spacing: .1em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .35rem;
}
/* Tiny inline dango in unit row */
.dango-mini {
  display: inline-flex;
  align-items: center;
  position: relative;
  vertical-align: middle;
}
.dango-mini::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 100%; height: 2px;
  background: #c09050;
  border-radius: 1px;
  z-index: 0;
}
.dango-mini span {
  width: 8px; height: 8px;
  border-radius: 50%;
  position: relative; z-index: 1;
  box-shadow: 0 1px 2px rgba(0,0,0,.15);
}
.dango-mini span:nth-child(1) { background: #f5a0c0; }
.dango-mini span:nth-child(2) { background: #faf6f0; border: 1px solid #e8d0d8; }
.dango-mini span:nth-child(3) { background: #8fc87a; }

/* ── Give button ── */
#dango-give-btn {
  width: 100%;
  background: linear-gradient(135deg, #f5a0c0 0%, #e07aaa 50%, #c85888 100%);
  color: #fff;
  border: 2.5px solid #b04070;
  box-shadow: 4px 4px 0 #903050;
  border-radius: 12px;
  padding: .65rem .5rem;
  font-family: var(--ff, 'Zen Maru Gothic', sans-serif);
  font-size: .88rem;
  font-weight: 900;
  cursor: pointer;
  letter-spacing: .03em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  transition: transform .12s cubic-bezier(.34,1.56,.64,1), box-shadow .1s;
}
#dango-give-btn:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 #903050; }
#dango-give-btn:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 #903050; }
/* Dango on a stick inside the button */
.btn-dango {
  display: inline-flex;
  align-items: center;
  gap: 0;
  position: relative;
  flex-shrink: 0;
}
.btn-dango::before {
  content: '';
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 30px; height: 2.5px;
  background: rgba(255,255,255,.7);
  border-radius: 2px;
}
.btn-dango span {
  width: 11px; height: 11px;
  border-radius: 50%;
  display: block;
  position: relative; z-index: 1;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.btn-dango span:nth-child(1) { background: #ffcce0; margin-right: -1px; }
.btn-dango span:nth-child(2) { background: #fff8fc; margin-right: -1px; }
.btn-dango span:nth-child(3) { background: #b8e8a0; }

/* ── Progress ── */
#dango-next-wrap {
  font-size: .58rem;
  font-weight: 700;
  color: #b09090;
  text-align: center;
  letter-spacing: .06em;
  width: 100%;
}
#dango-progress-bar {
  width: 100%;
  height: 6px;
  background: rgba(200,88,136,.12);
  border-radius: 4px;
  overflow: hidden;
  margin-top: .3rem;
  border: 1px solid rgba(200,88,136,.15);
}
#dango-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #f5a0c0, #8fc87a);
  border-radius: 4px;
  width: 0%;
  transition: width .4s cubic-bezier(.16,1,.3,1);
}

/* ══════ MILESTONE POPUP ══════ */
#dango-milestone {
  position: fixed;
  inset: 0;
  z-index: 9100;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(30,10,20,.65);
  backdrop-filter: blur(4px);
  cursor: pointer;
}
#dango-milestone.open {
  display: flex;
  animation: msIn .35s cubic-bezier(.16,1,.3,1);
}
@keyframes msIn { from { opacity:0; transform:scale(.88); } to { opacity:1; transform:scale(1); } }
#dango-milestone-card {
  background: #faf6f0;
  border: 2.5px solid #e8a8c0;
  box-shadow: 6px 6px 0 #d4789a;
  border-radius: 22px;
  padding: 2rem 2rem 1.6rem;
  max-width: 360px;
  width: 90%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .75rem;
  text-align: center;
  cursor: default;
}
/* Dango skewer decoration above card */
.milestone-skewer {
}
.milestone-skewer::before {
  width: 80px;
  height: 5px;
}
.milestone-skewer span {
  width: 22px;
  height: 22px;
}
#dango-milestone-bust {
  width: 150px;
  height: 150px;
  object-fit: cover;
  object-position: center 5%;
  border-radius: 50%;
  border: 3px solid #e8a8c0;
  box-shadow: 3px 3px 0 #d4789a;
}
#dango-milestone-badge {
  font-size: .6rem;
  font-weight: 800;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #c85888;
  background: #fff0f6;
  border: 1.5px solid #e8a8c0;
  border-radius: 100px;
  padding: .25rem .9rem;
}
#dango-milestone-speaker {
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #a08090;
}
#dango-milestone-msg {
  font-size: .92rem;
  font-weight: 700;
  color: #7a6070;
  line-height: 1.75;
  max-width: 260px;
}
#dango-milestone-close {
  margin-top: .2rem;
  background: linear-gradient(135deg, #f5a0c0, #c85888);
  color: #fff;
  border: 2px solid #b04070;
  box-shadow: 3px 3px 0 #903050;
  border-radius: 10px;
  padding: .5rem 1.6rem;
  font-family: var(--ff, 'Zen Maru Gothic', sans-serif);
  font-size: .82rem;
  font-weight: 900;
  cursor: pointer;
  transition: transform .12s cubic-bezier(.34,1.56,.64,1);
}
#dango-milestone-close:hover { transform: translate(-1px,-1px); }

#hero-petals{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;}
