html,body{overflow-x:hidden}
/* Minimal, Apple-like aesthetic */
:root{--bg:#000;--fg:#fff;--muted:rgba(255,255,255,.68);--line:rgba(255,255,255,.12);--card:rgba(255,255,255,.05);--card-hover:rgba(255,255,255,.08)}
*{box-sizing:border-box}html,body{margin:0;overflow-x:hidden;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,system-ui,Segoe UI,Arial}
a{color:inherit;text-decoration:none}.container{max-width:1160px;margin:0 auto;padding:0 20px}
.nav{position:sticky;top:0;backdrop-background:rgba(0,0,0,.4);border-bottom:1px solid var(--line);z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;gap:12px;align-items:center}
.logo{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,rgba(255,255,255,.25),rgba(255,255,255,.04));border:1px solid var(--line)}
.brand-title{font-weight:600;font-size:14px;letter-spacing:.08em;text-transform:uppercase}
.brand-subtitle{font-size:12px;color:var(--muted)}
.menu{display:none;gap:20px}.menu a{opacity:.85}.menu a:hover{opacity:1}
@media(min-width:880px){.menu{display:flex}}.lang{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted)}
select{background:transparent;border:1px solid var(--line);color:var(--fg);padding:6px 10px;border-radius:10px}
.ticker-wrap{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--bg)}
.ticker{display:inline-block;white-space:nowrap;animation:scroll 28s linear infinite;font-size:14px;padding:8px 0;color:var(--muted)}
@keyframes scroll{0%{transform:translateX(100%)}100%{transform:translateX(-100%)}}
.hero{position:relative;position:relative;padding:96px 0;background:radial-gradient(60% 60% at 50% 0%,rgba(255,255,255,.08),rgba(0,0,0,0))}
.hero h1{font-size:60px;letter-spacing:-.02em;margin:0}
.hero .subtitle{font-size:18px;color:var(--muted);margin:.4rem 0 0}
.btn{display:inline-block;padding:10px 16px;border-radius:12px;border:1px solid var(--line);transition:.2s all}
.btn-primary{background:#fff;color:#000;border-color:#fff}.btn-outline:hover{background:var(--card)}.cta-row{margin-top:20px;display:flex;gap:10px}
.section{padding:64px 0;border-top:1px solid var(--line)}.section h2{font-size:24px;margin:0 0 16px}
.grid{display:grid;gap:16px}.grid.two{grid-template-columns:1fr}.grid.three{grid-template-columns:1fr}.grid.four{grid-template-columns:1fr 1fr}
@media(min-width:760px){.grid.two{grid-template-columns:1fr 1fr}.grid.three{grid-template-columns:1fr 1fr 1fr}.grid.four{grid-template-columns:1fr 1fr 1fr 1fr}}
.card{border:1px solid var(--line);background:var(--card);border-radius:16px;padding:16px;transition:.2s background}
.card:hover{background:var(--card-hover)}
.bullet{margin:0;padding-left:18px}.bullet li{margin:.4rem 0;color:var(--muted)}
.person{display:flex;flex-direction:column}
.avatar{width:100%;height:auto;object-fit:cover;border-radius:14px;border:1px solid var(--line);margin-bottom:10px;display:block;background:none}
.name-cn{font-weight:600}.name-en{font-size:13px;color:var(--muted)}
.roles{margin:.5rem 0 0;padding-left:16px}.roles li{color:var(--muted);margin:.25rem 0}
.label{font-size:12px;color:var(--muted);margin-top:8px}
.chips span{display:inline-block;border:1px solid var(--line);padding:4px 8px;border-radius:999px;margin-right:20px;margin-top:6px}
.muted{color:var(--muted);font-size:14px}.footer{border-top:1px solid var(--line);padding:18px 0}.space-between{display:flex;align-items:center;justify-content:space-between}
.toplink{opacity:.8}.toplink:hover{opacity:1}

/* Shows section */
.tabs{display:flex;gap:10px;margin-bottom:14px}
.tab{border:1px solid var(--line);background:transparent;color:var(--fg);padding:8px 12px;border-radius:10px;cursor:pointer;opacity:.8}
.tab.active{background:var(--card-hover);opacity:1}
.showcard{border:1px solid var(--line);background:var(--card);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:6px}
.showcard .when{font-weight:600}
.showcard .meta{color:var(--muted);font-size:14px}
.showcard .title{font-size:16px;margin-top:4px}
.btn-ghost{display:inline-block;border:1px solid var(--line);padding:6px 10px;border-radius:10px;margin-top:8px}

/* Hero scrolling gallery */
.hero-gallery{position:relative;margin-top:14px;overflow:hidden;border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));}
.hero-gallery:before,.hero-gallery:after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.hero-gallery:before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.hero-gallery:after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.gallery-track{display:flex;gap:10px;padding:10px;animation:gallery-scroll 30s linear infinite}
.gallery-track:hover{animation-play-state:paused}
.hero-gallery img{height:140px;width:auto;border-radius:12px;object-fit:cover;filter:saturate(105%);opacity:.95}
@media(min-width:860px){.hero-gallery img{height:160px}}
@keyframes gallery-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Full-width hero background photo scroll */
.hero-bg-track {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  overflow: hidden;
  z-index: 0;
  display: flex;
  animation: bg-scroll 7s linear infinite;
  opacity: 0.15;
  
}
.hero-bg-track img{height:100%;width:100vw;object-fit:cover;flex-shrink:0;background:#000;}
@keyframes bg-scroll{0%{transform:translateX(0)}100%{transform:translateX(-600vw)}}100%{transform:translateX(-600vw)}}100%{transform:translateX(-50%)}}
  100% { transform: translateX(-50%); }
}
.hero .container, .hero h1, .hero h2, .hero p, .hero .buttons {
  position: relative;
  z-index: 2;
}

.hero-content {position:relative;z-index:2;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;min-height:80vh;padding-left:4vw;padding-top:4vh;}







  100% { transform: translateX(-50%); }
}

#about {
  position: relative;
  z-index: 1;
  overflow: hidden;
}


.about-blur-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.about-blur-bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url('assets/photo/hero1.jpg?ver=v36');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: brightness(0.35);
}

.hero-bg-track img{box-shadow: inset 0 0 0 1.2vw rgba(0,0,0,.85);} /* visual dark edge without affecting width */

/* --- Photo Marquee (Apple-style) --- */
.photo-marquee{position:relative; z-index:1; padding:16px 0; overflow:hidden;}
.photo-marquee .track{display:flex; gap:16px; align-items:center; animation: marquee 14s linear infinite;}
/* desktop height */
.photo-marquee img{height:220px; width:auto; object-fit:cover; border-radius:14px; flex:0 0 auto;
/* edge darkening using inset shadows on both sides */
box-shadow: inset 80px 0 100px rgba(0,0,0,.55), inset -80px 0 100px rgba(0,0,0,.55);
}
@keyframes marquee{ 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.photo-marquee:hover .track{ animation-play-state: paused; } /* hover to pause */
/* responsive */
@media (max-width: 640px){
  .photo-marquee .track{gap:12px; animation-duration: 16s;}
  .photo-marquee img{height:160px; border-radius:12px; box-shadow: inset 56px 0 80px rgba(0,0,0,.55), inset -56px 0 80px rgba(0,0,0,.55);}
}


/* --- Hero Background Layers (v67) --- */
.hero { position: relative; }
.hero { position: relative; }
.hero { position: relative; }
.hero { position: relative; }
.hero-bg-layer {
  position:absolute; inset:0; z-index:0;
  background: url("assets/photo/hero_bg_v89.jpg") center calc(50% - 8vh) / cover no-repeat;
}
.hero .container, .hero h1, .hero h2, .hero p, .hero .buttons, .hero-content{ position:relative; z-index:2; }











.hero-bg-art{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-48%, -67%);
  width: clamp(980px, 116vw, 2850px);
  height:auto;
  z-index:1;
  opacity:0.88;
  filter: blur(2.2px);
  pointer-events:none;
}













/* --- v82: Animated spotlight + metallic grain overlay --- */
.hero { position: relative; overflow: hidden; }

/* Soft moving spotlight from top-left */
.hero-light{
  position:absolute; inset:0; z-index:1;
  background:
    radial-gradient(38% 38% at 22% 18%, rgba(255, 225, 160, 0.24) 0%,
                                      rgba(255, 210, 120, 0.10) 36%,
                                      rgba(255, 200, 90, 0.00) 68%);
  mix-blend-mode: screen;
  animation: heroLightDrift 18s ease-in-out infinite alternate;
  pointer-events:none;
}

/* Fine metallic grain */
.hero-grain{
  position:absolute; inset:0; z-index:1;
  background-image: url("assets/photo/grain_v82.png");
  background-size: 320px 320px;
  opacity: 0.12;
  mix-blend-mode: overlay;
  animation: grainFloat 6s linear infinite;
  pointer-events:none;
}

/* Keep mark above effects but below text */




.hero-bg-art{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-48%, -67%);
  width: clamp(980px, 116vw, 2850px);
  height:auto;
  z-index:1;
  opacity:0.88;
  filter: blur(2.2px);
  pointer-events:none;
}




.hero .container, .hero h1, .hero h2, .hero p, .hero .buttons, .hero-content{ z-index: 2; position: relative; }

@keyframes heroLightDrift{
  0%   { transform: translate3d(0,0,0) scale(1.00); }
  50%  { transform: translate3d(1.2%, -0.8%, 0) scale(1.04); }
  100% { transform: translate3d(2.0%, -1.4%, 0) scale(1.06); }
}

@keyframes grainFloat{
  0%   { transform: translate3d(0,0,0); }
  50%  { transform: translate3d(0.6%, -0.6%, 0); }
  100% { transform: translate3d(1.0%, -1.0%, 0); }
}


.hero-white-haze {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2400px;
  height: auto;
  transform: translate(-50%, -55%);
  pointer-events: none;
  z-index: 1;
  opacity: 0.33;
  mix-blend-mode: screen;
  filter: blur(2px);
}



.hero-white-halo {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 3000px;
  height: auto;
  transform: translate(-50%, -56%);
  pointer-events: none;
  z-index: 1;
  opacity: 0.2;
  mix-blend-mode: screen;
}



/* --- Demo Player (三语言: 最新单曲 / New Single / 最新シングル) --- */
.demo-player{padding:64px 0;border-top:1px solid rgba(255,255,255,0.06);background: rgba(0,0,0,0.12);backdrop-filter: blur(2px);}
.demo-player .container{max-width:1080px;margin:0 auto;padding:0 20px;}
.demo-title{font-size:clamp(22px,2.6vw,36px);letter-spacing:0.02em;margin:0 0 10px;color:#fff;}
.demo-sub{opacity:.7;margin:0 0 24px;color:#ddd;font-size:clamp(13px,1.6vw,16px)}
.track-list{display:grid;grid-template-columns:1fr;gap:16px}
.track{display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid rgba(255,255,255,0.08);border-radius:14px;background:rgba(255,255,255,0.03)}
.track-title{min-width:120px;margin:0;color:#fff;opacity:.92}
audio{width:100%;outline:none;filter: drop-shadow(0 2px 8px rgba(0,0,0,.25));border-radius:8px}



/* v123: correct brand logo placement and sizing */
.brand .logo{width:48px;height:48px;border-radius:12px;overflow:hidden}
.brand .logo img{width:100%;height:100%;object-fit:contain;display:block}


/* v127: Apple-like hover language switch */
.lang-switch{ position: relative; margin-left: auto; }
.lang-btn{
  display:flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:10px;
  background:rgba(255,255,255,0.06); color:#fff; border:1px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(6px);
  cursor:pointer; transition: background .2s ease, border-color .2s ease, transform .15s ease;
}
.lang-btn:hover{ background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.22); transform: translateY(-1px); }
.lang-label{ font-size:13px; opacity:.9; }

.lang-menu{
  position:absolute; top:42px; right:0; min-width:160px;
  padding:8px; margin:0; list-style:none; opacity:0; visibility:hidden; transform: translateY(-6px);
  background: rgba(20,20,20,0.8); border:1px solid rgba(255,255,255,0.12); border-radius:12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
  transition: opacity .18s ease, transform .18s ease, visibility .18s;
  z-index: 30;
}
.lang-menu li{
  padding:10px 12px; border-radius:8px; cursor:pointer;
  color:#fff; font-size:14px; white-space:nowrap;
  transition: background .15s ease, color .15s ease;
}
.lang-menu li:hover{ background:rgba(255,255,255,0.12); }
.lang-menu li.active{ background:rgba(255,255,255,0.2); }

/* Show on hover */
.lang-switch:hover .lang-menu,
.lang-switch:focus-within .lang-menu{
  opacity:1; visibility:visible; transform: translateY(0);
}
