:root{
  --black:#111;
  --white:#fff;
  --cream:#f4f4f5;
  --line:#e5e5e7;
  --accent1:#f3a6b8;
  --accent2:#c8e0a3;
  --accent3:#7fc4b3;
  --accent4:#5b8bd0;
  --accent5:#e8744a;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Noto Sans JP","Inter",sans-serif;
  font-weight:300;
  color:#222;
  background:var(--white);
  line-height:1.85;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
}
.serif{font-family:"Noto Sans JP",sans-serif}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;
  display:flex;justify-content:space-between;align-items:center;
  padding:20px 40px;
  z-index:100;
  mix-blend-mode:difference;
  color:#fff;
}
.nav__logo{font-family:"Inter";font-weight:500;font-size:18px;letter-spacing:.05em}
.nav__logo span{font-size:11px;vertical-align:super;margin-left:2px}
.nav__menu{display:flex;gap:28px;font-family:"Inter";font-size:12px;font-weight:400;letter-spacing:.1em}
.nav__menu a{transition:opacity .3s}
.nav__menu a:hover{opacity:.5}
.nav__toggle{
  display:none;
  width:32px;height:32px;background:transparent;border:none;
  cursor:pointer;padding:0;position:relative;
}
.nav__toggle span{
  display:block;width:22px;height:1px;background:#fff;
  margin:6px auto;transition:transform .35s ease,opacity .25s ease;
}
.nav__toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.is-open span:nth-child(2){opacity:0}
.nav__toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav__drawer{
  position:fixed;inset:0;z-index:90;
  background:#111;
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;
  transition:opacity .4s ease,visibility .4s;
}
.nav__drawer.is-open{opacity:1;visibility:visible}
.nav__drawer-menu{display:flex;flex-direction:column;gap:32px;text-align:center}
.nav__drawer-menu a{
  font-family:"Inter";font-size:16px;font-weight:400;
  letter-spacing:.2em;color:#fff;
  transform:translateY(10px);opacity:0;
  transition:transform .5s ease,opacity .5s ease,color .3s;
}
.nav__drawer-menu a:hover{color:#aaa}
.nav__drawer.is-open .nav__drawer-menu a{transform:translateY(0);opacity:1}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(1){transition-delay:.1s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(2){transition-delay:.15s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(3){transition-delay:.2s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(4){transition-delay:.25s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(5){transition-delay:.3s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(6){transition-delay:.35s}
.nav__drawer.is-open .nav__drawer-menu a:nth-child(7){transition-delay:.4s}
@media(max-width:768px){
  .nav{padding:16px 20px}
  .nav__menu{display:none}
  .nav__toggle{display:block}
}
@media(min-width:769px){.nav__drawer{display:none}}

/* HERO ― minimal */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  background:#fff;
}
.hero__confetti{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}
.hero__inner{position:relative;z-index:1;text-align:center;padding:120px 20px 0}
.hero__logo{
  width:min(400px,62vw);height:auto;display:block;margin:0 auto 56px;
  opacity:0;transform:translateY(40px) scale(.92);
  animation:heroLogoIn 4s .5s cubic-bezier(.12,.8,.2,1) forwards;
}
@keyframes heroLogoIn{to{opacity:1;transform:translateY(0) scale(1)}}
.hero__title{opacity:0;animation:heroFadeUp 1.2s .9s ease forwards}
.hero__meta{opacity:0;animation:heroFadeUp 1.2s 1.2s ease forwards}
.hero__scroll{opacity:0;animation:heroFadeUp 1s 1.6s ease forwards,bounce 2.4s 2.6s ease-in-out infinite}
@keyframes heroFadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero__title{
  font-family:"Noto Sans JP",sans-serif;
  font-size:clamp(16px,1.55vw,20px);
  font-weight:400;
  line-height:2.2;
  letter-spacing:.15em;
  color:#1a1a1a;
  margin-bottom:40px;
}
.hero__meta{
  font-family:"Inter";font-weight:300;
  font-size:15px;letter-spacing:.3em;
  color:#999;text-transform:uppercase;
}
.hero__scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  font-family:"Inter";font-size:10px;letter-spacing:.3em;font-weight:400;
  color:#aaa;text-transform:uppercase;
  animation:bounce 2.4s ease-in-out infinite;
}
.ten{
  font-family:"Inter";font-weight:500;
  font-size:140px;line-height:1;
  letter-spacing:-.05em;
  position:relative;z-index:2;
  display:inline-block;
}
.ten span{font-size:32px;vertical-align:super;margin-left:4px;letter-spacing:0}
.ten__circle{
  position:absolute;
  top:-15px;right:-30px;
  width:120px;height:120px;
  border-radius:50%;
  background:
    conic-gradient(
      var(--accent1) 0 12%,
      var(--accent2) 12% 24%,
      var(--accent3) 24% 36%,
      var(--accent4) 36% 48%,
      var(--accent5) 48% 60%,
      #c8e0a3 60% 72%,
      #f3a6b8 72% 84%,
      #94c9e6 84% 100%
    );
  z-index:1;
  animation:spin 30s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* SECTIONS */
.section{padding:160px 40px;max-width:1200px;margin:0 auto;position:relative}
@media(max-width:768px){.section{padding:100px 24px}}
.section__label{
  font-family:"Inter";font-size:10px;font-weight:400;
  letter-spacing:.35em;margin-bottom:28px;color:#999;
  text-transform:uppercase;
  display:inline-block;position:relative;padding-left:40px;
}
.section__label:before{
  content:"";position:absolute;left:0;top:50%;
  width:28px;height:1px;background:#bbb;
}
.section__label.light{color:rgba(255,255,255,.55)}
.section__label.light:before{background:rgba(255,255,255,.35)}
.section__title{
  font-family:"Noto Sans JP",sans-serif;
  font-size:clamp(30px,4.2vw,56px);
  font-weight:400;line-height:1.5;
  margin-bottom:80px;letter-spacing:.04em;
}
.section__title.light{color:#fff}
.section__title .dash{display:inline-block;transform:translateY(-.08em);margin:0 .1em}

/* NEWS */
.news{padding-top:120px;padding-bottom:0}
.news + .section{padding-top:80px}
.news__list{
  list-style:none;margin:0;padding:0;
  border-top:1px solid #eee;
}
.news__list li{
  display:flex;gap:32px;align-items:baseline;
  padding:18px 0;
  border-bottom:1px solid #eee;
  font-family:"Noto Sans JP",sans-serif;
  font-size:14px;color:#333;letter-spacing:.05em;
}
.news__list time{
  font-family:"Inter";font-size:12px;letter-spacing:.15em;
  color:#999;flex-shrink:0;min-width:90px;
}
@media(max-width:768px){
  .news__list li{flex-direction:column;gap:6px}
}

/* ABOUT */
.about__lead{
  font-family:"Noto Sans JP",sans-serif;
  font-size:20px;line-height:2.2;
  margin-bottom:80px;max-width:none;
  color:#333;letter-spacing:.06em;
}
@media(min-width:900px){.about__lead>span{white-space:nowrap}}
.about__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:64px}
@media(max-width:768px){.about__grid{grid-template-columns:1fr;gap:48px}}
.about__item{padding:0;background:transparent;position:relative}
.about__num{font-family:"Inter";font-size:10px;font-weight:400;color:#999;margin-bottom:24px;letter-spacing:.3em}
.about__item h3{font-family:"Noto Sans JP",sans-serif;font-size:22px;font-weight:400;margin-bottom:16px;letter-spacing:.06em}
.about__item p{font-size:15px;color:#666;line-height:2}

/* NUMBERS */
.numbers{
  background:rgba(10,10,10,.65);color:#fff;
  max-width:none;width:100%;padding:80px 40px;
  position:relative;overflow:hidden;isolation:isolate;
}
.numbers__bg{position:absolute;inset:0;z-index:0;opacity:.48;pointer-events:none}
.numbers__track{display:flex;gap:0;height:100%;width:max-content;animation:numMarquee 110s linear infinite}
.numbers__track img{height:100%;width:auto;object-fit:cover;display:block;filter:grayscale(.2)}
@keyframes numMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.numbers > *:not(.numbers__bg){position:relative;z-index:1}
.numbers > .section__label,.numbers > .section__title{max-width:1200px;margin-left:auto;margin-right:auto;display:block;width:100%}
.numbers__grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
}
.numbers__note{
  max-width:1200px;margin:60px auto 0;
  font-family:"Noto Sans JP",sans-serif;
  font-size:11px;color:rgba(255,255,255,.55);
  letter-spacing:.08em;text-align:right;
  position:relative;z-index:1;
}
.numbers__grid .num{
  padding:0 32px;border-left:1px solid rgba(255,255,255,.15);
}
.numbers__grid .num:first-child{border-left:none;padding-left:0}
@media(max-width:768px){.numbers__grid{grid-template-columns:repeat(2,1fr);gap:48px 0}.numbers__grid .num{padding:0 16px}.numbers__grid .num:nth-child(3){border-left:none;padding-left:0}}
.num__big{
  font-family:"Inter";font-weight:300;
  font-size:clamp(34px,4.2vw,58px);
  line-height:1;letter-spacing:-.03em;
  margin-bottom:20px;
}
.num__big{color:#fff}
.num__big > span:last-child{font-size:.32em;margin-left:6px;color:#fff;letter-spacing:.1em;font-weight:300}
.num__cap{font-size:13px;color:#fff;letter-spacing:.22em;text-transform:uppercase}

/* HISTORY */
.timeline{display:flex;flex-direction:column;gap:0}
.tl{display:grid;grid-template-columns:180px 1fr;gap:60px;padding:48px 0;border-top:1px solid #e5e5e7;transition:background .4s}
.tl:hover{background:#fafafa}
.tl:last-child{border-bottom:1px solid #e5e5e7}
.tl__year{font-family:"Inter";font-size:36px;font-weight:300;letter-spacing:-.02em;color:#1a1a1a}
.tl__body h4{font-family:"Noto Sans JP",sans-serif;font-size:22px;font-weight:400;margin-bottom:12px;letter-spacing:.04em}
.tl__body p{color:#777;font-size:15px;line-height:2;max-width:560px}
@media(max-width:768px){.tl{grid-template-columns:1fr;gap:12px;padding:32px 0}.tl__year{font-size:28px}}

/* ARTISTS */
.artists{position:relative;background:var(--cream);overflow:hidden}
.artists__visual{
  width:100%;height:clamp(180px,28vw,360px);
  overflow:hidden;position:relative;
}
.artists__visual img{
  width:100%;height:100%;object-fit:cover;
  display:block;
  animation:slidePan 40s linear infinite alternate;
}
@keyframes slidePan{from{transform:scale(1.02)}to{transform:translateX(-3%) scale(1.05)}}
.artists__inner{max-width:1200px;margin:0 auto;padding:100px 40px 140px;text-align:left}
.artists__title{text-align:center}
.artists__lead{font-size:17px;color:#555;line-height:2;margin-bottom:60px;text-align:center}
.artists__stats{
  display:flex;justify-content:flex-start;gap:60px;flex-wrap:wrap;
  padding-top:40px;border-top:1px solid var(--line);
}
.artists__stats > div{text-align:left}
.artists__stats span{
  font-family:"Inter";font-weight:500;font-size:48px;
  letter-spacing:-.03em;display:block;line-height:1;
}
.artists__stats small{font-size:.4em;margin-left:4px;color:#111}
.artists__stats p{font-size:12px;color:#888;margin-top:8px;letter-spacing:.05em}
@media(max-width:768px){.artists__inner{padding:60px 20px 80px}.artists__stats{gap:32px}.artists__stats span{font-size:36px}}

/* ARCHIVE */
.archive__lead{font-size:17px;color:#555;margin-bottom:40px;max-width:680px;line-height:2}
.section__lead{font-size:17px;color:#555;line-height:2;margin-bottom:40px;max-width:680px}
.archive__hero{margin-bottom:60px;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.12)}
.archive__hero img{width:100%;height:auto;display:block;object-fit:cover}
.archive__tabs{display:flex;gap:6px;margin-bottom:6px;flex-wrap:wrap}
.archive__tabs--cat{margin-bottom:40px}
.tab{
  font-family:"Inter";font-size:11px;font-weight:400;
  padding:8px 14px;border:1px solid var(--black);
  background:#fff;cursor:pointer;border-radius:999px;
  letter-spacing:.08em;transition:all .3s;
}
.tab.is-active,.tab:hover{background:var(--black);color:#fff}
.tab--random{display:inline-flex;align-items:center;gap:6px}
.tab--random svg{transition:transform .5s ease}
.tab--random:hover svg{transform:rotate(180deg)}
.tab--random.is-rolling svg{animation:tabRandomSpin .6s ease}
@keyframes tabRandomSpin{
  0%{transform:rotate(0deg)}
  100%{transform:rotate(360deg)}
}
.tab--cat{
  font-size:10px;padding:6px 12px;
  border-color:#bbb;color:#666;
}
.tab--cat.is-active,.tab--cat:hover{background:#444;border-color:#444;color:#fff}
.archive__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px 24px}
@media(max-width:768px){.archive__grid{grid-template-columns:repeat(2,1fr);gap:32px 16px}}
.card{
  margin:0;background:#fff;cursor:pointer;
  border-radius:4px;overflow:hidden;
  transition:transform .5s ease,box-shadow .5s ease;
  display:flex;flex-direction:column;
}
.card img{
  width:100%;aspect-ratio:1;object-fit:cover;display:block;
  transition:transform .8s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.card:hover img{transform:scale(1.04)}
.card figcaption{
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding:14px 4px 4px;background:transparent;
}
.card__name{
  font-family:"Noto Sans JP",sans-serif;
  font-size:12px;font-weight:400;color:#333;letter-spacing:.06em;
}
.card__code{
  font-family:"Inter",sans-serif;
  font-size:10px;font-weight:400;color:#aaa;letter-spacing:.12em;
  white-space:nowrap;
}

/* ANNIVERSARY */
.anniversary{
  background:#111;color:#fff;
  max-width:none;width:100%;padding:180px 40px;
  position:relative;overflow:hidden;
}
.anniversary__bg{
  position:absolute;inset:0;z-index:0;
}
.anniversary__bg img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  opacity:0;
  animation:anniBgFade 21s infinite;
  transform:scale(1.06);
  will-change:opacity,transform;
}
.anniversary__bg img:nth-child(1){animation-delay:0s}
.anniversary__bg img:nth-child(2){animation-delay:7s}
.anniversary__bg img:nth-child(3){animation-delay:14s}
@keyframes anniBgFade{
  0%{opacity:0;transform:scale(1.06)}
  2%{opacity:1;transform:scale(1.055)}
  33%{opacity:1;transform:scale(1.01)}
  45%{opacity:0;transform:scale(1)}
  100%{opacity:0;transform:scale(1.06)}
}
.anniversary__bg::after{
  content:'';position:absolute;inset:0;
  background:rgba(10,10,10,.72);
  z-index:1;
}
.anniversary__inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;
  position:relative;z-index:2;
}
.anniversary--coming{padding:140px 40px}
.anniversary__inner--coming{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;gap:0;
  min-height:280px;
}
.anniversary__inner--coming .section__label{
  margin-top:-120px;
  margin-bottom:100px;
  align-self:flex-start;
}
.coming-soon__title{
  font-family:"Inter";font-weight:300;
  font-size:clamp(40px,7vw,88px);
  letter-spacing:.2em;color:#fff;
  margin:0 0 28px;line-height:1;
}
.coming-soon__lead{
  font-family:"Noto Sans JP",sans-serif;font-weight:300;
  font-size:17px;letter-spacing:.1em;line-height:2;
  color:#fff;
  margin:0;
}
@media(max-width:768px){.anniversary__inner{grid-template-columns:1fr;gap:60px}}
.anniversary__text p{
  font-family:"Noto Sans JP",sans-serif;
  color:rgba(255,255,255,.65);
  margin-bottom:48px;line-height:2.2;font-size:15px;letter-spacing:.05em;
}
.anniversary__text .section__title{margin-bottom:40px;font-size:clamp(26px,3.6vw,44px)}
.anniversary__name{
  font-family:"Noto Sans JP",sans-serif;
  font-size:18px;color:#fff;
  letter-spacing:.08em;margin-bottom:24px;
}
.anniversary__spec{
  list-style:none;margin:0 0 48px;padding:0;
  border-top:1px solid rgba(255,255,255,.2);
}
.anniversary__spec li{
  display:flex;align-items:center;gap:24px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.2);
  font-family:"Noto Sans JP",sans-serif;
  font-size:13px;color:rgba(255,255,255,.85);letter-spacing:.05em;
}
.anniversary__spec span{
  font-family:"Inter";font-size:10px;font-weight:400;
  letter-spacing:.3em;color:rgba(255,255,255,.45);
  min-width:64px;text-transform:uppercase;
}
.book{
  position:relative;width:100%;max-width:460px;margin:0 auto;
  aspect-ratio:1/1.35;
  perspective:1600px;
  filter:drop-shadow(0 30px 60px rgba(0,0,0,.4));
}
.book__cover{
  position:absolute;inset:0;background:#f4f4f5;
  color:#111;padding:44px 40px;
  display:flex;flex-direction:column;justify-content:space-between;
  transform:rotateY(-6deg);transform-origin:left center;
  border-radius:2px 6px 6px 2px;
  background-image:
    linear-gradient(180deg,rgba(0,0,0,.03) 0%,transparent 30%),
    repeating-linear-gradient(0deg,rgba(0,0,0,.015) 0 2px,transparent 2px 4px);
}
.book__spine{
  position:absolute;left:0;top:0;bottom:0;width:14px;
  background:linear-gradient(90deg,rgba(0,0,0,.25),rgba(0,0,0,.05) 60%,transparent);
  transform:rotateY(-6deg);transform-origin:left center;
  border-radius:2px 0 0 2px;
}
.book__top,.book__bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-family:"Inter",sans-serif;font-size:10px;font-weight:400;
  letter-spacing:.25em;color:#888;text-transform:uppercase;
}
.book__top{border-bottom:1px solid #d8d8dc;padding-bottom:16px}
.book__bottom{border-top:1px solid #d8d8dc;padding-top:16px}
.book__brand{font-weight:500;color:#111;letter-spacing:.2em}
.book__title{text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;gap:20px}
.book__title span{
  font-family:"Inter",sans-serif;font-weight:300;
  font-size:clamp(90px,12vw,150px);line-height:.85;
  letter-spacing:-.04em;color:#111;
}
.book__title span small{font-size:.22em;vertical-align:super;margin-left:4px;letter-spacing:.05em}
.book__title p{
  font-family:"Noto Sans JP",sans-serif;font-size:13px;
  font-weight:400;letter-spacing:.25em;color:#333;line-height:1.8;
}
.anniv-card__circle{
  width:60%;aspect-ratio:1;border-radius:50%;
  background:
    conic-gradient(
      var(--accent1) 0 12%,
      var(--accent2) 12% 24%,
      var(--accent3) 24% 36%,
      var(--accent4) 36% 48%,
      var(--accent5) 48% 60%,
      #c8e0a3 60% 72%,
      #f3a6b8 72% 84%,
      #94c9e6 84% 100%
    );
}
.anniv-card__label{
  position:absolute;top:30px;left:30px;
  font-family:"Inter";font-weight:500;font-size:18px;
  color:var(--black);line-height:1.1;
}

.btn{
  display:inline-block;padding:18px 40px;
  border:1px solid #fff;color:#fff;
  font-family:"Inter";font-weight:300;font-size:11px;
  letter-spacing:.25em;text-transform:uppercase;
  border-radius:0;background:transparent;
  transition:all .4s ease;
}
.btn:hover{background:#fff;color:#111;letter-spacing:.3em}
.btn--dark{background:#111;border-color:#111;color:#fff}
.btn--dark:hover{background:transparent;color:#111;border-color:#111}
.btn--ghost{border-color:#222;color:#222}
.btn--ghost:hover{background:#111;color:#fff;border-color:#111}

/* VOICES */
.voices__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px 40px;margin-top:80px}
@media(max-width:768px){.voices__grid{grid-template-columns:1fr;gap:56px}}
.voices blockquote{
  padding:36px 32px 40px;background:#f6f6f7;
  border-radius:16px;
  position:relative;margin-bottom:32px;
  transition:transform .5s ease,box-shadow .5s ease,background .4s ease,color .4s ease;
}
.voices blockquote:hover{transform:translateY(-4px);box-shadow:0 20px 50px rgba(0,0,0,.06);background:#111;color:#fff}
.voices blockquote:hover cite{color:rgba(255,255,255,.5)}
.voices blockquote:hover p{color:#fff}
.voices blockquote:hover:before,.voices blockquote:hover:after{background:#111}
.voices blockquote:before{
  content:"";position:absolute;
  left:14px;bottom:-10px;
  width:14px;height:14px;border-radius:50%;
  background:#f6f6f7;
}
.voices blockquote:after{
  content:"";position:absolute;
  left:2px;bottom:-22px;
  width:8px;height:8px;border-radius:50%;
  background:#f6f6f7;
}
.voices p{
  font-family:"Noto Sans JP",sans-serif;
  font-size:14px;line-height:2.1;color:#333;letter-spacing:.04em;
}
.voices .section__lead{font-size:17px;color:#555;line-height:2}
.voices cite{
  display:block;margin-left:40px;
  font-family:"Inter";font-size:10px;color:#999;
  font-style:normal;letter-spacing:.25em;text-transform:uppercase;
}

/* CTA ― seamless fade from VOICES */
.voices{position:relative;z-index:1}
.cta{
  position:relative;overflow:hidden;
  text-align:center;
  margin-top:-160px;padding:360px 40px 200px;
  background:transparent;border-top:none;
}
.cta:before{
  content:"";position:absolute;inset:-40% -40% -20%;
  background:
    radial-gradient(ellipse 80% 70% at 80% 25%, rgba(120,180,230,.95), transparent 70%),
    radial-gradient(ellipse 80% 70% at 20% 70%, rgba(100,160,220,.9), transparent 70%),
    radial-gradient(ellipse 70% 60% at 50% 90%, rgba(148,201,230,.85), transparent 70%),
    radial-gradient(ellipse 60% 50% at 15% 30%, rgba(243,166,184,.7), transparent 70%),
    radial-gradient(ellipse 60% 55% at 80% 80%, rgba(200,224,163,.7), transparent 70%),
    radial-gradient(ellipse 50% 40% at 50% 50%, rgba(245,208,74,.4), transparent 70%);
  filter:blur(130px);
  pointer-events:none;
  animation:ctaBlob 10s ease-in-out infinite alternate;
  transform-origin:center center;
}
.cta:after{
  content:"";position:absolute;top:0;left:0;right:0;height:45%;
  background:linear-gradient(180deg,#fff 0%,#fff 20%,transparent 100%);
  pointer-events:none;z-index:1;
}
@keyframes ctaBlob{
  0%{transform:translate(0,0) scale(1) rotate(0deg)}
  20%{transform:translate(8%,-10%) scale(1.15) rotate(5deg)}
  40%{transform:translate(-10%,8%) scale(.88) rotate(-4deg)}
  60%{transform:translate(6%,10%) scale(1.12) rotate(3deg)}
  80%{transform:translate(-8%,-6%) scale(.92) rotate(-5deg)}
  100%{transform:translate(5%,-8%) scale(1.08) rotate(4deg)}
}
.cta > *{position:relative;z-index:1}
.cta h2{
  font-family:"Noto Sans JP",sans-serif;
  font-size:clamp(30px,4.2vw,56px);
  font-weight:400;margin-bottom:64px;
  letter-spacing:.1em;line-height:1.8;color:#fff;
}
.cta__buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.btn--instagram{display:inline-flex;align-items:center;gap:8px}
.btn--instagram svg{flex-shrink:0}
.cta .btn,
.cta .btn--dark,
.cta .btn--ghost{
  background:#fff;
  border:1px solid #fff;
  color:#111;
  backdrop-filter:none;-webkit-backdrop-filter:none;
}
.cta .btn:hover,
.cta .btn--dark:hover,
.cta .btn--ghost:hover{
  background:transparent;
  color:#fff;
  border-color:#fff;
}

/* FOOTER */
.footer{
  background:var(--black);color:#fff;
  padding:60px 40px;text-align:center;
}
.footer__logo{font-family:"Inter";font-weight:500;font-size:16px;letter-spacing:.1em;margin-bottom:12px}
.footer p{font-size:11px;color:rgba(255,255,255,.5);letter-spacing:.05em}
.footer p a{color:inherit;text-decoration:none;transition:color .25s}
.footer p a:hover{color:#fff}

/* LIGHTBOX */
.lightbox{
  position:fixed;inset:0;z-index:1000;
  background:rgba(20,20,22,.78);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:flex;align-items:center;justify-content:center;
  padding:40px;opacity:0;visibility:hidden;
  transition:opacity .4s ease,visibility .4s;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__close{
  position:absolute;top:24px;right:28px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;
  border:none;font-size:24px;line-height:1;cursor:pointer;
  transition:background .3s;
}
.lightbox__close:hover{background:rgba(255,255,255,.25)}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:56px;height:56px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;
  border:none;font-size:32px;line-height:1;cursor:pointer;
  font-family:"Inter",sans-serif;font-weight:300;
  display:flex;align-items:center;justify-content:center;
  transition:background .3s,transform .3s;z-index:2;
}
.lightbox__nav:hover{background:rgba(255,255,255,.25)}
.lightbox__nav--prev{left:32px}
.lightbox__nav--prev:hover{transform:translateY(-50%) translateX(-3px)}
.lightbox__nav--next{right:32px}
.lightbox__nav--next:hover{transform:translateY(-50%) translateX(3px)}
@media(max-width:768px){.lightbox__nav{width:40px;height:40px;font-size:24px}.lightbox__nav--prev{left:8px}.lightbox__nav--next{right:8px}}
.lightbox__inner{
  display:grid;grid-template-columns:1fr 320px;gap:48px;
  max-width:1100px;width:100%;max-height:90vh;
  background:#fff;padding:32px;border-radius:6px;
  transform:scale(.96);transition:transform .5s ease;
}
.lightbox.is-open .lightbox__inner{transform:scale(1)}
.lightbox__imgwrap{
  background:#fff;border-radius:4px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;min-height:400px;
}
.lightbox__imgwrap{position:relative;min-height:280px}
.lightbox__imgwrap img{width:100%;height:auto;max-height:80vh;object-fit:contain;display:block}
.lightbox__placeholder{
  display:none;
  align-items:center;justify-content:center;
  width:100%;min-height:280px;height:100%;
  font-family:"Noto Sans JP",sans-serif;
  font-size:13px;letter-spacing:.2em;
  color:#aaa;
  background:#fafafa;
  border:1px dashed #ddd;
}
.lightbox__switch{
  position:absolute;right:12px;bottom:12px;
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:8px 14px;border-radius:999px;
  box-shadow:0 2px 10px rgba(0,0,0,.06);
  z-index:2;
}
.lightbox__switch-btn{
  font-family:"Noto Sans JP",sans-serif;font-size:11px;
  padding:0;border:none;background:transparent;cursor:pointer;
  letter-spacing:.12em;color:#999;
  transition:color .25s;
}
.lightbox__switch-btn:hover{color:#444}
.lightbox__switch-btn.is-active{color:#111;font-weight:500}
.lightbox__switch-divider{
  font-size:10px;color:#ccc;font-family:"Inter";
}
.lightbox__meta{display:flex;flex-direction:column;justify-content:center;padding:20px 8px}
.lightbox__label{
  font-family:"Inter";font-size:10px;font-weight:400;
  letter-spacing:.3em;color:#999;text-transform:uppercase;margin-bottom:20px;
}
.lightbox__name{
  font-family:"Noto Sans JP",sans-serif;
  font-size:26px;font-weight:500;line-height:1.5;
  letter-spacing:.04em;color:#111;margin-bottom:32px;
}
.lightbox__spec{margin:0;padding-top:24px;border-top:1px solid #eee;display:grid;grid-template-columns:80px 1fr;gap:12px 16px}
.lightbox__spec dt{
  font-family:"Inter",sans-serif;font-size:10px;font-weight:400;
  letter-spacing:.2em;color:#999;text-transform:uppercase;align-self:center;
}
.lightbox__spec dd{margin:0;font-size:13px;color:#333;letter-spacing:.05em;align-self:center}
.lightbox__cat{
  display:inline-block;
  font-family:"Inter";font-size:10px;font-weight:400;
  letter-spacing:.15em;color:#333;
  padding:4px 10px;margin-right:6px;margin-bottom:4px;
  border:1px solid #ddd;border-radius:999px;
  text-transform:uppercase;
}
.lightbox__shop{
  margin-top:24px;
  display:inline-flex;align-items:center;gap:8px;
  padding:0 0 4px;
  color:#666;
  font-family:"Inter";font-size:10px;font-weight:400;
  letter-spacing:.25em;text-transform:uppercase;
  text-decoration:none;
  border-bottom:1px solid #ccc;
  transition:color .25s, border-color .25s, gap .25s;
  align-self:flex-start;
}
.lightbox__shop:hover{color:#111;border-color:#111;gap:12px}
.lightbox__shop svg{flex-shrink:0;width:11px;height:11px}
@media(max-width:768px){
  .lightbox{padding:20px}
  .lightbox__inner{grid-template-columns:1fr;gap:20px;padding:20px;max-height:95vh;overflow-y:auto}
  .lightbox__imgwrap{min-height:260px}
  .lightbox__name{font-size:22px;margin-bottom:20px}
}
.artists__note{
  margin:20px 0 0;
  font-family:"Noto Sans JP",sans-serif;
  font-size:11px;color:#999;letter-spacing:.08em;
  text-align:right;
}
.artists__list{
  list-style:none;margin:24px 0 0;padding:24px 0 0;
  border-top:1px solid #e5e5e5;
  display:flex;flex-wrap:wrap;gap:10px 12px;
  font-family:"Noto Sans JP",sans-serif;font-weight:400;font-size:13px;color:#333;
}
.artists__list li{
  border:1px solid #e0e0e0;border-radius:999px;
  background:#fff;letter-spacing:.04em;line-height:1;
  transition:background .3s,border-color .3s;
}
.artists__list li a{
  display:inline-block;
  padding:8px 16px;
  color:inherit;text-decoration:none;
}
.artists__list li:hover{background:#111;border-color:#111}
.artists__list li:hover a{color:#fff}
.gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:56px}
.gallery__item{overflow:hidden;border-radius:6px;aspect-ratio:1/1;background:#f4f4f5}
.gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.gallery__item:hover img{transform:scale(1.05)}
.lightbox.is-gallery .lightbox__meta{display:none}
.lightbox.is-gallery .lightbox__switch{display:none}
.lightbox.is-gallery .lightbox__inner{grid-template-columns:1fr;max-width:900px;background:transparent;padding:0;box-shadow:none}
.lightbox.is-gallery .lightbox__imgwrap{background:transparent;padding:0}
@media(max-width:768px){.gallery__grid{grid-template-columns:repeat(2,1fr);gap:8px}}

/* Audio toggle */
.audio-toggle{
  position:fixed;bottom:32px;right:32px;z-index:90;
  width:48px;height:48px;border-radius:50%;
  background:#fff;border:1px solid #e0e0e0;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(0,0,0,.08);
  transition:background .3s,border-color .3s,transform .3s;
}
.audio-toggle:hover{transform:scale(1.08);border-color:#999}
.audio-toggle svg{width:20px;height:20px;color:#333}
.audio-toggle__on{display:none}
.audio-toggle__off{display:block}
.audio-toggle.is-playing{background:#111;border-color:#111}
.audio-toggle.is-playing svg{color:#fff}
.audio-toggle.is-playing .audio-toggle__on{display:block}
.audio-toggle.is-playing .audio-toggle__off{display:none}
