:root{
  /* 暮色梦核 · Slo-mo dusk palette */
  --bg:#0c0a14;
  --panel:#13101e;
  --ink:#f6f2fb;
  --muted:#9b93b3;
  --line:rgba(255,255,255,.1);
  --accent:#9b8bff;
  --accent2:#ff84bd;
  /* mist tones */
  --mist-pink:#ff9bc7;
  --mist-blue:#8fb8ff;
  --mist-violet:#bb9bff;
  --mist-peach:#ffb892;
  --radius:18px;
  --max:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--bg)}
body{font-family:'Noto Sans SC','Poppins',system-ui,sans-serif;background:transparent;color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased}

/* ---- 流动极光背景 · dreamcore aurora ---- */
.aurora{position:fixed;inset:-20% -10%;z-index:-2;pointer-events:none;overflow:hidden;filter:blur(44px) saturate(165%)}
.aurora b{position:absolute;display:block;border-radius:50%;opacity:.72;mix-blend-mode:screen;will-change:transform}
.aurora b:nth-child(1){width:46vw;height:46vw;left:-6%;top:-8%;background:radial-gradient(circle,var(--mist-violet),transparent 65%);animation:drift1 26s ease-in-out infinite}
.aurora b:nth-child(2){width:42vw;height:42vw;right:-8%;top:6%;background:radial-gradient(circle,var(--mist-pink),transparent 65%);animation:drift2 32s ease-in-out infinite}
.aurora b:nth-child(3){width:50vw;height:50vw;left:8%;bottom:-18%;background:radial-gradient(circle,var(--mist-blue),transparent 65%);animation:drift3 30s ease-in-out infinite}
.aurora b:nth-child(4){width:34vw;height:34vw;right:4%;bottom:-12%;background:radial-gradient(circle,var(--mist-peach),transparent 65%);animation:drift1 38s ease-in-out infinite reverse}
@keyframes drift1{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(8%,6%) scale(1.18)}}
@keyframes drift2{0%,100%{transform:translate(0,0) scale(1.05)}50%{transform:translate(-7%,9%) scale(.85)}}
@keyframes drift3{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(6%,-7%) scale(1.2)}}
.aurora:after{content:"";position:absolute;inset:0;background:radial-gradient(140% 110% at 50% 0%,transparent 62%,var(--bg) 100%)}
@media(prefers-reduced-motion:reduce){.aurora b{animation:none}}
.trail-layer{position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden}
.trail-bit{position:fixed;left:0;top:0;font-family:'Poppins',sans-serif;font-weight:800;line-height:1;will-change:transform,opacity;text-shadow:0 0 6px currentColor;user-select:none}
/* NEXZOO 文字说明（不转载官方角色图） */
.nexzoo-note{margin:34px auto 8px;max-width:860px;border:1px dashed var(--line);border-radius:16px;padding:18px 22px;font-size:13.5px;color:var(--ink);background:rgba(255,255,255,.02)}
.nexzoo-note b{font-family:'Poppins';letter-spacing:1px}
.nexzoo-note .zoo-names{display:block;margin:8px 0;color:var(--muted);font-size:12.5px;line-height:1.8}
.nexzoo-note a{color:var(--accent2)}
img{display:block}
a{color:inherit;text-decoration:none;transition:.2s}
::selection{background:var(--accent);color:#fff}

/* header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:20px 40px;transition:background .3s,padding .3s,border-color .3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(8,8,13,.8);backdrop-filter:blur(18px);padding:14px 40px;border-color:var(--line)}
.logo{font-family:'Poppins';font-weight:900;font-size:24px;letter-spacing:3px}
.logo span{color:var(--accent)}
.nav{display:flex;gap:26px}
.nav a{color:var(--muted);font-weight:500;font-size:13px;letter-spacing:1px;text-transform:uppercase}
.nav a:hover{color:var(--ink)}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);font-size:24px;cursor:pointer}

/* panel system — each section independent page */
.page{display:none}
.page.active{display:block;animation:fade .45s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
section.page{min-height:100vh;padding-top:128px}
body:not(.is-home) .site-header{background:rgba(8,8,13,.85);backdrop-filter:blur(18px);border-color:var(--line)}
.nav a.cur{color:var(--ink)}

/* home landing menu */
.home-menu{max-width:var(--max);margin:0 auto;padding:54px 40px 100px;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);border-radius:18px;overflow:hidden;margin-top:46px}
.home-menu a{background:var(--bg);padding:30px 26px;display:flex;flex-direction:column;gap:7px;transition:background .2s,transform .2s}
.home-menu a:hover{background:var(--accent);color:#fff}
.hm-idx{font-family:'Poppins';color:var(--accent);font-size:12px;font-weight:600;letter-spacing:1px}
.home-menu a:hover .hm-idx{color:#fff}
.hm-en{font-family:'Poppins';font-weight:800;font-size:23px;letter-spacing:.5px}
.hm-cn{color:var(--muted);font-size:12px}
.home-menu a:hover .hm-cn{color:rgba(255,255,255,.85)}

/* hero */
.hero{position:relative;height:calc(100vh - 64px);min-height:560px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background:
  radial-gradient(1200px 600px at 70% 8%, rgba(187,155,255,.34), transparent 62%),
  radial-gradient(1000px 560px at 12% 86%, rgba(255,132,189,.26), transparent 62%),
  radial-gradient(800px 500px at 90% 92%, rgba(143,184,255,.22), transparent 60%),
  linear-gradient(160deg,#15101f,#0a0810)}
.hero:after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(8,8,13,.55) 0%,transparent 30%,rgba(8,8,13,.4) 55%,var(--bg) 100%)}
.hero-inner{position:relative;z-index:2;padding:0 40px 90px;max-width:var(--max);margin:0 auto;width:100%}
.hero-kicker{color:#cdcdfb;letter-spacing:5px;font-size:12px;font-weight:600;text-transform:uppercase}
.hero-title{font-family:'Poppins';font-weight:900;font-size:clamp(88px,20vw,260px);line-height:.86;letter-spacing:-2px;margin:14px 0 18px;
  text-shadow:0 20px 60px rgba(0,0,0,.5)}
.hero-sub{font-size:clamp(15px,2.2vw,19px);color:#e3e3ee}
.hero-fandom{color:var(--muted);margin-top:4px;font-size:13px;letter-spacing:1px}
.hero-fandom strong{color:var(--accent2)}
.hero-cta{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.btn{font-family:'Poppins';font-weight:600;font-size:13px;letter-spacing:2px;padding:14px 30px;border-radius:999px;
  background:#fff;color:#000;transition:transform .15s,background .2s}
.btn:hover{transform:translateY(-2px);background:var(--accent);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:#fff;color:#000;border-color:#fff}
.hero-scroll{position:absolute;z-index:2;right:40px;bottom:40px;writing-mode:vertical-rl;letter-spacing:3px;font-size:11px;color:var(--muted)}
.hero-scroll:before{content:"";display:block;width:1px;height:46px;margin:0 auto 10px;background:linear-gradient(var(--accent),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{opacity:0;transform:scaleY(.2);transform-origin:top}50%{opacity:1}100%{opacity:0;transform:scaleY(1);transform-origin:bottom}}

/* marquee */
.marquee{overflow:hidden;border-bottom:1px solid var(--line);padding:18px 0;background:var(--panel)}
.marquee-track{display:flex;gap:44px;white-space:nowrap;width:max-content;animation:scroll 28s linear infinite;font-family:'Poppins';font-weight:800;font-size:24px;letter-spacing:4px}
.marquee-track span{color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.25)}
.marquee-track span.fill{color:var(--ink);-webkit-text-stroke:0}
@keyframes scroll{to{transform:translateX(-50%)}}

/* sections */
.section{max-width:var(--max);margin:0 auto;padding:110px 40px}
.section.alt{background:rgba(13,11,21,.82);max-width:none;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section.alt>*{max-width:var(--max);margin-left:auto;margin-right:auto}
.section-head{margin-bottom:54px;position:relative}
.sec-idx{font-family:'Poppins';font-weight:600;font-size:13px;color:var(--accent);letter-spacing:2px}
.section-head h2{font-family:'Poppins';font-size:clamp(26px,4vw,40px);font-weight:900;letter-spacing:-1px;line-height:1;margin:6px 0 10px}
.section-head p{color:var(--muted);font-size:14px}
.sub-head{margin:48px 0 20px;font-size:14px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted)}
.note{color:var(--muted);font-size:12.5px;margin-top:28px}
.legend{font-size:12px;color:#b9b3ff;margin:-2px 0 16px;padding:9px 14px;background:rgba(124,107,255,.08);border:1px dashed var(--line);border-radius:10px;display:inline-block}
.legend b{color:var(--accent2)}
.note a{color:#b9b3ff;border-bottom:1px solid rgba(185,179,255,.35)}
.note code{background:rgba(255,255,255,.08);padding:2px 7px;border-radius:5px;font-size:12px}

/* reveal */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* group intro */
.group-intro{display:grid;grid-template-columns:1.6fr 1fr;gap:30px;margin-bottom:40px;padding:30px 32px;
  background:linear-gradient(135deg,rgba(124,107,255,.08),rgba(255,91,168,.06));border:1px solid var(--line);border-radius:var(--radius)}
.gi-main h3{font-family:'Poppins';font-size:22px;font-weight:800;margin-bottom:14px}
.gi-main p{font-size:13.5px;line-height:1.85;color:#c7c7d4;margin-bottom:12px}
.gi-main strong{color:var(--accent2);font-weight:700}
.gi-facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;align-self:start}
.gi-facts div{background:var(--bg);padding:14px 16px;display:flex;flex-direction:column;gap:4px}
.gi-facts span{font-size:11px;color:var(--muted);letter-spacing:1px}
.gi-facts b{font-family:'Poppins';font-size:14px;font-weight:700}
@media(max-width:820px){.group-intro{grid-template-columns:1fr}}

/* members · Slo-mo dreamcore card */
.member-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.member-card{cursor:default;border-radius:22px;overflow:hidden;position:relative;
  background:linear-gradient(170deg,rgba(30,23,46,.6),rgba(18,14,28,.6));
  border:1px solid var(--line);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s}
.member-card:before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;transition:opacity .4s;
  background:radial-gradient(120% 80% at 50% -10%,color-mix(in srgb,var(--c1) 55%,transparent),transparent 60%)}
.member-card:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--c1) 50%,transparent);
  box-shadow:0 22px 60px -20px color-mix(in srgb,var(--c1) 60%,transparent)}
.member-card:hover:before{opacity:.85}
/* hero */
.m-hero{position:relative;z-index:1;height:170px;overflow:hidden;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,color-mix(in srgb,var(--c1) 80%,transparent),color-mix(in srgb,var(--c2) 70%,transparent))}
.m-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 50%,rgba(12,10,20,.65))}
.m-idx{position:absolute;top:12px;left:16px;font-family:'Poppins';font-weight:900;font-size:15px;letter-spacing:1px;color:rgba(255,255,255,.85);z-index:2}
.m-name-wm{position:absolute;left:0;right:0;bottom:8px;text-align:center;font-family:'Poppins';font-weight:900;
  font-size:40px;letter-spacing:1px;line-height:1;color:rgba(255,255,255,.16);z-index:1;text-transform:uppercase}
.m-emoji{position:relative;z-index:2;font-size:74px;line-height:1;filter:drop-shadow(0 8px 22px rgba(0,0,0,.4));transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.member-card:hover .m-emoji{transform:scale(1.14) translateY(-4px) rotate(-4deg)}
/* info */
.m-info{position:relative;z-index:1;padding:18px 20px 20px}
.member-card h3{font-family:'Poppins';font-size:24px;font-weight:800;margin:2px 0 2px;letter-spacing:.5px}
.m-full{color:var(--muted);font-size:12px;margin-bottom:10px}
.m-zooline{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}
.m-zooline b{font-family:'Poppins';font-size:12.5px;font-weight:700;color:color-mix(in srgb,var(--c1) 60%,#fff);letter-spacing:.5px}
.m-zooline span{font-size:11px;color:var(--muted);padding:2px 9px;border-radius:999px;border:1px solid var(--line)}
.m-intro{font-size:12.5px;line-height:1.75;color:#cfc9da;margin-bottom:14px}
.m-rows{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden}
.m-row{display:flex;flex-direction:column;gap:3px;font-size:12px;background:rgba(20,16,30,.4);padding:9px 12px}
.m-row span{color:var(--muted);font-size:10.5px;letter-spacing:.5px}
.m-row b{color:var(--ink);font-weight:600;font-size:12.5px}
.m-tag{display:inline-block;margin-top:14px;font-size:11px;padding:5px 13px;border-radius:999px;border:1px solid var(--line);color:#c8bfff;letter-spacing:1px;background:rgba(155,139,255,.08)}
.m-solo-wrap{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.m-solo-h{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--muted);margin-bottom:8px;text-transform:uppercase}
.m-solo-list{display:flex;flex-direction:column;gap:6px}
.m-solo{font-size:11.5px;font-weight:600;padding:6px 10px;border-radius:9px;text-decoration:none;background:rgba(255,255,255,.04);color:#d7d7e2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.m-solo:hover{background:rgba(255,255,255,.09)}
.m-solo.vlog{background:rgba(91,108,255,.12);color:#9aa6ff}
.m-solo.bday{background:rgba(255,107,163,.12);color:#ff9ec4}
.m-solo.vaca{background:rgba(17,197,212,.12);color:#7fe3ee}
.m-solo.guest{background:rgba(255,177,91,.12);color:#ffc987}

/* albums · Slo-mo cover card */
.album-grid{display:grid;grid-template-columns:1fr;gap:22px;max-width:900px;margin:0 auto}
.album-card{display:grid;grid-template-columns:230px 1fr;gap:0;
  background:rgba(19,16,30,.72);border:1px solid var(--line);border-radius:22px;overflow:hidden;
  transition:transform .35s,border-color .35s,box-shadow .35s}
.album-card:hover{transform:translateY(-4px);border-color:color-mix(in srgb,var(--g1) 50%,transparent);
  box-shadow:0 22px 60px -24px color-mix(in srgb,var(--g1) 70%,transparent)}
/* gradient cover */
.album-cover{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;gap:6px;padding:22px;
  min-height:230px;background:linear-gradient(150deg,var(--g1),var(--g2))}
.album-cover:before{content:"";position:absolute;inset:0;background:
  radial-gradient(80% 60% at 80% 10%,rgba(255,255,255,.35),transparent 55%),
  linear-gradient(transparent 40%,rgba(12,10,20,.5))}
.ac-disc{position:absolute;top:-44px;right:-44px;width:150px;height:150px;border-radius:50%;
  background:repeating-radial-gradient(circle,rgba(0,0,0,.18) 0 2px,transparent 2px 6px),rgba(0,0,0,.25);
  border:6px solid rgba(0,0,0,.2);box-shadow:inset 0 0 0 22px rgba(255,255,255,.06)}
.ac-disc:after{content:"";position:absolute;inset:0;margin:auto;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.5)}
.ac-type{position:relative;z-index:1;align-self:flex-start;font-size:10px;font-weight:700;letter-spacing:1px;
  padding:4px 10px;border-radius:999px;background:rgba(0,0,0,.28);color:#fff}
.ac-title{position:relative;z-index:1;font-family:'Poppins';font-weight:900;font-size:30px;line-height:1.05;
  color:#fff;text-shadow:0 4px 18px rgba(0,0,0,.4);letter-spacing:-.5px}
.ac-date{position:relative;z-index:1;font-family:'Poppins';font-size:12px;font-weight:600;color:rgba(255,255,255,.85)}
.album-body{padding:22px 24px}
@media(max-width:640px){.album-card{grid-template-columns:1fr}.album-cover{min-height:170px}}
.play-btn.sp:hover{border-color:#1db954;background:rgba(29,185,84,.14);color:#fff}
.play-btn.ne:hover{border-color:#c20c0c;background:rgba(194,12,12,.16);color:#fff}
.play-btn.qq:hover{border-color:#31c27c;background:rgba(49,194,124,.14);color:#fff}
.album-card .play-row{margin-top:6px}
.track-list{list-style:none;margin:15px 0 0;padding:13px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:2px}
.track{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 5px;border-radius:8px;transition:background .15s;flex-wrap:wrap}
.track:hover{background:rgba(255,255,255,.04)}
.t-head{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.t-num{font-family:'Poppins';font-size:12px;color:var(--muted);width:20px;flex:0 0 20px}
.t-name{font-size:14px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.t-links{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.tl-grp{display:inline-flex;align-items:center;gap:3px}
.tl-grp i{font-style:normal;font-size:10px;color:var(--muted);margin-right:2px;white-space:nowrap}
.tl-grp i.g-mv{color:#ff7b7b}
.tl-grp i.g-perf{color:#b9b3ff}
.tl-grp i.g-dance{color:#7fe0a0}
.tl-grp i.g-bts{color:#ffd27f}
.t-links .tl{font-size:10.5px;font-weight:700;padding:2px 7px;border-radius:6px;border:1px solid var(--line);color:var(--muted);transition:.15s;white-space:nowrap}
.t-links .tl.yt:hover{border-color:#ff3d3d;background:rgba(255,61,61,.14);color:#fff}
.t-links .tl.bili:hover{border-color:#00aeec;background:rgba(0,174,236,.14);color:#fff}
@media(max-width:560px){
  .t-head{flex:1 0 100%}
  .t-links{width:100%}
  .album-top{flex-wrap:wrap}
}

/* content / 物料 */
.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:8px}
.content-card{display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:transform .2s,border-color .2s}
.content-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.2)}
.cc-tag{align-self:flex-start;font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 10px;border-radius:999px;background:rgba(124,107,255,.16);color:#b9b3ff;margin-bottom:11px}
.content-card h4{font-family:'Poppins';font-size:18px;font-weight:800;letter-spacing:.5px}
.cc-cn{color:var(--muted);font-size:12px;margin:3px 0 9px}
.cc-desc{font-size:12.5px;line-height:1.65;color:#c7c7d4;margin-bottom:15px}
.content-card .play-row{margin-top:auto}

/* guest list — dense rows */
.guest-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:8px;margin-bottom:8px}
.guest-row{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:10px 14px}
.gr-date{flex:0 0 auto;font-family:'Poppins';font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.5px;min-width:38px}
.gr-main{flex:1 1 auto;min-width:0}
.gr-main h4{font-size:13.5px;font-weight:700;display:flex;align-items:baseline;gap:7px;flex-wrap:wrap}
.gr-mem{font-size:10.5px;font-weight:500;color:var(--muted)}
.gr-cn{font-size:11.5px;color:#c7c7d4;margin-top:2px;line-height:1.4}
.gr-links{flex:0 0 auto;display:flex;gap:6px}
.gr-lk{font-size:10.5px;font-weight:700;padding:5px 9px;border-radius:8px;white-space:nowrap;text-decoration:none}
.gr-lk.yt{background:rgba(255,0,0,.14);color:#ff6b6b}
.gr-lk.bili{background:rgba(0,174,236,.14);color:#5cc8f0}

/* link grids */
.link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.link-card{display:flex;align-items:center;gap:15px;background:rgba(255,255,255,.02);border-radius:var(--radius);padding:18px 20px;
  border:1px solid var(--line);transition:border-color .2s,transform .15s,background .2s}
.link-card:hover{transform:translateY(-3px);border-color:var(--accent);background:rgba(124,107,255,.06)}
.link-ico{font-size:22px;width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.05);border:1px solid var(--line)}
.link-card h4{font-size:15px;font-weight:600}
.link-card p{color:var(--muted);font-size:12.5px;word-break:break-all}

/* ============ 官方·社媒 = 手机主屏 ============ */
.phone-page .phone-wrap{display:flex;justify-content:center;margin-top:8px}
.phone{position:relative;width:392px;max-width:94vw;border-radius:46px;padding:13px 13px 11px;
  background:linear-gradient(160deg,#2a2342,#161122);border:3px solid #0c0a16;
  box-shadow:0 0 0 6px #1c1730,0 24px 50px -16px rgba(0,0,0,.7),inset 0 0 0 2px rgba(255,255,255,.05)}
.ph-notch{position:absolute;left:50%;top:12px;transform:translateX(-50%);width:120px;height:22px;border-radius:0 0 14px 14px;
  background:#0c0a16;z-index:3}
.ph-statusbar{display:flex;justify-content:space-between;align-items:center;padding:6px 18px 8px;color:#fff}
.ph-time{font-family:'Poppins';font-weight:700;font-size:13px;letter-spacing:.5px}
.ph-stat{display:inline-flex;align-items:center;gap:6px}
.ph-stat i{display:inline-block}
.ph-sig{width:15px;height:11px;background:
  linear-gradient(to top,#fff 100%,transparent 0) left/3px 40% no-repeat,
  linear-gradient(to top,#fff 100%,transparent 0) 4px bottom/3px 60% no-repeat,
  linear-gradient(to top,#fff 100%,transparent 0) 8px bottom/3px 80% no-repeat,
  linear-gradient(to top,#fff 100%,transparent 0) right/3px 100% no-repeat}
.ph-wifi{width:14px;height:11px;border-radius:50%;
  background:radial-gradient(circle at 50% 100%,#fff 0 2px,transparent 3px),
  conic-gradient(from 225deg at 50% 100%,#fff 0 90deg,transparent 0);
  -webkit-mask:radial-gradient(circle at 50% 100%,#000 38%,#000 100%);clip-path:polygon(0 0,100% 0,50% 100%)}
.ph-bat{width:24px;height:12px;border:1.5px solid #fff;border-radius:3px;position:relative;
  background:linear-gradient(to right,#3ad36b 78%,transparent 0)}
.ph-bat:after{content:"";position:absolute;right:-3px;top:3px;width:2px;height:5px;background:#fff;border-radius:0 2px 2px 0}
.ph-screen{margin:2px 7px 0;border-radius:28px;padding:18px 16px 20px;min-height:392px;
  background:radial-gradient(120% 90% at 30% 0%,rgba(124,107,255,.5),rgba(255,132,189,.22) 45%,rgba(20,16,34,.6) 100%),
  linear-gradient(180deg,#241c3e,#15102a)}
.ph-greet{text-align:center;font-size:12.5px;color:rgba(255,255,255,.85);margin-bottom:18px;letter-spacing:.5px}
.app-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px 8px}
/* 社媒下面空出一行：页面圆点指示器 */
.ph-dots{display:flex;justify-content:center;gap:7px;margin-top:64px;min-height:18px;align-items:center}
.ph-dots i{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.32)}
.ph-dots i.on{background:rgba(255,255,255,.92);width:7px;height:7px}
.app-ico{display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none}
.ai-tile{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:29px;
  background:linear-gradient(150deg,color-mix(in srgb,var(--ac) 78%,#fff 22%),var(--ac));
  border:1px solid rgba(255,255,255,.18);box-shadow:0 5px 10px -3px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.3);
  transition:transform .15s}
.app-ico:active .ai-tile,.app-ico:hover .ai-tile{transform:translateY(-3px) scale(1.05)}
.ai-label{font-size:10px;color:rgba(255,255,255,.92);max-width:64px;text-align:center;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ph-dock{margin:12px 6px 0;border-radius:26px;padding:12px 10px 8px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(6px)}
.ph-dock-hd{display:block;text-align:center;font-size:9px;letter-spacing:1px;color:rgba(255,255,255,.6);margin-bottom:9px}
.ph-dock-row{display:flex;justify-content:space-around;gap:8px}
.app-ico.dock .ai-tile{width:52px;height:52px;font-size:24px}
.ph-home{display:block;width:130px;height:4px;border-radius:3px;background:rgba(255,255,255,.5);margin:10px auto 4px}
/* ---- phone liveliness (matches other pages) ---- */
.phone-page .phone-wrap{position:relative}
.phone-page .phone-wrap::before{content:"";position:absolute;top:50%;left:50%;width:330px;height:560px;
  transform:translate(-50%,-50%);border-radius:50%;pointer-events:none;z-index:0;filter:blur(44px);
  background:radial-gradient(closest-side,rgba(124,107,255,.55),rgba(255,132,189,.3) 55%,transparent 78%);
  animation:phoneAura 5s ease-in-out infinite}
@keyframes phoneAura{0%,100%{opacity:.55;transform:translate(-50%,-50%) scale(.96)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.06)}}
.phone-page .phone{z-index:1;animation:phoneFloat 6s ease-in-out infinite}
@keyframes phoneFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.app-grid .app-ico{animation:appBob 3.2s ease-in-out infinite}
.app-grid .app-ico:nth-child(4n+2){animation-delay:.25s}
.app-grid .app-ico:nth-child(4n+3){animation-delay:.5s}
.app-grid .app-ico:nth-child(4n){animation-delay:.75s}
.app-grid .app-ico:nth-child(n+5){animation-duration:3.6s}
@keyframes appBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.ai-tile{position:relative;overflow:hidden}
.ai-tile::after{content:"";position:absolute;top:0;left:-70%;width:55%;height:100%;transform:skewX(-18deg);
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.4),transparent);animation:aiShine 5s ease-in-out infinite}
.app-ico:nth-child(2n) .ai-tile::after{animation-delay:1.2s}
.app-ico:nth-child(3n) .ai-tile::after{animation-delay:2.4s}
@keyframes aiShine{0%,72%{left:-70%}88%,100%{left:140%}}
@media(prefers-reduced-motion:reduce){.phone-page .phone,.app-grid .app-ico,.phone-page .phone-wrap::before,.ai-tile::after{animation:none}}
@media(max-width:420px){
  .app-grid{gap:15px 5px}
  .ai-tile{width:54px;height:54px;font-size:25px}
  .app-ico.dock .ai-tile{width:48px;height:48px;font-size:22px}
}

/* cheer */
.cheer-base{display:flex;flex-wrap:wrap;gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;margin-bottom:40px}
.cheer-base div{flex:1;min-width:200px;padding:20px 24px;border-right:1px solid var(--line)}
.cheer-base div:last-child{border-right:0}
.cheer-base span{display:block;color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase;margin-bottom:6px}
.cheer-base b{font-family:'Poppins';color:var(--ink);font-size:15px;font-weight:600}
.cheer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.cheer-card{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:rgba(20,16,30,.7);
  transition:transform .3s,border-color .3s,box-shadow .3s}
.cheer-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.22);box-shadow:0 14px 40px -20px rgba(0,0,0,.7)}
.cheer-thumb{display:grid;place-items:center;aspect-ratio:16/7;position:relative;overflow:hidden;transition:filter .3s}
.cheer-thumb:before{content:"";position:absolute;inset:0;background:radial-gradient(80% 70% at 30% 20%,rgba(255,255,255,.22),transparent 60%)}
.cheer-thumb:hover{filter:brightness(1.12)}
.cheer-thumb .ph-song{position:relative;z-index:1;font-family:'Poppins';font-weight:900;font-size:16px;color:#fff;padding:0 14px;text-align:center;letter-spacing:.3px;text-shadow:0 3px 14px rgba(0,0,0,.4)}
.cheer-thumb .g-play{position:absolute;right:9px;bottom:6px;z-index:1;font-size:17px;text-shadow:0 2px 16px #000}
.cheer-body{padding:13px 15px}
.cheer-body h3{font-size:15px}
.cheer-body .play-row{margin-top:10px;gap:6px}
.cheer-body .play-btn{font-size:11px;padding:6px 11px}
.cheer-body h3{font-family:'Poppins';font-weight:700}
.cheer-body .links{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.cheer-body .links a{font-size:12px;padding:7px 13px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}
.cheer-body .links a:hover{border-color:var(--accent);color:var(--ink);background:rgba(124,107,255,.1)}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.92);display:none;place-items:center;padding:24px;backdrop-filter:blur(8px)}
.lightbox.open{display:grid}
.lb-frame{width:min(980px,100%);aspect-ratio:16/9}
.lb-frame iframe{width:100%;height:100%;border:0;border-radius:14px}
.lb-close{position:absolute;top:22px;right:26px;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:20px;width:46px;height:46px;border-radius:50%;cursor:pointer}
.lb-close:hover{background:var(--accent)}

/* play buttons (albums + cheer) */
.play-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.play-btn{font-size:12px;font-weight:600;padding:8px 14px;border-radius:999px;border:1px solid var(--line);
  color:var(--muted);cursor:pointer;background:rgba(255,255,255,.02);transition:.18s;line-height:1}
.play-btn:hover{color:#fff;transform:translateY(-2px)}
.play-btn.yt:hover{border-color:#ff3d3d;background:rgba(255,61,61,.14);color:#fff}
.play-btn.bili:hover{border-color:#00aeec;background:rgba(0,174,236,.14);color:#fff}
.play-btn.txt:hover{border-color:var(--accent);background:rgba(124,107,255,.14);color:#fff}
.play-btn.srch{border-style:dashed;opacity:.82}

/* image lightbox */
.img-lb{z-index:120}
.img-lb img{max-width:min(1100px,100%);max-height:82vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 80px rgba(0,0,0,.6)}
.img-cap{position:absolute;bottom:26px;left:0;right:0;text-align:center;font-family:'Poppins';font-weight:600;letter-spacing:1px;color:#fff;text-shadow:0 2px 12px #000}

/* floating home button — star */
.home-fab{position:fixed;left:24px;bottom:24px;z-index:90;width:68px;height:68px;text-decoration:none;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;
  color:#fff;background:linear-gradient(140deg,#9a86ff,#ff84bd);
  clip-path:polygon(50% 1%,63% 34%,99% 35%,70% 58%,81% 95%,50% 72%,19% 95%,30% 58%,1% 35%,37% 34%);
  filter:drop-shadow(0 6px 14px rgba(124,107,255,.5));transition:transform .22s,filter .22s}
.home-fab .hf-txt{font-family:'Press Start 2P',monospace;font-size:8px;letter-spacing:.5px;margin-top:-3px;text-shadow:0 1px 2px rgba(0,0,0,.3)}
.home-fab:hover{transform:translateY(-3px) rotate(-7deg) scale(1.07);filter:drop-shadow(0 11px 22px rgba(255,132,189,.6))}
body.is-home .home-fab{opacity:0;pointer-events:none;transform:scale(.5)}

/* footer */
.site-footer{text-align:center;padding:50px 24px;border-top:1px solid var(--line);color:var(--muted)}
.foot-sub{font-size:11.5px;margin-top:8px;opacity:.75}

@media(max-width:860px){
  .home-menu{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:720px){
  .site-header,.section{padding-left:22px;padding-right:22px}
  .nav{position:fixed;inset:60px 0 auto 0;flex-direction:column;gap:0;background:var(--panel);transform:translateY(-140%);transition:.3s;border-bottom:1px solid var(--line)}
  .nav.open{transform:translateY(0)}
  .nav a{padding:16px 24px;border-top:1px solid var(--line)}
  .nav-toggle{display:block}
  .hero-inner{padding-bottom:60px}
  .cheer-base div{flex-basis:100%;border-right:0;border-bottom:1px solid var(--line)}
}

/* ===================== NEXZ 的客厅 · pixel living room ===================== */
.lr-stage{position:relative;height:calc(100vh - 64px);min-height:540px;overflow:hidden;
  --wall:#2c2342;--wall2:#352a4f;--floor:#241a32;--floor2:#2e2240;--wood:#6b4a7a;
  font-family:'Press Start 2P',monospace;image-rendering:pixelated}
.lr-room{position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(0,0,0,.18),transparent 30%,transparent 70%,rgba(0,0,0,.18)),
    linear-gradient(var(--wall) 0 68%,var(--wood) 68% 70%,var(--floor) 70% 100%)}
/* floor perspective lines */
.lr-room:after{content:"";position:absolute;left:0;right:0;bottom:0;height:30%;pointer-events:none;
  background:repeating-linear-gradient(90deg,transparent 0 11.1%,rgba(0,0,0,.13) 11.1% 11.3%);opacity:.5}
/* 景深暗角 + 中央舞台聚光：装饰退后，可点击物件与小人(z≥5)浮在前面 */
.lr-room:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:4;
  background:radial-gradient(120% 75% at 50% 80%,rgba(255,205,150,.12),transparent 46%)}

/* title */
.lr-title{position:absolute;left:50%;top:4.3%;transform:translateX(-50%);z-index:8;text-align:center;
  font-size:26px;color:#fff;letter-spacing:1px;text-shadow:3px 3px 0 #1a1228,0 0 18px rgba(155,139,255,.5);line-height:1.5;white-space:nowrap}
.lr-title span{color:#ff9bc7}
.lr-title em{display:block;font-size:9px;color:#c8bfff;margin-top:12px;font-style:normal;animation:tipblink 1.6s steps(2) infinite}
@keyframes tipblink{50%{opacity:.35}}

/* generic interactive object — 持续微光标记“可点击” */
.lr-obj{position:absolute;z-index:5;border:0;background:none;cursor:pointer;padding:0;
  font-family:inherit;transition:transform .18s,filter .18s;animation:objpulse 2.8s ease-in-out infinite}
@keyframes objpulse{0%,100%{filter:drop-shadow(2px 4px 0 rgba(0,0,0,.32))}
  50%{filter:drop-shadow(2px 4px 0 rgba(0,0,0,.32)) drop-shadow(0 0 9px rgba(255,233,168,.65))}}
.lr-obj:hover{transform:translateY(-5px) scale(1.04);animation:none;
  filter:drop-shadow(0 0 13px rgba(255,233,168,.95)) brightness(1.12);z-index:9}
.lr-obj:focus-visible{outline:3px solid #ff9bc7;outline-offset:3px}
/* 角标：可点击提示 ✦ */
.lr-obj .lr-tip:after{content:"· 点击进入";color:#b5651d;font-size:9px}
.lr-tip{position:absolute;left:50%;bottom:100%;transform:translate(-50%,-6px);white-space:nowrap;z-index:7;
  font-size:12px;color:#1a1228;background:#ffe9a8;border:3px solid #1a1228;padding:8px 12px;border-radius:4px;
  box-shadow:4px 4px 0 rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:opacity .15s,transform .15s}
.lr-obj:hover .lr-tip{opacity:1;transform:translate(-50%,-12px)}

/* ---- window + dreamcore sky ---- */
.lr-window{position:absolute;left:3.1%;top:13.5%;width:25%;height:40%;z-index:2;
  border:7px solid #1a1228;border-radius:4px;box-shadow:0 0 0 5px var(--wood),6px 8px 0 rgba(0,0,0,.35);overflow:hidden;background:#0a0a16}
.lr-sky{position:absolute;inset:0;background:linear-gradient(#3a2c5e,#7a4d77 55%,#ffae8a 100%)}
.lr-sky b{position:absolute;border-radius:50%;filter:blur(14px);opacity:.7;mix-blend-mode:screen}
.lr-sky b:nth-child(1){width:60%;height:40%;left:-10%;top:8%;background:#bb9bff;animation:skyd 16s ease-in-out infinite}
.lr-sky b:nth-child(2){width:55%;height:38%;right:-8%;top:24%;background:#ff9bc7;animation:skyd 20s ease-in-out infinite reverse}
.lr-sky b:nth-child(3){width:70%;height:40%;left:10%;bottom:-6%;background:#ffd6a0;animation:skyd 18s ease-in-out infinite}
@keyframes skyd{0%,100%{transform:translate(0,0)}50%{transform:translate(10%,6%)}}
.lr-sky .cloud{position:absolute;height:9px;background:rgba(255,255,255,.55);border-radius:6px;box-shadow:10px 0 0 -1px rgba(255,255,255,.4),-10px 1px 0 -2px rgba(255,255,255,.35)}
.lr-sky .cloud.c1{width:40px;top:26%;left:-30%;animation:cloudm 22s linear infinite}
.lr-sky .cloud.c2{width:28px;top:50%;left:-30%;animation:cloudm 30s linear infinite 4s}
@keyframes cloudm{to{left:130%}}
.lr-sky .star{position:absolute;width:3px;height:3px;background:#fff;box-shadow:0 0 5px #fff;animation:tw 2.2s steps(2) infinite}
.lr-sky .star.s1{left:18%;top:14%}.lr-sky .star.s2{left:62%;top:10%;animation-delay:.6s}
.lr-sky .star.s3{left:80%;top:30%;animation-delay:1.1s}.lr-sky .star.s4{left:40%;top:20%;animation-delay:1.6s}
@keyframes tw{50%{opacity:.2}}
.lr-sky .hill{position:absolute;left:0;right:0;bottom:0;height:22%;background:#2e2350;border-radius:40% 50% 0 0/100% 100% 0 0}
.lr-win-frame{position:absolute;inset:0;z-index:2;pointer-events:none}
.lr-win-frame:before,.lr-win-frame:after{content:"";position:absolute;background:#1a1228}
.lr-win-frame:before{left:0;right:0;top:50%;height:6px;transform:translateY(-50%)}
.lr-win-frame:after{top:0;bottom:0;left:50%;width:6px;transform:translateX(-50%)}
.lr-curtain{position:absolute;top:-2px;bottom:-2px;width:18%;z-index:3;background:repeating-linear-gradient(90deg,#b85b8e 0 6px,#9c4a78 6px 12px)}
.lr-curtain.left{left:-2px;border-right:3px solid #1a1228}
.lr-curtain.right{right:-2px;border-left:3px solid #1a1228}

/* ---- calendar ---- */
.lr-cal{left:64.2%;top:28.9%;width:13%;height:19%;background:#fff6e6;border:4px solid #1a1228;border-radius:4px;
  box-shadow:5px 6px 0 rgba(0,0,0,.35);display:flex;flex-direction:column;overflow:hidden}
.cal-top{height:22%;background:#ff5b8e;border-bottom:3px solid #1a1228;position:relative}
.cal-top:before,.cal-top:after{content:"";position:absolute;top:-7px;width:5px;height:12px;background:#1a1228}
.cal-top:before{left:22%}.cal-top:after{right:22%}
.cal-month{font-size:9px;color:#fff;position:absolute;top:5px;left:0;right:0;text-align:center;z-index:1}
.cal-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);gap:1px;padding:4px}
.cal-grid i{font-style:normal;background:#e9dcc4;border-radius:1px;display:flex;align-items:center;justify-content:center;
  font-size:4.5px;font-weight:700;color:#7a5a3a;line-height:1}
.cal-grid i.today{background:#ff5b8e;color:#fff;box-shadow:0 0 0 1px #1a1228}
.cal-grid i.blank{background:transparent;color:transparent}

/* ---- bookshelf ---- */
.lr-shelf{right:3%;top:14%;width:14%;height:54%;z-index:1;
  background:linear-gradient(160deg,#4a3a86,#241a48);border:5px solid #0c0a1c;border-radius:4px;
  box-shadow:7px 9px 0 rgba(0,0,0,.4),inset 0 0 0 3px #5cc8f0,0 0 20px rgba(124,107,255,.55);
  display:flex;flex-direction:column;justify-content:space-between;padding:9px 8px 11px;gap:8px}
/* 落地的两只金属脚（带霓虹） */
.lr-shelf:before,.lr-shelf:after{content:"";position:absolute;bottom:-13px;width:22%;height:13px;
  background:linear-gradient(180deg,#9aa6d8,#3a3f6a);border:2px solid #0c0a1c;border-radius:0 0 4px 4px}
.lr-shelf:before{left:8%}.lr-shelf:after{right:8%}
.shelf-row{flex:1;display:flex;align-items:flex-end;gap:4px;padding:0 5px 5px;
  border-bottom:7px solid #1a1238;box-shadow:inset 0 -2px 0 rgba(92,200,240,.3);
  background:linear-gradient(180deg,rgba(92,200,240,.14),rgba(255,91,168,.14))}
.shelf-row i{flex:1;height:70%;background:var(--bc);border:2px solid #1a1228;border-radius:1px 1px 0 0;position:relative;overflow:hidden}
.shelf-row i:nth-child(2n){height:88%}.shelf-row i:nth-child(3n){height:60%}
.shelf-row i b{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  writing-mode:vertical-rl;text-orientation:upright;white-space:nowrap;line-height:1;
  font-size:5px;font-weight:800;letter-spacing:0;color:rgba(26,18,40,.85)}
/* 书架底层：抽屉柜 */
.shelf-row.drawers{align-items:stretch;justify-content:space-between;gap:3px;border-bottom:5px solid #3a2750;background:rgba(0,0,0,.22)}
.shelf-row.drawers i{flex:1;height:100%;writing-mode:horizontal-tb;background:linear-gradient(180deg,#8a6090,#6b4a7a);
  border:2px solid #1a1228;border-radius:1px;position:relative}
.shelf-row.drawers i:before{content:"";position:absolute;left:32%;right:32%;top:42%;height:2px;background:#1a1228;border-radius:1px}

/* ---- plushie：大熊 + 小狐狸（去掉底座） ---- */
.lr-plush{left:79.6%;top:79.8%;right:auto;bottom:auto;width:13%;height:16%;display:flex;align-items:flex-end;justify-content:center;z-index:7}
.plush-doll{font-size:38px;position:relative;z-index:1;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.4))}
.plush-doll.d2{font-size:22px;margin-left:-14px;align-self:flex-end;z-index:0}

/* ---- TV ---- */
.lr-tv{left:1.9%;top:59.5%;width:24%;height:30%}
.tv-screen{position:absolute;left:6%;right:6%;top:0;height:72%;background:#0c0c1a;border:6px solid #1a1228;border-radius:6px;
  box-shadow:0 0 0 4px #6b4a7a,5px 6px 0 rgba(0,0,0,.4);overflow:hidden;display:flex}
.tv-screen .tvcard{flex:1;height:100%;animation:tvflip 3.6s steps(1) infinite}
.tv-screen .tvcard:nth-child(1){background:linear-gradient(135deg,#9b8bff,#ff84bd)}
.tv-screen .tvcard:nth-child(2){background:linear-gradient(135deg,#8fb8ff,#bb9bff);animation-delay:1.2s}
.tv-screen .tvcard:nth-child(3){background:linear-gradient(135deg,#ffb892,#ff84bd);animation-delay:2.4s}
@keyframes tvflip{0%,30%{opacity:1}31%,100%{opacity:.25}}
.tv-scan{position:absolute;inset:0;background:repeating-linear-gradient(rgba(255,255,255,.06) 0 2px,transparent 2px 4px);pointer-events:none}
.tv-stand{position:absolute;left:31%;right:31%;top:70%;height:18%;background:#3a2750;border:3px solid #1a1228;border-top:0}
.lr-tv:before{content:"";position:absolute;left:16%;right:16%;bottom:4%;height:10%;background:#1a1228;border-radius:3px}

/* ---- sofa + people (中央舞台) ---- */
.lr-sofa{position:absolute;left:26.2%;top:59.2%;right:auto;bottom:auto;width:56%;height:22%;z-index:3}
.sofa-back{position:absolute;left:8%;right:8%;top:0;height:58%;background:#7c5bd6;border:4px solid #1a1228;border-radius:10px 10px 4px 4px;box-shadow:inset 0 -6px 0 rgba(0,0,0,.2)}
.sofa-seat{position:absolute;left:0;right:0;bottom:14%;height:42%;background:#8e6ce6;border:4px solid #1a1228;border-radius:8px;box-shadow:inset 0 4px 0 rgba(255,255,255,.12)}
.sofa-arm{position:absolute;bottom:10%;width:13%;height:50%;background:#6b4ac4;border:4px solid #1a1228;border-radius:8px}
.sofa-arm.l{left:-2%}.sofa-arm.r{right:-2%}
.lr-people{position:absolute;left:27.4%;top:48.4%;right:auto;bottom:auto;width:54%;height:28%;z-index:6;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:3px}
.lr-prow{display:flex;align-items:flex-end;justify-content:center;width:100%}
.lr-prow.back{gap:5%;z-index:1;margin-bottom:-15px}
.lr-prow.front{gap:7%;z-index:2}
.lr-prow.back .lr-person{--ps:54px}
.lr-prow.front .lr-person{--ps:54px}
/* 沙发上的抱枕小人 */
.lr-person{position:relative;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;
  width:var(--ps,46px);height:var(--ps,46px);background:var(--pc,#ff9ecb);border:3px solid #1a1228;border-radius:15px;
  box-shadow:inset 0 4px 0 rgba(255,255,255,.32),inset 0 -5px 0 rgba(0,0,0,.16),0 4px 7px rgba(0,0,0,.32),0 0 12px 2px var(--pc,#ff9ecb);
  animation:bob 2.6s ease-in-out infinite,personGlow 2.6s ease-in-out infinite;transition:transform .15s}
@keyframes personGlow{0%,100%{box-shadow:inset 0 4px 0 rgba(255,255,255,.32),inset 0 -5px 0 rgba(0,0,0,.16),0 4px 7px rgba(0,0,0,.32),0 0 8px 1px var(--pc,#ff9ecb)}50%{box-shadow:inset 0 4px 0 rgba(255,255,255,.32),inset 0 -5px 0 rgba(0,0,0,.16),0 4px 7px rgba(0,0,0,.32),0 0 16px 4px var(--pc,#ff9ecb)}}
.lr-person .pf{font-size:calc(var(--ps,46px) * .58);line-height:1;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.22))}
.lr-person:nth-child(2n){animation-delay:.4s}.lr-person:nth-child(3n){animation-delay:.8s}.lr-person:nth-child(4n){animation-delay:1.2s}
.lr-person:hover{transform:translateY(-8px) scale(1.1) rotate(-2deg);z-index:5}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.lr-person .pname{position:absolute;left:50%;bottom:100%;transform:translate(-50%,-4px);white-space:nowrap;font-size:7px;
  color:#1a1228;background:#d7ccff;border:2px solid #1a1228;padding:3px 5px;border-radius:3px;opacity:0;transition:.15s;box-shadow:2px 2px 0 rgba(0,0,0,.4)}
.lr-person:hover .pname{opacity:1;transform:translate(-50%,-8px)}
@media(hover:none){.lr-person .pname{display:none}}

/* ---- 椅子 (舞台道具) ---- */
.lr-chair{position:absolute;bottom:11%;width:8%;height:15%;z-index:5}
.lr-chair.l{left:15%}.lr-chair.r{right:15%}
.lr-chair .ch-back{position:absolute;left:18%;top:0;width:64%;height:42%;background:#6b4ac4;border:3px solid #1a1228;border-radius:4px 4px 2px 2px}
.lr-chair .ch-seat{position:absolute;left:5%;right:5%;top:40%;height:20%;background:#8e6ce6;border:3px solid #1a1228;border-radius:3px}
.lr-chair .ch-leg{position:absolute;bottom:0;width:10%;height:42%;background:#3a2750;border:2px solid #1a1228}
.lr-chair .ch-leg.a{left:14%}.lr-chair .ch-leg.b{right:14%}

/* ---- 麦克风架 (舞台道具) ---- */
.lr-mic{display:none}
.lr-mic.m1{left:32%}.lr-mic.m2{right:32%}
.lr-mic .mic-pole{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:22%;height:88%;background:#2a2140;border:2px solid #1a1228}
.lr-mic .mic-head{position:absolute;left:50%;top:-2%;transform:translateX(-50%);width:120%;aspect-ratio:1;background:#3a2750;border:3px solid #1a1228;border-radius:50%;box-shadow:inset 0 0 0 2px #6b4a7a}
.lr-mic:before{content:"";position:absolute;left:50%;bottom:-2px;transform:translateX(-50%);width:60%;height:6px;background:#1a1228;border-radius:2px}
@keyframes micglow{0%,100%{box-shadow:inset 0 0 0 2px #6b4a7a}50%{box-shadow:inset 0 0 0 2px #6b4a7a,0 0 10px #9b8bff}}

/* ---- coffee table (移到角落) ---- */
.lr-coffee{left:40.3%;top:86.9%;right:auto;bottom:auto;width:26%;height:13%;z-index:6}
.cof-table{position:absolute;left:0;right:0;top:34%;height:34%;background:#7a4d77;border:4px solid #1a1228;border-radius:5px;box-shadow:5px 5px 0 rgba(0,0,0,.3)}
.lr-coffee:before{content:"";position:absolute;left:10%;bottom:0;width:6%;height:40%;background:#3a2750;border:2px solid #1a1228}
.lr-coffee:after{content:"";position:absolute;right:10%;bottom:0;width:6%;height:40%;background:#3a2750;border:2px solid #1a1228}
.cof-cup{position:absolute;left:35%;top:12%;transform:translateX(-50%);font-size:27px;z-index:2;filter:drop-shadow(1px 2px 0 rgba(0,0,0,.4))}
.cof-cup .steam{position:absolute;left:40%;top:-8px;width:3px;height:10px;background:rgba(255,255,255,.5);border-radius:3px;animation:steam 1.8s ease-in-out infinite}
.cof-cup .steam.s2{left:58%;animation-delay:.9s}
/* 茶几上的手机（→ 官方·社媒）*/
.cof-phone{position:absolute;right:24%;top:38%;width:13%;height:24%;background:#15111f;border:2px solid #1a1228;
  border-radius:4px;transform:rotate(-12deg);z-index:1;box-shadow:1px 2px 0 rgba(0,0,0,.4);overflow:hidden}
.cof-phone .cp-scr{position:absolute;inset:2px;border-radius:2px;
  background:linear-gradient(150deg,#7c6bff,#ff84bd);box-shadow:inset 0 0 4px rgba(255,255,255,.4);
  animation:cpGlow 2.6s ease-in-out infinite}
@keyframes cpGlow{0%,100%{opacity:.78}50%{opacity:1}}
@keyframes steam{0%{opacity:0;transform:translateY(4px) scaleY(.6)}50%{opacity:.8}100%{opacity:0;transform:translateY(-8px) scaleY(1.2)}}

/* ---- floor lamp ---- */
.lr-lamp{position:absolute;right:4%;bottom:13%;width:10%;height:46%;z-index:2}
.lamp-glow{position:absolute;left:50%;top:-6%;transform:translateX(-50%);width:160%;height:34%;
  background:radial-gradient(closest-side,rgba(255,184,107,.5),transparent 70%);animation:breathe 3.4s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:.55}50%{opacity:1}}
.lamp-head{position:absolute;left:30%;top:2%;width:40%;height:14%;background:#ffcf8a;border:3px solid #1a1228;border-radius:6px 6px 2px 2px}
.lamp-pole{position:absolute;left:48%;top:16%;width:5%;height:70%;background:#3a2750;border:2px solid #1a1228}
.lamp-base{position:absolute;left:32%;bottom:0;width:36%;height:5%;background:#3a2750;border:3px solid #1a1228;border-radius:3px}

/* ---- rug ---- */
.lr-rug{position:absolute;left:29.5%;top:83.8%;right:auto;bottom:auto;width:46%;height:9%;z-index:1;
  background:repeating-linear-gradient(90deg,#5a3f6e 0 14px,#6b4a7a 14px 28px);border:4px solid #1a1228;border-radius:50%;opacity:.9}

/* ---- decor: wall clock（实时 · 时尚款）---- */
.lr-clock{position:absolute;left:33.1%;top:21.5%;width:5.6%;aspect-ratio:1;z-index:2;border-radius:50%;
  background:radial-gradient(circle at 50% 38%,#ffffff,#efe7ff 72%,#d9ccff 100%);
  border:3px solid #1a1228;box-shadow:0 0 0 3px #2a1f4d,4px 6px 0 rgba(0,0,0,.32),inset 0 2px 5px rgba(255,255,255,.7)}
/* 刻度环 */
.lr-clock:before{content:"";position:absolute;inset:13%;border-radius:50%;
  background:repeating-conic-gradient(#1a1228 0deg 2.4deg,transparent 2.4deg 30deg);
  -webkit-mask:radial-gradient(circle,transparent 0 78%,#000 80%,#000 100%);
          mask:radial-gradient(circle,transparent 0 78%,#000 80%,#000 100%);opacity:.55}
.lr-clock .ck-h,.lr-clock .ck-m,.lr-clock .ck-s{position:absolute;left:50%;bottom:50%;transform-origin:bottom center;border-radius:3px}
.lr-clock .ck-h{width:3px;height:24%;background:#1a1228;transform:translateX(-50%) rotate(0deg)}
.lr-clock .ck-m{width:2.5px;height:34%;background:#3a2768;transform:translateX(-50%) rotate(0deg)}
.lr-clock .ck-s{width:1.5px;height:38%;background:#ff3b6e;transform:translateX(-50%) rotate(0deg);box-shadow:0 0 4px rgba(255,59,110,.6)}
.lr-clock .ck-dot{position:absolute;left:50%;top:50%;width:7px;height:7px;background:#ff3b6e;border:1.5px solid #1a1228;border-radius:50%;transform:translate(-50%,-50%);z-index:2}
/* ---- decor: wall frame（移到右上墙，避开时钟）---- */
.lr-frame{position:absolute;left:31.8%;top:36.8%;width:7.5%;height:12%;z-index:2;padding:0;cursor:pointer;
  background:linear-gradient(180deg,#6fb6e6,#4f93cc);border:4px solid #fff6e6;outline:3px solid #1a1228;
  box-shadow:4px 5px 0 rgba(0,0,0,.3);overflow:hidden;transform:rotate(-3deg);transition:transform .18s,box-shadow .18s}
.lr-frame:hover{transform:rotate(-3deg) translateY(-3px) scale(1.05);box-shadow:6px 8px 0 rgba(0,0,0,.35)}
.lr-frame .map{position:absolute;inset:0;background:
  radial-gradient(ellipse 26% 30% at 24% 40%,#7fc26a 0 99%,transparent 100%),
  radial-gradient(ellipse 20% 26% at 52% 64%,#7fc26a 0 99%,transparent 100%),
  radial-gradient(ellipse 15% 20% at 74% 34%,#7fc26a 0 99%,transparent 100%),
  radial-gradient(ellipse 10% 14% at 86% 70%,#7fc26a 0 99%,transparent 100%)}
.lr-frame:after{content:"";position:absolute;left:0;right:0;top:0;bottom:0;pointer-events:none;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 1px,transparent 1px 7px),
  repeating-linear-gradient(0deg,rgba(255,255,255,.06) 0 1px,transparent 1px 7px)}
/* ---- decor: 作者签名小卡（便利贴彩蛋）---- */
.lr-sign{position:absolute;left:75.1%;top:47.5%;z-index:8;transform:rotate(-6deg);
  background:linear-gradient(160deg,#fff2a8,#ffd86b);color:#5a3a12;border:2px solid #1a1228;
  padding:6px 9px 7px;border-radius:3px;box-shadow:3px 4px 0 rgba(0,0,0,.32);text-align:center;line-height:1.2}
.lr-sign:before{content:"";position:absolute;left:50%;top:-7px;transform:translateX(-50%) rotate(2deg);
  width:34px;height:11px;background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.18)}
.lr-sign b{display:block;font-size:8px;font-weight:800;letter-spacing:.2px}
.lr-sign span{display:block;font-family:'Press Start 2P',monospace;font-size:7px;margin-top:3px;color:#b14a2a}
/* ---- decor: plant ---- */
.lr-plant{position:absolute;left:95.3%;top:92.2%;right:auto;bottom:auto;z-index:3;font-size:34px;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.4));
  animation:sway 4s ease-in-out infinite;transform-origin:bottom center}
@keyframes sway{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}
/* ---- decor: string lights ---- */
.lr-lights{position:absolute;left:0;right:0;top:2%;height:18px;z-index:2;display:flex;justify-content:space-around;align-items:flex-start}
.lr-lights i{width:7px;height:7px;border-radius:50%;margin-top:6px}
.lr-lights i:before{content:"";position:absolute;width:2px;height:6px;background:#1a1228;left:50%;top:-6px;transform:translateX(-50%)}
.lr-lights i:nth-child(1){background:#ff9bc7;box-shadow:0 0 8px #ff9bc7}
.lr-lights i:nth-child(2){background:#8fb8ff;box-shadow:0 0 8px #8fb8ff;animation-delay:.3s}
.lr-lights i:nth-child(3){background:#ffd27f;box-shadow:0 0 8px #ffd27f;animation-delay:.6s}
.lr-lights i:nth-child(4){background:#9b8bff;box-shadow:0 0 8px #9b8bff;animation-delay:.9s}
.lr-lights i:nth-child(5){background:#7fe0c0;box-shadow:0 0 8px #7fe0c0;animation-delay:1.2s}
.lr-lights i:nth-child(6){background:#ff9bc7;box-shadow:0 0 8px #ff9bc7;animation-delay:1.5s}
.lr-lights i:nth-child(7){background:#8fb8ff;box-shadow:0 0 8px #8fb8ff;animation-delay:1.8s}
.lr-lights i:nth-child(8){background:#ffd27f;box-shadow:0 0 8px #ffd27f;animation-delay:2.1s}
@keyframes twinkle{50%{opacity:.3}}

/* ---- 抱枕落在沙发上的接触阴影 ---- */
.lr-person:before{content:"";position:absolute;left:10%;right:10%;bottom:-6px;height:7px;border-radius:50%;
  background:rgba(0,0,0,.3);filter:blur(2px);z-index:-1}

/* ---- 沙发抱枕 ---- */
.lr-sofa .cushion{position:absolute;bottom:30%;width:11%;height:34%;border:4px solid #1a1228;border-radius:6px;
  box-shadow:inset 0 3px 0 rgba(255,255,255,.16);z-index:1}
.lr-sofa .cushion.c1{left:4%;background:#ff84bd;transform:rotate(-8deg)}
.lr-sofa .cushion.c2{right:4%;background:#8fb8ff;transform:rotate(8deg)}

/* ---- 流星 + 飞鸟 (窗外) ---- */
.lr-sky .shoot{position:absolute;width:32px;height:2px;background:linear-gradient(90deg,transparent,#fff);left:-20%;top:14%;
  transform:rotate(22deg);box-shadow:0 0 6px #fff;opacity:0;animation:shoot 7s ease-in infinite}
@keyframes shoot{0%{left:-20%;top:6%;opacity:0}6%{opacity:1}18%{left:85%;top:42%;opacity:0}100%{opacity:0}}
.lr-sky .bird{position:absolute;width:9px;height:5px;border-top:2px solid rgba(20,15,30,.65);border-radius:50% 50% 0 0;left:-12%}
.lr-sky .bird:before{content:"";position:absolute;left:90%;top:-1px;width:9px;height:5px;border-top:2px solid rgba(20,15,30,.65);border-radius:50% 50% 0 0}
.lr-sky .bird.b1{top:28%;animation:birdfly 20s linear infinite}
.lr-sky .bird.b2{top:36%;transform:scale(.75);animation:birdfly 26s linear infinite 6s}
@keyframes birdfly{0%{left:-12%}100%{left:122%}}

/* ---- 墙上海报 ---- */
.lr-poster{position:absolute;left:46.9%;top:25.3%;width:11%;height:22%;z-index:2;border-radius:9px;
  background:linear-gradient(160deg,#2a1f4d,#1a1228);padding:4px;display:flex;flex-direction:column;
  border:3px solid #ffe3b0;box-shadow:0 0 0 2px #1a1228,5px 7px 0 rgba(0,0,0,.35),0 0 18px rgba(255,150,200,.28);
  animation:posterGlow 3.4s ease-in-out infinite}
@keyframes posterGlow{0%,100%{box-shadow:0 0 0 2px #1a1228,5px 7px 0 rgba(0,0,0,.35),0 0 14px rgba(255,150,200,.22)}50%{box-shadow:0 0 0 2px #1a1228,5px 7px 0 rgba(0,0,0,.35),0 0 24px rgba(159,134,255,.55)}}
.lr-poster .po-img{flex:1;position:relative;overflow:hidden;border-radius:5px;
  background:linear-gradient(150deg,#9b8bff,#ff84bd 52%,#ffd27f);
  display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:1px 3px;padding:5px 4px}
.lr-poster .po-img:before{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(circle at 28% 18%,rgba(255,255,255,.55),transparent 42%)}
.lr-poster .po-img:after{content:"";position:absolute;top:-60%;left:-40%;width:36%;height:220%;z-index:1;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.65),transparent);transform:rotate(20deg);
  animation:posterShine 4.5s ease-in-out infinite}
@keyframes posterShine{0%,68%{left:-45%}100%{left:135%}}
.lr-poster .po-img i{position:relative;z-index:2;font-style:normal;font-size:11px;line-height:1;filter:drop-shadow(1px 1px 0 rgba(0,0,0,.35))}
/* 电脑版海报：动物分层错落，前大后小有纵深 */
@media(min-width:721px){
  .lr-poster .po-img{display:block;position:relative}
  .lr-poster .po-img i{position:absolute;filter:drop-shadow(1px 2px 0 rgba(0,0,0,.4))}
  .lr-poster .po-img i:nth-child(1){left:5%;top:9%;font-size:13px;z-index:2}
  .lr-poster .po-img i:nth-child(2){left:38%;top:4%;font-size:15px;z-index:3}
  .lr-poster .po-img i:nth-child(3){left:69%;top:10%;font-size:13px;z-index:2}
  .lr-poster .po-img i:nth-child(4){left:19%;top:37%;font-size:18px;z-index:4}
  .lr-poster .po-img i:nth-child(5){left:50%;top:34%;font-size:20px;z-index:5}
  .lr-poster .po-img i:nth-child(6){left:9%;top:62%;font-size:17px;z-index:4}
  .lr-poster .po-img i:nth-child(7){left:57%;top:63%;font-size:19px;z-index:6}
}
.lr-poster .po-cap{font-size:7px;font-weight:700;text-align:center;color:#2a1f4d;letter-spacing:1.5px;
  white-space:nowrap;margin-top:4px;border-radius:4px;padding:3px 0;background:linear-gradient(90deg,#ffe3b0,#ffd27f)}
.lr-poster .po-cap:before{content:"\2605";margin-right:5px;color:#ff5a98}
.lr-poster .po-cap:after{content:"\2605";margin-left:5px;color:#ff5a98}
/* 窗外随机蹦的成员动物 */
.lr-sky{overflow:hidden}
.lr-sky .sky-pop{position:absolute;z-index:1;font-size:18px;line-height:1;pointer-events:none;
  filter:drop-shadow(0 2px 3px rgba(0,0,0,.5));animation:skyPeek .9s forwards}
@keyframes skyPeek{0%{transform:translateY(120%);animation-timing-function:cubic-bezier(.12,.66,.3,1)}50%{transform:translateY(-150%);animation-timing-function:cubic-bezier(.7,0,.88,.34)}100%{transform:translateY(120%)}}
@media(prefers-reduced-motion:reduce){.lr-poster{animation:none}.lr-poster .po-img:after{display:none}.lr-sky .sky-pop{display:none}}
/* 窗户 / 海报：hover 前无文字，hover（或触屏点开）浮现半透明介绍层 */
.lr-panel{cursor:pointer}
.lr-reveal{position:absolute;inset:0;z-index:7;display:flex;flex-direction:column;justify-content:center;gap:4px;
  padding:8px 9px;overflow:auto;text-align:left;
  background:rgba(8,6,16,.78);box-shadow:inset 0 0 0 2px rgba(255,255,255,.12);
  opacity:0;pointer-events:none;transition:opacity .2s}
@media(hover:hover){.lr-info:hover .lr-reveal{opacity:1;pointer-events:auto}}
.lr-reveal b{font-size:9px;color:#fff;text-shadow:1px 1px 0 #1a1228}
.lr-reveal>b:first-child{margin-bottom:2px}
.lr-reveal p{margin:0;font-size:7px;line-height:1.55;color:#e7e1ff}
.lr-reveal p.zoo{color:#ffd6ec}
.lr-poster .lr-reveal{padding:6px 7px;gap:3px}
.lr-poster .lr-reveal p{font-size:6px;line-height:1.45}

/* ---- 应援灯牌 (右下角) ---- */
.lr-banner{position:absolute;left:82.4%;top:79%;right:auto;bottom:auto;width:14%;height:16%;z-index:5}
.lr-banner .bn-screen{position:absolute;left:0;right:0;top:0;height:56%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  background:linear-gradient(135deg,#2a1f4d,#3a2768);border:4px solid #1a1228;border-radius:5px;color:#ffd6ec;letter-spacing:1px;
  box-shadow:5px 5px 0 rgba(0,0,0,.3)}
.lr-banner .bn-screen i{font-style:normal;line-height:1;white-space:nowrap;text-align:center}
.lr-banner .bn-screen i:first-child{font-size:8px;font-weight:700}
.lr-banner .bn-screen i:last-child{font-size:6px;letter-spacing:1.5px;color:#ffb3d8;margin-top:5px}
@keyframes bnglow{0%,100%{box-shadow:0 0 10px rgba(255,132,189,.4),5px 5px 0 rgba(0,0,0,.3)}50%{box-shadow:0 0 22px rgba(255,132,189,.85),5px 5px 0 rgba(0,0,0,.3)}}
.lr-banner .bn-pole{position:absolute;left:47%;top:54%;width:6%;height:40%;background:#3a2750;border:2px solid #1a1228}
.lr-banner .bn-base{position:absolute;left:28%;bottom:0;width:44%;height:7%;background:#3a2750;border:3px solid #1a1228;border-radius:3px}

/* ---- 应援棒 (中央前) ---- */
.lr-sticks{position:absolute;left:20.2%;top:84.3%;right:auto;bottom:auto;width:9%;height:13%;z-index:5}
.lr-sticks .st-pot{position:absolute;left:32%;bottom:0;width:36%;height:32%;background:#5a3f6e;border:3px solid #1a1228;border-radius:3px}
.lr-sticks i{position:absolute;bottom:22%;width:7%;height:78%;border-radius:5px;transform-origin:bottom center}
.lr-sticks i:nth-child(1){left:36%;background:#ff84bd;box-shadow:0 0 8px #ff84bd;transform:rotate(-15deg)}
.lr-sticks i:nth-child(2){left:47%;background:#8fb8ff;box-shadow:0 0 8px #8fb8ff;transform:rotate(2deg);animation-delay:.4s}
.lr-sticks i:nth-child(3){left:58%;background:#ffd27f;box-shadow:0 0 8px #ffd27f;transform:rotate(15deg);animation-delay:.8s}
@keyframes stickglow{50%{filter:brightness(1.45)}}

/* ---- 地毯花纹 ---- */
.lr-rug:before{content:"";position:absolute;inset:16% 20%;border:3px solid rgba(255,214,236,.32);border-radius:50%;pointer-events:none}
.lr-rug:after{content:"";position:absolute;left:50%;top:50%;width:14px;height:14px;transform:translate(-50%,-50%) rotate(45deg);
  background:rgba(255,214,236,.38);border:2px solid rgba(26,18,40,.45);pointer-events:none}

/* 纯装饰退为背景层，弱化存在感，突出可点击与小人 */
.lr-clock,.lr-frame,.lr-plant,.lr-lights,.lr-poster,.lr-curtain{opacity:.82}
/* 错开可点击物件的微光节奏，避免齐闪显乱 */
.lr-shelf{animation-delay:.55s}.lr-plush{animation-delay:1.1s}.lr-tv{animation-delay:1.65s}.lr-coffee{animation-delay:2.2s}

/* ---- pixel-art pass: make the lobby read as an 8-bit room, not a soft gradient scene ---- */
body.is-home .aurora{display:none}
.lr-stage{background:#0b0711;--px-dark:#1a1228;--px-shadow:#0b0711;--wall:#2d2447;--wall2:#3a2d59;--floor:#241832;--floor2:#332246;--wood:#7a567d}
.lr-room{
  background:
    linear-gradient(90deg,rgba(0,0,0,.16),transparent 18%,transparent 82%,rgba(0,0,0,.2)),
    repeating-linear-gradient(90deg,rgba(255,255,255,.04) 0 1px,transparent 1px 8px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 8px),
    linear-gradient(var(--wall) 0 68%,var(--wood) 68% 70%,var(--floor) 70% 100%);
}
.lr-room:before{
  background:
    linear-gradient(180deg,transparent 0 68%,rgba(0,0,0,.18) 68% 100%),
    repeating-linear-gradient(90deg,transparent 0 7px,rgba(255,255,255,.03) 7px 8px);
  opacity:.9;
}
.lr-room:after{
  height:30%;
  background:
    repeating-linear-gradient(90deg,transparent 0 7px,rgba(0,0,0,.2) 7px 8px),
    repeating-linear-gradient(0deg,rgba(255,255,255,.05) 0 1px,transparent 1px 8px),
    linear-gradient(180deg,var(--floor2),var(--floor));
  opacity:1;
}
.lr-title{
  padding:10px 18px 12px;background:#211631;border:4px solid var(--px-dark);box-shadow:6px 6px 0 var(--px-shadow);
  text-shadow:3px 3px 0 #000,0 0 0 transparent;line-height:1.25;
}
.lr-title:before,.lr-title:after{content:"";position:absolute;top:50%;width:10px;height:10px;background:#ff9bc7;border:3px solid var(--px-dark);transform:translateY(-50%)}
.lr-title:before{left:-20px}.lr-title:after{right:-20px}
.lr-title em{margin-top:8px;color:#ffd27f;text-shadow:2px 2px 0 #000}
.lr-window,.lr-cal,.lr-shelf,.lr-plush:before,.tv-screen,.tv-stand,.lr-tv:before,.sofa-back,.sofa-seat,.sofa-arm,
.lr-chair .ch-back,.lr-chair .ch-seat,.cof-table,.cof-phone,.lamp-head,.lamp-base,.lr-frame,.lr-sign,.lr-banner .bn-screen,.lr-banner .bn-base,.lr-sticks .st-pot{
  border-radius:0;
  box-shadow:6px 6px 0 rgba(0,0,0,.42);
}
.lr-window{box-shadow:0 0 0 6px var(--wood),8px 8px 0 rgba(0,0,0,.45)}
.lr-sky{
  background:
    repeating-linear-gradient(90deg,transparent 0 7px,rgba(255,255,255,.04) 7px 8px),
    linear-gradient(#26315f 0 42%,#654073 42% 70%,#d97b78 70% 100%);
}
.lr-sky b{display:none}
.lr-sky .cloud{height:8px;border-radius:0;background:#f4e2ff;box-shadow:8px 0 0 #f4e2ff,16px 0 0 #f4e2ff,8px -8px 0 #f4e2ff}
.lr-sky .star{width:5px;height:5px;box-shadow:none}
.lr-sky .hill{height:22%;background:#232445;border-radius:0;clip-path:polygon(0 60%,18% 34%,34% 66%,54% 28%,76% 62%,100% 36%,100% 100%,0 100%)}
.lr-person{border-radius:0;box-shadow:inset 0 4px 0 rgba(255,255,255,.3),inset 0 -5px 0 rgba(0,0,0,.18),5px 5px 0 rgba(0,0,0,.38),0 0 0 3px rgba(255,255,255,.08)}
.lr-person:before{filter:none;border-radius:0;height:5px;background:rgba(0,0,0,.35)}
.lr-rug{border-radius:0;background:repeating-linear-gradient(90deg,#5a3f6e 0 16px,#7a567d 16px 32px);box-shadow:6px 6px 0 rgba(0,0,0,.35)}
.lr-rug:before,.lr-rug:after{border-radius:0}
.lr-clock{border-radius:0;background:#efe7ff;box-shadow:0 0 0 3px #2a1f4d,5px 5px 0 rgba(0,0,0,.38)}
.lr-clock:before{display:none}
.lamp-glow{display:none}
.lr-obj{transition:transform .12s;animation:objpulse 2.8s steps(2,end) infinite}
.lr-obj:hover{transform:translate(-2px,-6px);filter:drop-shadow(6px 6px 0 rgba(0,0,0,.42));}

/* ---- 小人游戏属性卡 ---- */
.lr-card{position:fixed;z-index:60;width:240px;pointer-events:none;opacity:0;transform:translateY(6px) scale(.96);
  transition:opacity .14s,transform .14s;font-family:'Press Start 2P',monospace;
  background:#16101f;border:3px solid #1a1228;border-radius:6px;
  box-shadow:6px 7px 0 rgba(0,0,0,.5),0 0 0 3px var(--cc,#9b8bff)}
.lr-card.show{opacity:1;transform:translateY(0) scale(1)}
.lr-card .lc-head{display:flex;align-items:center;gap:10px;padding:11px 12px;
  background:linear-gradient(120deg,var(--cc,#9b8bff),var(--cc2,#ff84bd));border-bottom:3px solid #1a1228}
.lr-card .lc-emoji{font-size:30px;filter:drop-shadow(1px 2px 0 rgba(0,0,0,.4))}
.lr-card .lc-name{font-size:13px;color:#fff;text-shadow:2px 2px 0 #1a1228;line-height:1.4}
.lr-card .lc-name small{display:block;font-size:7px;margin-top:5px;color:#2a1f3d;text-shadow:none;letter-spacing:.5px}
.lr-card .lc-body{padding:12px}
.lr-card .lc-line{font-size:7.5px;line-height:1.7;color:#c8bfff;margin-bottom:4px}
.lr-card .lc-line b{color:#fff}
.lr-card .lc-tag{display:inline-block;margin:6px 6px 2px 0;font-size:7px;color:#ffe9a8;border:2px solid #ffe9a8;padding:3px 6px;border-radius:3px}
.lr-card .lc-stats{margin-top:10px;display:grid;gap:6px}
.lr-card .lc-stat{display:grid;grid-template-columns:42px 1fr;align-items:center;gap:7px;font-size:6.5px;color:#9b93b3}
.lr-card .lc-bar{height:9px;background:#2a2140;border:2px solid #1a1228;border-radius:2px;overflow:hidden}
.lr-card .lc-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--cc,#9b8bff),var(--cc2,#ff84bd))}
.lr-card .lc-intro{margin-top:9px;font-family:'Noto Sans SC',sans-serif;font-size:11px;line-height:1.6;color:#d7ccff}

/* home full-bleed (no section padding) */
body.is-home .marquee{position:relative;z-index:6}
body.is-home .site-header{display:none}

@media(max-width:720px){
  .lr-stage{height:calc(100vh - 56px);min-height:480px;font-size:9px}
  .lr-title{font-size:16px;top:40px}
  .lr-window{width:34%;height:30%;top:11%}
  .lr-sky .sky-pop{font-size:13px}
  .lr-shelf{width:26%}
  .lr-tv{left:0.8%;top:69.4%;right:auto;bottom:auto;width:33%}
  .lr-sofa{left:24.3%;top:57.7%;right:auto;bottom:auto;width:72%}
  .lr-people{left:33.3%;top:43.9%;right:auto;bottom:auto;width:58%}
  .lr-prow.front .lr-person{--ps:42px}
  .lr-prow.back .lr-person{--ps:42px}
  .lr-prow.back{margin-bottom:-12px;gap:6%}
  .lr-chair.l{left:7%}.lr-chair.r{right:7%}
  .lr-mic.m1{left:28%}.lr-mic.m2{right:28%}
  .lr-poster{left:41.5%;top:38.5%;right:auto;bottom:auto;width:26%;height:16%}
  .lr-banner{left:72.6%;top:83.5%;right:auto;bottom:auto;width:21%;height:14%}
  .lr-banner .bn-screen i:first-child{font-size:7px}.lr-banner .bn-screen i:last-child{font-size:5px}
  .lr-plush{left:62.8%;top:81.6%;right:auto;bottom:auto}
  .lr-plant{left:88.4%;top:91%;right:auto;bottom:auto;font-size:28px}
  .lr-coffee{left:41.5%;top:76.2%;right:auto;bottom:auto;width:26%}
  .lr-cal{left:4.3%;top:45.9%;right:auto;bottom:auto;width:22%;height:17%}
  .lr-clock{left:42.5%;top:18.2%;right:auto;bottom:auto;width:9%}
  .lr-frame{left:53.9%;top:23.6%;right:auto;bottom:auto;width:13%;height:8%}
  .lr-rug{left:34.3%;top:84.4%;right:auto;bottom:auto}
  .lr-card{width:min(240px,86vw)}
}
/* 窄屏：进一步减负，避免拥挤 */
@media(max-width:480px){
  .lr-title{font-size:13px;top:36px}
  .lr-sticks,.lr-sign{display:none}
  .lr-prow.front .lr-person{--ps:36px}
  .lr-prow.back .lr-person{--ps:36px}
}

/* ============================================================
   页面切换动画 · page transitions
   ============================================================ */
.page-fx{position:fixed;inset:0;z-index:300;pointer-events:none;overflow:hidden}
/* —— 电视开机：上下黑条合拢 + 闪光 —— */
.fx-tv .fx-top,.fx-tv .fx-bot{position:absolute;left:0;right:0;height:56%;background:#05040b}
.fx-tv .fx-top{top:0;transform:translateY(-100%)}
.fx-tv .fx-bot{bottom:0;transform:translateY(100%)}
.fx-tv .fx-flash{position:absolute;left:0;right:0;top:50%;height:0;background:#fff;opacity:0;
  box-shadow:0 0 40px 12px rgba(255,255,255,.9);transform:translateY(-50%)}
.fx-tv.on .fx-top{animation:fxTvTop .6s cubic-bezier(.7,0,.3,1) forwards}
.fx-tv.on .fx-bot{animation:fxTvBot .6s cubic-bezier(.7,0,.3,1) forwards}
.fx-tv.on .fx-flash{animation:fxTvFlash .6s ease forwards}
@keyframes fxTvTop{0%{transform:translateY(-100%)}30%{transform:translateY(0)}35%{transform:translateY(0)}100%{transform:translateY(-100%)}}
@keyframes fxTvBot{0%{transform:translateY(100%)}30%{transform:translateY(0)}35%{transform:translateY(0)}100%{transform:translateY(100%)}}
@keyframes fxTvFlash{0%,22%{height:0;opacity:0}31%{height:100%;opacity:.95}34%{height:3px;opacity:1}45%{height:3px;opacity:.7}100%{height:3px;opacity:0}}
/* —— 角色选择：彩色斜扫 + VS 字 —— */
.fx-select .fx-wipe{position:absolute;inset:-20% -30%;background:linear-gradient(115deg,transparent 38%,#9b8bff 42%,#ff84bd 58%,transparent 62%);
  transform:translateX(-120%)}
.fx-select .fx-vs{position:absolute;inset:0;display:grid;place-items:center;font-family:'Poppins';font-weight:900;
  font-size:clamp(48px,12vw,120px);color:#fff;letter-spacing:2px;text-shadow:0 0 30px rgba(155,139,255,.9);opacity:0;transform:scale(.4)}
.fx-select.on .fx-wipe{animation:fxWipe .58s cubic-bezier(.6,0,.2,1) forwards}
.fx-select.on .fx-vs{animation:fxVs .58s ease forwards}
@keyframes fxWipe{0%{transform:translateX(-120%)}100%{transform:translateX(120%)}}
@keyframes fxVs{0%{opacity:0;transform:scale(.4)}38%{opacity:1;transform:scale(1.04)}62%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.12)}}

/* ============================================================
   专辑 = 电视机页 · NEXZ-TV
   ============================================================ */
.tv-wrap{max-width:1120px;margin:0 auto}
.tv-set{position:relative;background:linear-gradient(160deg,#2a2036,#1a1326);border:1px solid var(--line);
  border-radius:26px;padding:20px 20px 0;box-shadow:0 30px 70px -34px rgba(0,0,0,.85),inset 0 1px 0 rgba(255,255,255,.05)}
.tv-cabinet{display:flex;gap:16px;align-items:stretch}
.tv-frame{flex:1;min-width:0;position:relative;background:#0a0814;border-radius:16px;padding:14px;
  box-shadow:inset 0 0 0 3px rgba(255,255,255,.04),inset 0 0 50px rgba(0,0,0,.7)}
.tv-screen-big{position:relative;height:min(66vh,600px);overflow-y:auto;overflow-x:hidden;border-radius:10px;
  background:radial-gradient(120% 90% at 50% 0%,#13101f,#07060e 80%);
  box-shadow:inset 0 0 60px rgba(0,0,0,.85);scrollbar-width:thin;scrollbar-color:var(--accent) transparent;
  transition:filter .18s,opacity .18s,transform .18s}
.tv-screen-big::-webkit-scrollbar{width:8px}
.tv-screen-big::-webkit-scrollbar-thumb{background:rgba(155,139,255,.5);border-radius:8px}
.tv-screen-big:before{content:"";position:absolute;inset:0;z-index:5;pointer-events:none;border-radius:10px;
  background:repeating-linear-gradient(rgba(255,255,255,.035) 0 1px,transparent 1px 3px)}
.tv-screen-big.switching{filter:brightness(1.6) blur(2px) saturate(.4);opacity:.5;transform:scaleY(.985)}
.tv-screen-big.switching:after{content:"";position:absolute;inset:0;z-index:6;pointer-events:none;border-radius:10px;
  background:repeating-linear-gradient(90deg,rgba(255,255,255,.12) 0 2px,transparent 2px 5px);mix-blend-mode:screen;
  animation:tvStatic .18s steps(3) infinite}
@keyframes tvStatic{0%{transform:translateX(0)}50%{transform:translateX(-4px)}100%{transform:translateX(3px)}}
.tv-glass{position:absolute;inset:14px;border-radius:10px;pointer-events:none;
  background:linear-gradient(125deg,rgba(255,255,255,.1),transparent 30%,transparent 70%,rgba(255,255,255,.04))}
.tv-glass .tv-power{position:absolute;right:9px;bottom:-1px;width:7px;height:7px;border-radius:50%;
  background:#7fe0a0;box-shadow:0 0 8px 2px rgba(127,224,160,.8)}
.tv-foot{display:flex;align-items:center;gap:12px;padding:13px 6px 16px}
.tv-brand{font-family:'Press Start 2P',monospace;font-size:10px;color:#9b8bff;letter-spacing:1px}
.tv-vent{flex:1;height:8px;border-radius:4px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 3px,transparent 3px 7px)}
.tv-knob{width:20px;height:20px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#3a2d52,#15101f);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.06),0 2px 4px rgba(0,0,0,.5)}
/* 屏幕内容 */
.tvs{animation:tvsIn .42s cubic-bezier(.2,.7,.3,1)}
@keyframes tvsIn{0%{opacity:0;transform:translateY(10px) scale(.99)}100%{opacity:1;transform:none}}
.tvs .album-cover{min-height:150px;border-radius:0}
.tvs .ac-title{font-size:clamp(24px,4.4vw,38px)}
.tvs .album-body{padding:20px 22px 30px}
.tvs-cheer{padding:20px 20px 30px}
.tvs-cheer .cheer-base{margin-bottom:24px}
.tvs-cheer .link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:24px}
.tvs-note{color:var(--muted);font-size:11.5px;margin-top:18px;line-height:1.6}
/* 频道面板 · 嵌在电视机右侧木壳里（复古旋钮区）*/
.tv-channels{flex:0 0 178px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:min(66vh,600px);
  background:linear-gradient(160deg,#171120,#0c0914);border-radius:14px;padding:12px 10px;
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.04),inset 0 0 28px rgba(0,0,0,.7);scrollbar-width:thin;scrollbar-color:var(--accent) transparent}
.tv-channels::-webkit-scrollbar{width:6px}
.tv-channels::-webkit-scrollbar-thumb{background:rgba(155,139,255,.5);border-radius:6px}
.tv-ch-hd{font-family:'Press Start 2P',monospace;font-size:8px;letter-spacing:1px;color:#6b5e8f;text-align:center;padding:2px 0 6px}
.tv-ch{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:8px;text-align:left;cursor:pointer;
  background:rgba(25,20,38,.85);border:1px solid var(--line);border-radius:10px;padding:9px 10px;color:var(--ink);
  transition:transform .2s,border-color .2s,background .2s,box-shadow .2s}
.tv-ch:hover{transform:translateX(-2px);border-color:var(--accent)}
.tv-ch .ch-no{grid-row:1/3;align-self:center;font-family:'Press Start 2P',monospace;font-size:8px;color:var(--accent);
  padding:6px 6px;border:1px solid rgba(155,139,255,.4);border-radius:6px;background:rgba(155,139,255,.08)}
.tv-ch .ch-name{font-family:'Poppins';font-weight:700;font-size:12px;line-height:1.2;display:flex;align-items:center;flex-wrap:wrap;gap:3px 5px}
.tv-ch .ch-date{font-size:10px;color:var(--muted)}
.tv-ch.on{border-color:transparent;background:linear-gradient(120deg,var(--accent),var(--accent2));color:#fff;
  box-shadow:0 12px 30px -14px rgba(155,139,255,.8)}
.tv-ch.on .ch-no{color:#fff;border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.15)}
.tv-ch.on .ch-date{color:rgba(255,255,255,.85)}
/* 每首曲目「应援」组 */
.tl-grp.grp-cheer{background:rgba(255,132,189,.08);border-color:rgba(255,132,189,.32)}
.t-links .g-cheer{color:#ff84bd}
.tl.cheer,.tl.cheer-img{border-color:rgba(255,132,189,.45);color:#ffb6d6}
.play-btn.cheer{background:linear-gradient(120deg,#ff84bd,#ffb892);color:#2a1020;border-color:transparent;font-weight:700}
/* 未发售专辑（预告） */
.tv-ch.soon{border-style:dashed;opacity:.92}
.tv-ch .ch-name em{flex:0 0 auto;font-style:normal;font-family:'Press Start 2P',monospace;font-size:6.5px;color:#ffd27f;
  border:1px solid rgba(255,210,127,.5);border-radius:4px;padding:1px 3px}
.tv-ch.on .ch-name em{color:#fff;border-color:rgba(255,255,255,.6)}
.ac-soon{position:absolute;top:12px;right:12px;z-index:2;font-family:'Press Start 2P',monospace;font-size:8px;
  color:#2a1020;background:#ffd27f;padding:4px 7px;border-radius:6px;letter-spacing:1px}
.tvs.is-soon .album-cover{filter:saturate(.85)}
.play-btn.soon{background:rgba(255,210,127,.16);border-color:rgba(255,210,127,.5);color:#ffd27f;cursor:default}
.play-btn.ap:hover{border-color:#fc3c44;background:rgba(252,60,68,.14);color:#fff}
.track-list.upcoming .track{opacity:.78}
.t-soon{font-size:11px;color:var(--muted);white-space:nowrap}

/* ============================================================
   成员 = 角色选择页 · CHARACTER SELECT
   ============================================================ */
.char-select{display:grid;grid-template-columns:128px 1fr;gap:22px;align-items:start;max-width:1100px;margin:30px auto 0}
.cs-roster{display:flex;flex-direction:column;gap:10px;position:sticky;top:90px}
.cs-tab{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:12px 6px;border-radius:14px;
  background:rgba(19,16,30,.7);border:2px solid var(--line);color:var(--muted);
  transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}
.cs-tab:hover{transform:translateY(-2px);border-color:var(--c1,#9b8bff);color:var(--ink)}
.cst-emoji{font-size:30px;filter:grayscale(.5) brightness(.85);transition:filter .18s,transform .18s}
.cst-name{font-family:'Poppins';font-weight:700;font-size:12px}
.cs-tab.on{border-color:transparent;color:#fff;background:linear-gradient(150deg,var(--c1,#9b8bff),var(--c2,#ff84bd));
  box-shadow:0 12px 28px -12px var(--c1,#9b8bff);transform:translateY(-2px) scale(1.03)}
.cs-tab.on .cst-emoji{filter:none;transform:scale(1.15)}
.cs-panel{min-height:480px}
.csc{display:grid;grid-template-columns:300px 1fr;gap:0;border:1px solid var(--line);border-radius:22px;overflow:hidden;
  background:rgba(19,16,30,.72)}
.csc-portrait{position:relative;min-height:360px;padding:18px;display:flex;flex-direction:column;justify-content:flex-end;
  background:linear-gradient(160deg,var(--c1,#9b8bff),var(--c2,#ff84bd));overflow:hidden;
  animation:cscPortIn .5s cubic-bezier(.2,.7,.3,1)}
.csc-portrait:before{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 70% 15%,rgba(255,255,255,.3),transparent 60%),linear-gradient(transparent 45%,rgba(8,6,16,.55))}
.csc-idx{position:absolute;top:14px;left:16px;z-index:2;font-family:'Press Start 2P',monospace;font-size:12px;color:#fff;
  text-shadow:2px 2px 0 rgba(0,0,0,.3)}
.csc-wm{position:absolute;inset:0;z-index:0;display:grid;place-items:center;font-family:'Poppins';font-weight:900;
  font-size:64px;color:rgba(255,255,255,.14);letter-spacing:-2px;transform:rotate(-8deg)}
.csc-emoji{position:relative;z-index:1;align-self:center;margin:auto 0;font-size:120px;
  filter:drop-shadow(2px 6px 10px rgba(0,0,0,.35));animation:cscEmoji 3.5s ease-in-out infinite}
@keyframes cscEmoji{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.csc-mbti{position:relative;z-index:2;align-self:flex-start;font-family:'Press Start 2P',monospace;font-size:8px;color:#fff;
  padding:6px 9px;border-radius:999px;background:rgba(0,0,0,.28);letter-spacing:.5px}
.csc-info{padding:22px 24px 26px;animation:cscInfoIn .5s cubic-bezier(.2,.7,.3,1)}
.csc-info>h3{font-family:'Poppins';font-weight:900;font-size:28px;line-height:1.1}
.csc-info>h3 small{display:block;font-size:13px;font-weight:600;color:var(--muted);margin-top:4px}
.csc-zoo{display:flex;align-items:center;gap:10px;margin:10px 0 16px;font-size:13px}
.csc-zoo b{color:var(--accent)}.csc-zoo span{color:var(--muted)}
.csc-stats{display:grid;gap:9px;margin-bottom:18px}
.csc-stat{display:grid;grid-template-columns:54px 1fr 30px;align-items:center;gap:10px}
.csk{font-family:'Press Start 2P',monospace;font-size:8px;color:var(--muted)}
.csc-bar{height:11px;background:#221a35;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.csc-bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--c1,#9b8bff),var(--c2,#ff84bd));
  animation:cscBar .6s cubic-bezier(.2,.8,.3,1)}
@keyframes cscBar{0%{width:0!important}}
.csc-stat em{font-family:'Press Start 2P',monospace;font-size:9px;font-style:normal;color:var(--ink);text-align:right}
.csc-rows{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:16px}
.csc-rows>div{padding:11px 14px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.csc-rows>div:nth-child(2n){border-right:0}.csc-rows>div:nth-last-child(-n+2){border-bottom:0}
.csc-rows span{display:block;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.csc-rows b{font-family:'Poppins';font-weight:600;font-size:14px}
.csc-intro{font-size:14px;line-height:1.7;color:#d7ccff;margin-bottom:8px}
@keyframes cscPortIn{0%{opacity:0;transform:translateX(-26px)}100%{opacity:1;transform:none}}
@keyframes cscInfoIn{0%{opacity:0;transform:translateX(22px)}100%{opacity:1;transform:none}}

/* ---- 响应式：TV / 角色选择 ---- */
@media(max-width:860px){
  .tv-cabinet{flex-direction:column-reverse;gap:12px}
  .tv-channels{flex:0 0 auto;flex-direction:row;max-height:none;overflow-x:auto;overflow-y:hidden;padding:8px 8px}
  .tv-ch{flex:0 0 auto;min-width:128px}.tv-ch:hover{transform:translateY(-2px)}
  .tv-ch-hd{display:none}
  .tv-screen-big{height:min(70vh,560px)}
  .char-select{grid-template-columns:1fr}
  .cs-roster{flex-direction:row;position:static;overflow-x:auto;padding-bottom:6px;gap:8px}
  .cs-tab{flex:0 0 auto;min-width:78px}
  .csc{grid-template-columns:1fr}
  .csc-portrait{min-height:230px}
  .csc-emoji{font-size:88px}
}
@media(max-width:560px){
  .tv-set{padding:12px 12px 0;border-radius:18px}
  .tv-screen-big{height:min(64vh,460px)}
  .csc-info>h3{font-size:23px}
  .csc-rows{grid-template-columns:1fr}
  .csc-rows>div{border-right:0}
}
@media(prefers-reduced-motion:reduce){
  .page-fx{display:none}
  .tvs,.csc-portrait,.csc-info,.csc-emoji,.csc-bar i{animation:none}
}

/* ============================================================
   客厅信息浮层 · 窗户=关于NEXZ / 海报=NEXZOO
   ============================================================ */
.lr-info{cursor:pointer}
.lr-obj.lr-info .lr-tip:after{content:"· 查看简介";color:#b5651d;font-size:9px}
/* 窗户右上角信息角标 */
.lr-window .lr-badge{position:absolute;top:6px;right:6px;z-index:6;width:18px;height:18px;border-radius:50%;
  display:grid;place-items:center;font-size:11px;font-weight:700;color:#1a1228;background:#ffe9a8;
  border:2px solid #1a1228;box-shadow:2px 2px 0 rgba(0,0,0,.4);font-family:'Press Start 2P',monospace;line-height:1}
/* 遮罩（仅点击 pin 时） */
.lr-pop-back{position:fixed;inset:0;z-index:110;background:rgba(8,6,16,.6);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .2s}
.lr-pop-back.show{opacity:1;pointer-events:auto}
/* 信息卡：锚定在物件旁 hover 浮现（非居中浮窗）*/
.lr-pop{position:fixed;z-index:120;left:0;top:0;transform-origin:top left;transform:scale(.94);
  width:min(330px,calc(100vw - 28px));max-height:78vh;overflow-y:auto;opacity:0;pointer-events:none;
  background:#16101f;color:#e9e2ff;border:3px solid #1a1228;border-radius:10px;padding:18px 18px 20px;
  box-shadow:6px 8px 0 rgba(0,0,0,.5),0 0 0 3px var(--accent);transition:opacity .16s,transform .16s}
.lr-pop.show{opacity:1;pointer-events:auto;transform:scale(1)}
/* 无锚点时回退到居中 */
.lr-pop.center{left:50%;top:50%;transform-origin:center;transform:translate(-50%,-46%) scale(.94)}
.lr-pop.center.show{transform:translate(-50%,-50%) scale(1)}
.lr-pop h4{font-family:'Press Start 2P',monospace;font-size:13px;color:#fff;margin-bottom:14px;letter-spacing:.5px}
.lr-pop p{font-size:13.5px;line-height:1.7;color:#cfc6ee;margin-bottom:11px}
.lr-pop b{color:#fff}
.lr-pop .pop-facts{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-top:14px}
.lr-pop .pop-facts>div{padding:9px 12px;border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.lr-pop .pop-facts>div:nth-child(2n){border-right:0}
.lr-pop .pop-facts>div:nth-last-child(-n+2){border-bottom:0}
.lr-pop .pop-facts span{display:block;font-size:9.5px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);margin-bottom:3px}
.lr-pop .pop-facts b{font-family:'Poppins';font-weight:600;font-size:13px}
.lr-pop .pop-zoo{font-size:12.5px;color:#c8bfff;background:rgba(155,139,255,.08);border:1px solid var(--line);border-radius:8px;padding:10px 12px}
.lr-pop .pop-link{display:inline-block;margin-top:6px;font-size:12.5px;font-weight:600;color:#fff;
  background:linear-gradient(120deg,var(--accent),var(--accent2));padding:9px 16px;border-radius:999px;text-decoration:none}
.lr-pop .pop-link:hover{filter:brightness(1.1)}
.lr-pop-x{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;cursor:pointer;
  background:rgba(255,255,255,.1);border:1px solid var(--line);color:#fff;font-size:14px;line-height:1}
.lr-pop-x:hover{background:var(--accent);border-color:transparent}
@media(prefers-reduced-motion:reduce){.lr-pop{transition:none}}

/* ============ 物料 = 书架页 ============ */
.shelf-page .bookcase{max-width:1180px;margin:8px auto 0;padding:22px 22px 8px;
  background:
    linear-gradient(180deg,#3a2417,#2a190f);
  border:5px solid #1c1009;border-radius:10px;
  box-shadow:inset 0 0 0 4px #4a2f1c, inset 0 8px 22px rgba(0,0,0,.5),
    8px 8px 0 rgba(0,0,0,.35);
  position:relative}
.shelf-page .legend{max-width:1180px;margin:18px auto 4px;color:var(--muted);font-size:12.5px}
.shelf-page .legend b{color:var(--accent2)}
.shelf-unit{position:relative;margin-bottom:30px}
.shelf-unit:last-child{margin-bottom:14px}
.shelf-label{margin:0 0 16px;font-size:13px;letter-spacing:1px;color:#ffdca8;text-transform:none;
  display:inline-block;background:#1c1009;border:2px solid #5a3a22;border-radius:6px;
  padding:7px 14px;box-shadow:3px 3px 0 rgba(0,0,0,.4);font-weight:700}
.shelf-unit .content-grid, .shelf-unit .guest-list{margin-bottom:14px}
/* 木板 */
.shelf-plank{display:block;height:14px;border-radius:3px;
  background:linear-gradient(180deg,#6b4428,#3a2417);
  border:2px solid #1c1009;box-shadow:0 6px 12px rgba(0,0,0,.45),inset 0 2px 0 rgba(255,255,255,.12)}
/* 一本本书：内容直接印封面上（小开本，无翻页）*/
.shelf-page .content-grid{grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:18px 12px}
.book{position:relative;display:flex;flex-direction:column;min-height:188px;color:#fff;
  border-radius:3px 8px 8px 3px;padding:11px 11px 11px 17px;
  background:linear-gradient(150deg,var(--bc),var(--bc2));
  box-shadow:inset 10px 0 13px -9px rgba(0,0,0,.6), 4px 6px 14px rgba(0,0,0,.42);
  transition:transform .2s,box-shadow .2s}
.book:before{content:"";position:absolute;left:6px;top:0;bottom:0;width:2px;background:rgba(255,255,255,.4)}
.book:after{content:"";position:absolute;left:10px;top:0;bottom:0;width:1px;background:rgba(0,0,0,.18)}
.bk-tag{align-self:flex-start;font-size:8.5px;background:rgba(0,0,0,.32);padding:2px 7px;border-radius:999px;letter-spacing:.5px}
.bk-title{margin-top:8px;font-family:'Poppins';font-weight:800;font-size:13px;line-height:1.15;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.bk-cn{margin-top:3px;font-size:9px;color:rgba(255,255,255,.85);line-height:1.35}
.bk-desc{margin-top:7px;font-size:9px;line-height:1.45;color:rgba(255,255,255,.78);
  overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}
.bk-links{display:flex;gap:5px;margin-top:auto;padding-top:9px}
.bk-lk{flex:1;text-align:center;font-size:9.5px;font-weight:700;padding:5px 3px;border-radius:6px;
  text-decoration:none;background:rgba(0,0,0,.28);color:#fff;border:1px solid rgba(255,255,255,.25)}
.bk-lk.yt:hover{background:rgba(255,61,61,.55);border-color:#fff}
.bk-lk.bili:hover{background:rgba(0,174,236,.55);border-color:#fff}
.bk-lk.srch{border-style:dashed;opacity:.9}
@media(hover:hover){
  .book:hover{transform:translateY(-6px) rotate(-.6deg);box-shadow:inset 10px 0 13px -9px rgba(0,0,0,.6),6px 12px 22px rgba(0,0,0,.5)}
}
/* 节目客串 = 平铺叠放的「合上的书」（书脊朝外，一摞）*/
.shelf-page .guest-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:8px 10px}
.shelf-page .guest-row{position:relative;border:none;border-radius:15px 5px 5px 15px;
  background:linear-gradient(180deg,#f1e6cd 0 52%,#e3d2ad 52% 100%);color:#3a2417;
  padding:10px 14px 10px 34px;gap:12px;
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.14),inset 0 2px 0 rgba(255,255,255,.5),2px 4px 7px rgba(0,0,0,.34)}
/* 书脊：左侧圆弧状（横向渐变模拟圆柱书脊，左角大圆角）*/
.shelf-page .guest-row:before{content:"";position:absolute;left:0;top:0;bottom:0;width:18px;border-radius:15px 0 0 15px;
  background:linear-gradient(90deg,rgba(0,0,0,.4) 0,var(--spine,#8f2f49) 20%,
    color-mix(in srgb,var(--spine,#8f2f49) 62%,#fff) 50%,var(--spine,#8f2f49) 80%,rgba(0,0,0,.42) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.2),inset 0 -1px 0 rgba(0,0,0,.25)}
/* 书脊上的烫金压线（上下两道）*/
.shelf-page .guest-row:after{content:"";position:absolute;left:6px;top:9px;bottom:9px;width:6px;border-radius:3px;
  background:linear-gradient(180deg,transparent 0 12%,rgba(255,255,255,.32) 12% 16%,transparent 16% 84%,rgba(255,255,255,.32) 84% 88%,transparent 88%)}
.shelf-page .guest-row:nth-child(7n+1){--spine:#8f2f49}
.shelf-page .guest-row:nth-child(7n+2){--spine:#235e84}
.shelf-page .guest-row:nth-child(7n+3){--spine:#226b4c}
.shelf-page .guest-row:nth-child(7n+4){--spine:#9b5e22}
.shelf-page .guest-row:nth-child(7n+5){--spine:#5f3f9b}
.shelf-page .guest-row:nth-child(7n+6){--spine:#9b3a70}
.shelf-page .guest-row:nth-child(7n+7){--spine:#2c6184}
.shelf-page .guest-row .gr-date{color:#9b4f2c}
.shelf-page .guest-row .gr-main h4{color:#2a1a0e}
.shelf-page .guest-row .gr-mem{color:#7a5a3a}
.shelf-page .guest-row .gr-cn{color:#5a4128}
.shelf-page .guest-row .gr-lk.yt{background:rgba(177,40,40,.16);color:#a32525}
.shelf-page .guest-row .gr-lk.bili{background:rgba(0,120,170,.16);color:#1d6f93}
@media(hover:hover){
  .shelf-page .guest-row{transition:transform .16s,box-shadow .16s}
  .shelf-page .guest-row:hover{transform:translateX(4px);box-shadow:inset 0 -3px 0 rgba(0,0,0,.14),inset 0 2px 0 rgba(255,255,255,.5),5px 6px 11px rgba(0,0,0,.42)}
}

/* ============ 活动 = 全年日历页 ============ */
.cal-page .cal-legend{display:flex;flex-wrap:wrap;gap:8px 14px;justify-content:center;
  max-width:1100px;margin:4px auto 18px}
.cal-page .lg-i{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);
  background:var(--panel);border:1px solid var(--line);border-radius:999px;padding:4px 11px 4px 8px}
.cal-page .lg-i b{font-size:13px;line-height:1}
.cal-page .year-cal{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;
  max-width:1100px;margin:8px auto 24px}
.cal-page .cal-mon{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 12px 14px}
.cal-page .cal-mon.has-ev{border-color:rgba(255,132,189,.4);box-shadow:0 0 0 1px rgba(255,132,189,.15)}
.cal-page .cal-mon h4{font-family:'Poppins';font-size:14px;font-weight:800;letter-spacing:1px;margin-bottom:8px;color:var(--ink)}
.cal-page .cal-wk{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px;margin-bottom:4px}
.cal-page .cal-wk span{text-align:center;font-size:9px;color:var(--muted)}
.cal-page .cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px}
/* 普通日：只显示日期；有活动/生日的日子：直接显示图形（无方块）；方块只给今天 */
.cal-page .cal-d{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  border-radius:6px;background:none;border:none}
.cal-page .cal-d i{font-style:normal;font-size:10.5px;color:var(--muted);background:none}
.cal-page .cal-d u{display:none}
.cal-page .cal-d.empty{visibility:hidden}
/* 有标注的日子：图形占主体，日期缩到左上角 */
.cal-page .cal-d.hit{cursor:pointer;transition:transform .14s}
.cal-page .cal-d.hit i{position:absolute;left:2px;top:1px;font-size:8px;font-weight:700;color:var(--muted);opacity:.85}
.cal-page .cal-d.hit u{display:flex;align-items:center;justify-content:center;font-size:20px;text-decoration:none;line-height:1;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}
.cal-page .cal-d.both u:after{content:"🎂";font-size:11px;margin-left:-2px}
.cal-page .cal-d.hit:hover,.cal-page .cal-d.sel{transform:scale(1.22);z-index:2}
.cal-page .cal-d.sel u{filter:drop-shadow(0 0 6px var(--accent2)) drop-shadow(0 1px 2px rgba(0,0,0,.45))}
/* 今天：唯一的方块 */
.cal-page .cal-d.today{background:rgba(124,107,255,.14)}
.cal-page .cal-d.today:after{content:"";position:absolute;inset:0;border-radius:6px;
  border:2px solid var(--accent);pointer-events:none}
.cal-page .cal-d.today i{color:var(--ink);font-weight:700}

.cal-page .cal-detail{max-width:760px;margin:0 auto 8px;background:var(--panel);
  border:1px dashed var(--line);border-radius:16px;padding:10px 16px}
.cal-page .cd-hint{color:var(--muted);font-size:12.5px;text-align:center;letter-spacing:.5px}
.cal-page .cd-date{font-family:'Press Start 2P',monospace;font-size:13px;color:var(--accent2);
  margin-bottom:14px;letter-spacing:1px}
.cal-page .cd-empty{color:var(--muted);font-size:13px;text-align:center;padding:18px 0}
.cal-page .cd-item{display:flex;gap:14px;padding:12px 0;border-top:1px dashed var(--line)}
.cal-page .cd-item:first-of-type{border-top:none;padding-top:0}
.cal-page .cd-cat{flex:0 0 84px;display:flex;flex-direction:column;align-items:center;gap:3px;
  font-size:10px;color:var(--muted);text-align:center}
.cal-page .cd-cat b{font-size:24px;line-height:1}
.cal-page .cd-main{flex:1;min-width:0}
.cal-page .cd-main h4{font-size:15px;color:var(--ink);margin-bottom:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cal-page .cd-main p{font-size:12.5px;color:var(--muted);line-height:1.55}
.cal-page .cd-when{display:inline-block;margin-top:6px;font-size:11px;color:var(--accent2)}
.cal-page .cd-st{font-family:'Press Start 2P',monospace;font-size:7px;padding:3px 6px;border-radius:5px;letter-spacing:.5px}
.cal-page .cd-st.st-done{background:rgba(255,255,255,.08);color:var(--muted)}
.cal-page .cd-st.st-live{background:var(--accent);color:#fff;animation:pulseLive 1.4s infinite}
.cal-page .cd-st.st-next{background:rgba(255,210,127,.2);color:var(--accent2)}
@keyframes pulseLive{0%,100%{opacity:1}50%{opacity:.55}}
.cal-page .cd-lk{display:inline-block;margin-top:8px;font-size:12px;color:var(--accent2);
  text-decoration:none;border-bottom:1px solid rgba(255,210,127,.4)}
.cal-page .cd-lk:hover{color:var(--accent)}

/* ---- 活动便签弹窗（点日期弹出）---- */
.cal-note-back{position:fixed;inset:0;z-index:140;background:rgba(8,6,16,.62);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .2s}
.cal-note-back.show{opacity:1;pointer-events:auto}
.cal-note{position:fixed;z-index:150;left:50%;top:50%;transform:translate(-50%,-46%) rotate(-1.4deg) scale(.96);
  width:min(420px,calc(100vw - 32px));max-height:80vh;overflow-y:auto;opacity:0;pointer-events:none;
  background:linear-gradient(180deg,#fff7d6,#ffeeb0);color:#3a2a12;
  border:1px solid #d9b86b;border-radius:3px;padding:24px 22px 24px;
  box-shadow:0 18px 40px -12px rgba(0,0,0,.6),inset 0 0 0 1px rgba(255,255,255,.5);
  background-image:linear-gradient(180deg,#fff7d6,#ffeeb0),repeating-linear-gradient(180deg,transparent 0 27px,rgba(155,79,44,.12) 27px 28px);
  transition:opacity .18s,transform .18s}
.cal-note.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) rotate(-1.4deg) scale(1)}
.cal-note .cn-tape{position:absolute;left:50%;top:-12px;transform:translateX(-50%) rotate(-2deg);
  width:96px;height:24px;background:rgba(255,255,255,.42);border:1px solid rgba(0,0,0,.12);box-shadow:0 2px 4px rgba(0,0,0,.2)}
.cal-note .cn-x{position:absolute;top:9px;right:9px;width:28px;height:28px;border-radius:50%;cursor:pointer;z-index:2;
  background:rgba(0,0,0,.08);border:1px solid rgba(0,0,0,.2);color:#5a3a12;font-size:13px;line-height:1}
.cal-note .cn-x:hover{background:#e35d7b;color:#fff;border-color:transparent}
.cal-note .cd-date{font-family:'Press Start 2P',monospace;font-size:13px;color:#9b4f2c;margin:2px 0 14px;letter-spacing:1px}
.cal-note .cd-empty{color:#7a5a3a;font-size:13px;text-align:center;padding:18px 0}
.cal-note .cd-item{display:flex;gap:14px;padding:12px 0;border-top:1px dashed rgba(90,58,18,.3)}
.cal-note .cd-item:first-of-type{border-top:none;padding-top:0}
.cal-note .cd-cat{flex:0 0 70px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;color:#7a5a3a;text-align:center}
.cal-note .cd-cat b{font-size:24px;line-height:1}
.cal-note .cd-main{flex:1;min-width:0}
.cal-note .cd-main h4{font-size:15px;color:#2a1a0e;margin-bottom:5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cal-note .cd-main p{font-size:12.5px;color:#5a4128;line-height:1.55}
.cal-note .cd-when{display:inline-block;margin-top:6px;font-size:11px;color:#9b4f2c}
.cal-note .cd-st{font-family:'Press Start 2P',monospace;font-size:7px;padding:3px 6px;border-radius:5px;letter-spacing:.5px}
.cal-note .cd-st.st-done{background:rgba(0,0,0,.1);color:#7a5a3a}
.cal-note .cd-st.st-live{background:#e35d7b;color:#fff;animation:pulseLive 1.4s infinite}
.cal-note .cd-st.st-next{background:rgba(155,79,44,.18);color:#9b4f2c}
.cal-note .cd-lk{display:inline-block;margin-top:8px;font-size:12px;color:#9b4f2c;text-decoration:none;border-bottom:1px solid rgba(155,79,44,.45)}
.cal-note .cd-lk:hover{color:#e35d7b}
@media(prefers-reduced-motion:reduce){.cal-note{transition:none}}

/* ============ 周边 = 扭蛋机页（店名直接标扭蛋上）============ */
.gacha-page .gacha{display:flex;justify-content:center;max-width:1080px;margin:10px auto 0}
.gacha-machine{position:relative;width:100%;max-width:440px;background:linear-gradient(180deg,#231a44,#15102a);
  border:5px solid #0d0a1c;border-radius:26px;padding:22px 22px 20px;
  box-shadow:10px 10px 0 rgba(0,0,0,.35),inset 0 0 0 3px rgba(255,255,255,.05)}
.gm-top{display:block;text-align:center;font-family:'Press Start 2P',monospace;font-size:12px;
  color:var(--accent2);margin-bottom:16px;letter-spacing:1px;text-shadow:2px 2px 0 rgba(0,0,0,.4)}
.gm-dome{position:relative;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;
  gap:14px 16px;padding:74px 16px 26px;min-height:370px;border-radius:20px 20px 10px 10px;overflow:hidden;
  background:radial-gradient(circle at 42% 28%,rgba(255,255,255,.22),rgba(255,255,255,.05));
  border:4px solid #0d0a1c;box-shadow:inset 0 0 30px rgba(0,0,0,.4)}
.gm-dome:before{content:"";position:absolute;left:14%;top:8%;width:34%;height:30%;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);pointer-events:none}
.gm-cap{position:relative;z-index:1;flex:0 0 116px;height:116px;border-radius:50%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  text-decoration:none;text-align:center;
  background:radial-gradient(circle at 38% 30%,#fff 0 12%,var(--cap) 14% 52%,color-mix(in srgb,var(--cap) 65%,#000) 53%);
  box-shadow:inset -6px -6px 0 rgba(0,0,0,.18),0 4px 8px rgba(0,0,0,.35);
  animation:gmFloat 4.5s ease-in-out infinite;animation-delay:var(--d,0s);
  transition:transform .16s}
.gm-cap:before{content:"";position:absolute;left:0;right:0;top:50%;height:3px;background:rgba(0,0,0,.22)}
.gm-cap:hover{transform:scale(1.07) translateY(-4px);z-index:2}
.gm-cap .cap-ico{font-size:30px;line-height:1;filter:drop-shadow(0 2px 2px rgba(0,0,0,.3))}
.gm-cap .cap-name{font-family:'Poppins';font-weight:800;font-size:12.5px;letter-spacing:.2px;
  color:#1a1030;text-shadow:0 1px 0 rgba(255,255,255,.4);padding:0 6px}
@keyframes gmFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
.gm-body{position:relative;margin-top:14px;height:84px;border-radius:8px;
  background:linear-gradient(180deg,#2a1f4e,#15102a);border:4px solid #0d0a1c}
.gm-knob{position:absolute;left:50%;top:16px;transform:translateX(-50%);
  width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 40% 35%,#fff,#9b8bff);
  border:4px solid #0d0a1c;box-shadow:inset -3px -3px 0 rgba(0,0,0,.2)}
.gm-knob:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:5px;height:20px;border-radius:3px;background:#0d0a1c}
.gm-coinslot{position:absolute;right:18px;top:20px;width:8px;height:26px;border-radius:3px;
  background:#0d0a1c;box-shadow:inset 0 0 0 2px rgba(255,255,255,.06)}
.gm-slot{position:absolute;left:50%;bottom:10px;transform:translateX(-50%);width:64px;height:12px;
  border-radius:3px;background:#0d0a1c}
.gm-tray{position:relative;height:40px;margin-top:8px;border-radius:0 0 14px 14px;
  background:linear-gradient(180deg,#15102a,#0d0a1c);border:4px solid #0d0a1c;border-top:0}
.gm-tray-cap{position:absolute;left:50%;bottom:8px;transform:translateX(-50%);
  width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 38% 30%,#fff 0 14%,#ffd27f 15% 52%,#c79a4a 53%);
  box-shadow:inset -3px -3px 0 rgba(0,0,0,.2)}
.gm-tray-cap:before{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background:rgba(0,0,0,.25)}

/* ============ 通用主题过渡 FX（flip）============ */
.page-fx.fx-flip{
  position:fixed;inset:0;z-index:9998;pointer-events:none;overflow:hidden}
.fx-flip .fx-wipe{
  position:absolute;inset:0;transform:scaleX(0);transform-origin:left;
  background:linear-gradient(120deg,var(--fx1,#7a4a2d),var(--fx2,#2a190f))}
.fx-flip.on .fx-wipe{animation:fxGenWipe .58s cubic-bezier(.7,0,.3,1) forwards}
@keyframes fxGenWipe{0%{transform:scaleX(0);transform-origin:left}45%{transform:scaleX(1);transform-origin:left}
  55%{transform:scaleX(1);transform-origin:right}100%{transform:scaleX(0);transform-origin:right}}
.fx-badge{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.6);opacity:0;
  display:flex;flex-direction:column;align-items:center;gap:8px;color:#fff;
  font-family:'Press Start 2P',monospace;font-size:13px;letter-spacing:1px;text-shadow:2px 2px 0 rgba(0,0,0,.4)}
.fx-badge b{font-size:46px}
.on .fx-badge{animation:fxBadge .58s ease forwards}
@keyframes fxBadge{0%,18%{opacity:0;transform:translate(-50%,-50%) scale(.5)}
  40%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  70%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.1)}}

/* ===== 每页专属主题转场 ===== */
.fx-flash2{position:absolute;inset:0;background:#fff;opacity:0}

/* 物料：一本书从书架抽出 → 滑到中央 → 翻开铺满 */
.page-fx.fx-shelf{position:fixed;inset:0;z-index:9998;pointer-events:none;overflow:hidden;perspective:1100px}
.fx-shelf .bk{position:absolute;width:clamp(54px,6vw,90px);height:clamp(78px,8.6vw,128px);
  background:linear-gradient(135deg,#5cc8f0,#b9b3ff 52%,#ff5ba8);border:4px solid #0c0a1c;
  box-shadow:inset -7px 0 0 rgba(0,0,0,.22),6px 8px 0 rgba(0,0,0,.45),0 0 16px rgba(124,107,255,.6)}
.fx-shelf .cover{position:absolute;inset:0;transform:scaleX(0);transform-origin:center;image-rendering:pixelated;
  background:
    repeating-linear-gradient(90deg,rgba(255,255,255,.12) 0 6px,transparent 6px 14px),
    linear-gradient(120deg,#5cc8f0,#9b8bff 45%,#ff5ba8 80%,#ffd27f);
  box-shadow:inset 0 0 0 6px #0c0a1c}
.fx-shelf.on .bk{animation:bkSlide .78s cubic-bezier(.5,0,.2,1) forwards}
.fx-shelf.on .cover{animation:bkCover .78s ease forwards}
@keyframes bkSlide{0%{left:82%;top:26%;transform:rotate(10deg) scale(.55);opacity:0}
  18%{opacity:1}48%{left:calc(50% - 40px);top:42%;transform:rotate(0) scale(1)}
  64%{transform:perspective(900px) rotateY(-70deg) scale(1.2)}100%{opacity:0;transform:perspective(900px) rotateY(-110deg) scale(1.6)}}
@keyframes bkCover{0%,42%{transform:scaleX(0)}58%{transform:scaleX(1)}74%{transform:scaleX(1)}100%{transform:scaleX(0);transform-origin:center}}

/* 社媒：指纹解锁（指纹盘扫描点亮→打勾解锁）*/
.page-fx.fx-phone{position:fixed;inset:0;z-index:9998;pointer-events:none;overflow:hidden;
  background:#0a0a16;display:grid;place-items:center}
.fx-phone .fp{position:relative;width:96px;height:96px;border-radius:50%;border:4px solid #3a3f6a;overflow:hidden;
  background:repeating-radial-gradient(circle at 50% 58%,#7079b0 0 2px,#10121f 2px 6px);
  filter:grayscale(.85) brightness(.75)}
.fx-phone .fp-scan{position:absolute;left:0;right:0;top:50%;height:5px;margin-top:-2px;
  background:linear-gradient(90deg,transparent,#aab6ff,transparent);box-shadow:0 0 12px #8f9bff;opacity:0}
.fx-phone .fp-ok{position:absolute;font-size:50px;color:#7fe0a0;opacity:0;text-shadow:0 0 16px #7fe0a0}
.fx-phone.on .fp{animation:fpPad .66s ease forwards}
.fx-phone.on .fp-scan{animation:fpScan .66s ease forwards}
.fx-phone.on .fp-ok{animation:fpOk .66s ease forwards}
@keyframes fpPad{0%{filter:grayscale(.9) brightness(.7);box-shadow:0 0 0 rgba(143,155,255,0)}
  55%{filter:grayscale(0) brightness(1.1);box-shadow:0 0 26px 5px rgba(143,155,255,.8)}
  100%{filter:grayscale(0) brightness(1.2);box-shadow:0 0 44px 12px rgba(143,155,255,.4);opacity:.12;transform:scale(1.3)}}
@keyframes fpScan{0%,8%{opacity:0;transform:translateY(-46px)}22%{opacity:1}52%{opacity:1;transform:translateY(46px)}62%{opacity:0}100%{opacity:0}}
@keyframes fpOk{0%,56%{opacity:0;transform:scale(.4)}70%{opacity:1;transform:scale(1.15)}84%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.25)}}

/* 周边：扭蛋掉落→弹跳→裂开+闪光 */
.page-fx.fx-capsule{position:fixed;inset:0;z-index:9998;pointer-events:none;overflow:hidden;background:rgba(20,12,26,.0)}
.fx-capsule .cap-ball{position:absolute;left:50%;top:0;margin-left:-32px;font-size:64px;line-height:1;
  filter:drop-shadow(0 6px 6px rgba(0,0,0,.4))}
.fx-capsule .cap-l,.fx-capsule .cap-r{position:absolute;left:50%;top:44%;width:64px;height:32px;
  background:linear-gradient(180deg,#ffe08a,#f0a93a);border:4px solid #1a1228;opacity:0}
.fx-capsule .cap-l{margin-left:-32px;border-radius:32px 32px 0 0;transform-origin:bottom center}
.fx-capsule .cap-r{margin-left:-32px;border-radius:0 0 32px 32px;transform-origin:top center}
.fx-capsule.on .cap-ball{animation:capDrop .8s cubic-bezier(.45,0,.7,1) forwards}
.fx-capsule.on .cap-l{animation:capCrackL .8s ease forwards}
.fx-capsule.on .cap-r{animation:capCrackR .8s ease forwards}
.fx-capsule.on .fx-flash2{animation:capFlash .8s ease forwards}
@keyframes capDrop{0%{top:-12%}46%{top:42%}56%{top:36%}66%{top:42%;opacity:1}68%{opacity:0}100%{opacity:0}}
@keyframes capCrackL{0%,66%{opacity:0;transform:translateY(0) rotate(0)}70%{opacity:1}100%{opacity:0;transform:translate(-40px,-30px) rotate(-40deg)}}
@keyframes capCrackR{0%,66%{opacity:0;transform:translateY(0) rotate(0)}70%{opacity:1}100%{opacity:0;transform:translate(40px,40px) rotate(40deg)}}
@keyframes capFlash{0%,66%{opacity:0}70%{opacity:.9}100%{opacity:0}}

/* 活动：把墙上日历放大 → 过渡到活动日历页 */
.page-fx.fx-cal{position:fixed;inset:0;z-index:9998;pointer-events:none;overflow:hidden}
.fx-cal .cal-bg{position:absolute;inset:0;opacity:0;image-rendering:pixelated;
  background:
    repeating-linear-gradient(90deg,rgba(92,200,240,.1) 0 2px,transparent 2px 22px),
    repeating-linear-gradient(0deg,rgba(255,91,168,.08) 0 2px,transparent 2px 22px),
    linear-gradient(180deg,#3a2d6b,#16103a)}
.fx-cal.on .cal-bg{animation:czBg .82s ease forwards}
@keyframes czBg{0%{opacity:0}26%{opacity:1}72%{opacity:1}100%{opacity:0}}
.fx-cal .cal-zoom{position:absolute;left:50%;top:50%;width:min(360px,78vw);height:min(470px,72vh);
  transform:translate(-50%,-60%) scale(.14);transform-origin:center;image-rendering:pixelated;
  background:#fff6e6;border:5px solid #1a1228;box-shadow:8px 10px 0 rgba(0,0,0,.5);
  display:flex;flex-direction:column;overflow:hidden;opacity:0}
.fx-cal .cal-zoom b{display:block;background:#ff5b8e;color:#fff;font-family:'Press Start 2P',monospace;
  font-size:clamp(12px,2.4vw,22px);text-align:center;padding:11px 0;border-bottom:4px solid #1a1228;letter-spacing:2px}
.fx-cal .cz-grid{flex:1;display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:1fr;gap:3px;padding:8px}
.fx-cal .cz-grid i{background:#e9dcc4;border-radius:2px}
.fx-cal .cz-grid i.hit{background:#ff5b8e;box-shadow:0 0 0 2px #1a1228}
.fx-cal.on .cal-zoom{animation:czGrow .82s cubic-bezier(.4,0,.2,1) forwards}
@keyframes czGrow{0%{opacity:0;transform:translate(-50%,-60%) scale(.14)}
  16%{opacity:1}66%{transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1.14)}}

/* ============================================================
   Sitewide pixel pass
   ============================================================ */
:root{--px-ink:#f9f3ff;--px-muted:#b8adc9;--px-panel:#171020;--px-panel2:#21172e;--px-line:#090611;--px-hi:#ff9bc7;--px-blue:#8fb8ff;--px-gold:#ffd27f}
body:not(.is-home){background:
  repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 8px),
  repeating-linear-gradient(0deg,rgba(255,255,255,.022) 0 1px,transparent 1px 8px),
  #0c0a14}
body:not(.is-home) .aurora{display:none}
.site-header,.site-header.scrolled,body:not(.is-home) .site-header{
  background:#110b19;border-bottom:4px solid var(--px-line);box-shadow:0 6px 0 rgba(0,0,0,.35);backdrop-filter:none}
.logo{font-family:'Press Start 2P',monospace;font-size:15px;letter-spacing:1px;text-shadow:3px 3px 0 #000}
.nav a{font-family:'Press Start 2P',monospace;font-size:8px;letter-spacing:0;padding:7px 0;color:var(--px-muted)}
.nav a.cur,.nav a:hover{color:var(--px-gold);text-shadow:2px 2px 0 #000}
.nav-toggle{font-family:'Press Start 2P',monospace;border:3px solid var(--px-line);background:#21172e;color:#fff;box-shadow:4px 4px 0 #000}
section.page{background:
  repeating-linear-gradient(90deg,rgba(255,255,255,.03) 0 1px,transparent 1px 8px),
  repeating-linear-gradient(0deg,rgba(255,255,255,.022) 0 1px,transparent 1px 8px)}
.section.alt{background:
  repeating-linear-gradient(90deg,rgba(255,255,255,.035) 0 1px,transparent 1px 8px),
  linear-gradient(180deg,#151020,#100b19);border-top:4px solid var(--px-line);border-bottom:4px solid var(--px-line)}
.section-head{padding:18px 22px;background:#151020;border:4px solid var(--px-line);box-shadow:8px 8px 0 #000;margin-bottom:46px}
.sec-idx,.section-head h2,.sub-head,.shelf-label,.tv-brand,.gm-top{font-family:'Press Start 2P',monospace;letter-spacing:0}
.section-head h2{font-size:clamp(21px,3vw,34px);line-height:1.3;text-shadow:3px 3px 0 #000;color:#fff}
.section-head p,.note,.legend{color:var(--px-muted)}
.legend,.note code{border:3px solid var(--px-line);border-radius:0;background:#21172e;box-shadow:4px 4px 0 #000}
.album-card,.content-card,.link-card,.guest-row,.cheer-base,.cal-page .cal-detail,.lr-pop,.cal-note{
  border:4px solid var(--px-line);border-radius:0;background:#171020;box-shadow:8px 8px 0 rgba(0,0,0,.55)}
.album-card:hover,.content-card:hover,.link-card:hover{transform:translate(-2px,-4px);box-shadow:10px 12px 0 rgba(0,0,0,.6);border-color:var(--px-hi)}
.album-cover{border-radius:0;background:
  repeating-linear-gradient(90deg,rgba(0,0,0,.18) 0 4px,transparent 4px 8px),
  linear-gradient(150deg,var(--g1),var(--g2))}
.album-cover:before,.ac-disc{display:none}
.ac-type,.ac-soon,.cc-tag,.bk-tag,.csc-mbti,.cd-st,.tv-ch .ch-name em{border-radius:0;border:2px solid var(--px-line);box-shadow:3px 3px 0 rgba(0,0,0,.45)}
.play-btn,.tl,.gr-lk,.bk-lk,.cheer-body .links a,.lr-pop .pop-link,.cd-lk{
  border:3px solid var(--px-line);border-radius:0;background:#21172e;color:#f7efff;box-shadow:4px 4px 0 rgba(0,0,0,.45);font-family:'Press Start 2P',monospace;font-size:8px;letter-spacing:0}
.play-btn:hover,.tl:hover,.gr-lk:hover,.bk-lk:hover{transform:translate(-1px,-2px);box-shadow:5px 6px 0 rgba(0,0,0,.55)}
.track,.t-links .tl,.tl-grp{border-radius:0}
.tv-set,.tv-frame,.tv-screen-big,.tv-channels,.tv-ch,.char-select,.cs-roster,.cs-tab,.csc,.csc-portrait,.csc-rows,.csc-bar,.phone,.ph-screen,.ph-dock,.ai-tile,.bookcase,.book,.shelf-page .guest-row,.cal-page .cal-mon,.cal-page .cal-d,.gacha-machine,.gm-dome,.gm-body,.gm-cap,.gm-knob,.gm-tray,.gm-tray-cap{
  border-radius:0!important}
.tv-set,.char-select,.phone,.shelf-page .bookcase,.gacha-machine{
  border:6px solid var(--px-line);background:#171020;box-shadow:10px 10px 0 rgba(0,0,0,.58),inset 0 0 0 4px rgba(255,255,255,.04)}
.tv-frame,.tv-channels,.cs-roster,.csc,.ph-screen,.ph-dock,.gm-dome,.gm-body,.gm-tray{
  border:4px solid var(--px-line);box-shadow:6px 6px 0 rgba(0,0,0,.45);background:#100b19}
.tv-screen-big{border:4px solid #05030a;background:
  repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 2px,transparent 2px 5px),
  radial-gradient(120% 90% at 50% 0%,#171020,#06040a 82%)}
.tv-screen-big:before,.tv-glass{border-radius:0}
.tv-ch{border:3px solid var(--px-line);background:#21172e;box-shadow:4px 4px 0 rgba(0,0,0,.4)}
.tv-ch:hover{transform:translate(-2px,-2px)}
.tv-ch.on{background:#8f5bff;border-color:var(--px-line);box-shadow:5px 5px 0 #000}
.tv-ch .ch-no{border-radius:0;border:2px solid var(--px-line);background:#100b19}
.cs-roster{padding:10px}
.cs-tab{border:3px solid var(--px-line);background:#21172e;box-shadow:4px 4px 0 rgba(0,0,0,.45)}
.cs-tab.on{background:#8f5bff;box-shadow:5px 5px 0 #000}
.csc-portrait{background:
  repeating-linear-gradient(90deg,rgba(0,0,0,.16) 0 5px,transparent 5px 10px),
  linear-gradient(160deg,var(--c1,#9b8bff),var(--c2,#ff84bd))}
.csc-portrait:before{background:linear-gradient(transparent 45%,rgba(8,6,16,.55))}
.csc-emoji{filter:drop-shadow(5px 5px 0 rgba(0,0,0,.5));animation:cscEmoji 3.5s steps(2,end) infinite}
.csc-bar{border:3px solid var(--px-line);height:14px;background:#0b0711}
.csc-bar i{border-radius:0;background:linear-gradient(90deg,var(--c1,#9b8bff),var(--c2,#ff84bd))}
.csc-rows{border:3px solid var(--px-line)}
.phone-page .phone-wrap::before,.ai-tile::after{display:none}
.phone-page .phone{animation:none;background:#151020;padding:12px}
.ph-notch,.ph-home{border-radius:0;background:#090611}
.ai-tile{border:3px solid var(--px-line);background:var(--ac);box-shadow:4px 4px 0 rgba(0,0,0,.48),inset 0 4px 0 rgba(255,255,255,.2)}
.app-grid .app-ico{animation:appBob 3.2s steps(2,end) infinite}
.shelf-page .bookcase{background:#332112}
.shelf-label{border-radius:0;box-shadow:4px 4px 0 #000}
.book{border:3px solid #170d07;box-shadow:5px 7px 0 rgba(0,0,0,.5);background:linear-gradient(180deg,var(--bc),var(--bc2))}
.book:before{width:4px;background:rgba(255,255,255,.45)}.book:after{display:none}
.shelf-page .guest-row{border:3px solid #170d07;box-shadow:5px 5px 0 rgba(0,0,0,.45);background:#f1e6cd}
.shelf-page .guest-row:before,.shelf-page .guest-row:after{border-radius:0}
.cal-page .cal-mon{border:4px solid var(--px-line);background:#171020;box-shadow:6px 6px 0 rgba(0,0,0,.45)}
.cal-page .cal-mon.has-ev{box-shadow:6px 6px 0 rgba(0,0,0,.45),inset 0 0 0 3px rgba(255,155,199,.2)}
.cal-page .cal-mon h4{font-family:'Press Start 2P',monospace;font-size:11px}
.cal-page .cal-d{background:#100b19;border:2px solid rgba(255,255,255,.05)}
.cal-page .cal-d.hit{background:#21172e;border-color:var(--px-line);box-shadow:3px 3px 0 rgba(0,0,0,.42)}
.cal-page .cal-d.hit:hover,.cal-page .cal-d.sel{transform:translate(-1px,-2px) scale(1.08)}
.cal-page .cal-d.today:after{border-radius:0;border:3px solid var(--px-gold)}
.cal-note{background:#fff1a8;color:#2a1708;border-color:#170d07;box-shadow:8px 8px 0 rgba(0,0,0,.55)}
.cal-note .cn-x{border-radius:0;border:3px solid #170d07;box-shadow:3px 3px 0 rgba(0,0,0,.35)}
.gacha-machine,.gm-body,.gm-tray{background:#171020}
.gm-dome{background:
  repeating-linear-gradient(90deg,rgba(255,255,255,.08) 0 4px,transparent 4px 8px),
  #2a1f4e}
.gm-dome:before{display:none}
.gm-cap{border:3px solid var(--px-line);background:linear-gradient(180deg,#fff 0 18%,var(--cap) 18% 58%,color-mix(in srgb,var(--cap) 65%,#000) 58%);box-shadow:5px 5px 0 rgba(0,0,0,.45);animation:gmFloat 4.5s steps(2,end) infinite}
.gm-knob,.gm-tray-cap{background:#9b8bff;box-shadow:inset -5px -5px 0 rgba(0,0,0,.22),4px 4px 0 rgba(0,0,0,.42)}
.gm-coinslot,.gm-slot{border-radius:0}
.page-fx .fx-wipe,.fx-vs,.fx-badge{image-rendering:pixelated}

/* ---- Stardew pass: pixel texture stays, but curvature comes back ---- */
/* panels/cards: gentle pixel corner instead of razor square */
.album-card,.content-card,.link-card,.guest-row,.cheer-base,.cal-page .cal-detail,.lr-pop,.cal-note,
.section-head,.legend,.note code,.album-cover,.tv-set,.tv-frame,.tv-screen-big,.tv-channels,.tv-ch,
.char-select,.cs-roster,.cs-tab,.csc,.csc-portrait,.csc-rows,.phone,.ph-screen,.ph-dock,.ai-tile,
.bookcase,.book,.cal-page .cal-mon,.cal-page .cal-d,.gacha-machine,.gm-body,.gm-tray,
.play-btn,.tl,.gr-lk,.bk-lk,.lr-pop .pop-link,.cd-lk,.shelf-label,.cal-note .cn-x,
.ac-type,.ac-soon,.cc-tag,.bk-tag,.csc-mbti,.cd-st,.tv-ch .ch-name em,
.lr-window,.lr-cal,.lr-shelf,.lr-banner .bn-screen,.lr-banner .bn-base,.lr-rug{border-radius:5px!important}
/* genuinely round objects */
.gm-cap,.gm-knob,.gm-tray-cap,.lr-clock{border-radius:50%!important}
/* 沙发上的是抱枕，不是球：圆角方形 */
.lr-person{border-radius:34%!important}
.lr-person:before{border-radius:50%!important}
.gm-dome{border-radius:50% 50% 8px 8px / 58% 58% 8px 8px!important}
.lr-sky .cloud{border-radius:5px!important}

/* ===== 大屏自适应：客厅文字 / emoji / 摆件随视口缩放 ===== */
@media(min-width:721px){
  .lr-title{font-size:clamp(22px,3.1vw,50px)}
  .lr-title em{font-size:clamp(8px,1.05vw,17px)}
  .cal-month{font-size:clamp(8px,1vw,16px)}
  .cal-grid i{font-size:clamp(4px,.62vw,11px)}
  .shelf-row i b{font-size:clamp(4.5px,.66vw,12px)}
  .lr-poster .po-cap{font-size:clamp(6px,.8vw,14px)}
  .lr-sign{font-size:clamp(8px,1.05vw,16px)}
  .lr-banner .bn-screen i:first-child{font-size:clamp(7px,.95vw,17px)}
  .lr-banner .bn-screen i:last-child{font-size:clamp(5px,.66vw,12px)}
  .lr-prow.back .lr-person,.lr-prow.front .lr-person{--ps:clamp(40px,4.1vw,70px)}
  /* 抱枕以两行中线为轴缩放，不再从底排下移 */
  .lr-people{justify-content:center;top:55.7%}
  .lr-plush{left:79.6%;top:79.8%;right:auto;bottom:auto;width:clamp(80px,11vw,150px);height:clamp(80px,12vw,160px)}
  .lr-plush .plush-doll{font-size:clamp(34px,4.6vw,76px)}
  .lr-plush .plush-doll.d2{font-size:clamp(20px,2.7vw,46px);margin-left:clamp(-26px,-1.6vw,-12px)}
  /* 海报：大头海报，emoji 更大、错落有致 */
  .lr-poster{width:13%;height:25%}
  .lr-poster .po-img i:nth-child(1){left:3%;top:7%;font-size:clamp(13px,1.5vw,26px)}
  .lr-poster .po-img i:nth-child(2){left:38%;top:2%;font-size:clamp(16px,1.85vw,32px);z-index:3}
  .lr-poster .po-img i:nth-child(3){left:70%;top:8%;font-size:clamp(13px,1.5vw,26px)}
  .lr-poster .po-img i:nth-child(4){left:16%;top:38%;font-size:clamp(19px,2.2vw,40px);z-index:4}
  .lr-poster .po-img i:nth-child(5){left:48%;top:34%;font-size:clamp(22px,2.6vw,46px);z-index:5}
  .lr-poster .po-img i:nth-child(6){left:6%;top:64%;font-size:clamp(18px,2.1vw,38px);z-index:4}
  .lr-poster .po-img i:nth-child(7){left:56%;top:64%;font-size:clamp(21px,2.5vw,44px);z-index:6}
}
/* 小屏只显示前几本书，避免太挤 */
@media(max-width:720px){
  .lr-shelf .shelf-row i:nth-child(n+5){display:none}
}

/* ---- books: keep a book-like curve, spine rounded on the left ---- */
.book{border-radius:4px 9px 9px 4px!important}
.shelf-page .guest-row{border-radius:14px 6px 6px 14px!important;overflow:hidden}
.shelf-page .guest-row:before{border-radius:14px 0 0 14px!important}
.shelf-page .guest-row:after{border-radius:4px!important}

/* ---- retro CRT television ---- */
.tv-set{background:linear-gradient(165deg,#bb7d43,#894e24)!important;border:6px solid #46280f!important;
  box-shadow:10px 10px 0 rgba(0,0,0,.5),inset 0 0 0 4px rgba(255,222,176,.14)!important}
.tv-frame{background:#0c140d!important;border:5px solid #2a1a0c!important;
  box-shadow:inset 0 0 0 4px #d9c49a,7px 7px 0 rgba(0,0,0,.4)!important}
.tv-screen-big{background:radial-gradient(120% 90% at 50% 0%,#16331f,#050f0a 82%)!important}
.tv-brand{color:#ffe3b0!important}
.tv-knob{background:radial-gradient(circle at 36% 30%,#ecd2a3,#8a5a2c)!important;
  box-shadow:inset 0 0 0 2px rgba(0,0,0,.32),3px 3px 0 rgba(0,0,0,.4)!important}
.tv-vent{background:repeating-linear-gradient(90deg,#46280f 0 3px,transparent 3px 7px)!important}

/* ---- calendar: seasonal accents, weekend tint, livelier event days ---- */
.cal-page .cal-mon{position:relative;overflow:hidden;padding-top:16px!important}
.cal-page .cal-mon:before{content:"";position:absolute;left:0;right:0;top:0;height:6px;background:var(--mon,#9b8bff)}
.cal-page .cal-mon h4{color:var(--mon,#fff)!important;text-shadow:2px 2px 0 #000}
.cal-page .cal-mon:nth-child(1),.cal-page .cal-mon:nth-child(2),.cal-page .cal-mon:nth-child(12){--mon:#8fb8ff}
.cal-page .cal-mon:nth-child(3),.cal-page .cal-mon:nth-child(4),.cal-page .cal-mon:nth-child(5){--mon:#7fe0c0}
.cal-page .cal-mon:nth-child(6),.cal-page .cal-mon:nth-child(7),.cal-page .cal-mon:nth-child(8){--mon:#ffd27f}
.cal-page .cal-mon:nth-child(9),.cal-page .cal-mon:nth-child(10),.cal-page .cal-mon:nth-child(11){--mon:#ffb892}
.cal-page .cal-wk span:first-child{color:#ff9bc7}
.cal-page .cal-wk span:last-child{color:#8fb8ff}
.cal-page .cal-d.hit{background:rgba(255,255,255,.06)}
.cal-page .cal-d.hit i{color:var(--mon,#fff)}
.cal-page .cal-d.ev{box-shadow:inset 0 0 0 2px rgba(255,155,199,.5)}
.cal-page .cal-d.bday{box-shadow:inset 0 0 0 2px rgba(255,210,127,.55)}

/* ---- official/social: brighter phone + daytime pixel wallpaper ---- */
.phone-page .phone{background:linear-gradient(160deg,#7d6cae,#564980)!important;border-color:#2a2142!important;
  box-shadow:0 0 0 6px #2f2750,0 22px 46px -16px rgba(0,0,0,.6),inset 0 0 0 2px rgba(255,255,255,.1)!important;padding:13px 13px 11px!important}
.ph-screen{position:relative;overflow:hidden;
  background:linear-gradient(180deg,#8fd6ff 0 56%,#bfe9ff 56% 62%)!important}
.ph-wall{position:absolute;inset:0;z-index:0;pointer-events:none}
.pw-sun{position:absolute;right:15%;top:9%;width:34px;height:34px;border-radius:50%;background:#ffe27a;
  box-shadow:0 0 0 7px rgba(255,240,150,.35)}
.pw-cloud{position:absolute;height:9px;background:#fff;border-radius:6px;
  box-shadow:11px 0 0 -1px #fff,-11px 1px 0 -2px #fff,5px -7px 0 -1px #fff}
.pw-cloud.a{width:34px;top:18%;left:14%}.pw-cloud.b{width:24px;top:30%;left:60%}
.pw-mtn{position:absolute;left:0;right:0;bottom:28%;height:22%;background:#7088c0;
  clip-path:polygon(0 100%,12% 46%,24% 100%,38% 28%,52% 100%,64% 42%,80% 100%,92% 52%,100% 100%)}
.pw-grass{position:absolute;left:0;right:0;bottom:0;height:28%;background:linear-gradient(180deg,#86c95a,#5fa547)}
.pw-grass:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:#a3e472}
.pw-zoo{position:absolute;left:0;right:0;bottom:0;height:28%;pointer-events:none;overflow:hidden}
.pw-zoo i{position:absolute;left:0;bottom:32%;font-style:normal;font-size:16px;line-height:1;
  filter:drop-shadow(0 2px 1px rgba(0,0,0,.3));will-change:transform,left}
.ph-greet,.app-grid,.ph-dots{position:relative;z-index:1}
.ph-greet{color:#1f1540!important;text-shadow:0 1px 0 rgba(255,255,255,.4)}
.phone-page .ai-label{color:#1f1540;text-shadow:0 1px 0 rgba(255,255,255,.45)}
@media(prefers-reduced-motion:reduce){.pw-zoo i{animation:none}}

@media(max-width:860px){
  .cal-page .year-cal{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:560px){
  .cal-page .year-cal{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .cal-page .cal-mon{padding:9px 8px 10px}
  .cal-page .cal-d i{font-size:9.5px}
  .cal-page .cd-cat{flex-basis:64px}
  .shelf-page .bookcase{padding:14px 12px 6px}
  .gm-cap{flex-basis:96px;height:96px}
  .gm-cap .cap-ico{font-size:24px}
  .gm-cap .cap-name{font-size:11px}
  .gm-dome{padding:52px 14px 22px;min-height:300px}
}
@media(prefers-reduced-motion:reduce){
  .gm-cap{animation:none}
  .fx-shelf .fx-wipe,.fx-flip .fx-wipe,.fx-capsule .fx-wipe,.on .fx-badge{animation:none}
  .cal-page .cd-st.st-live{animation:none}
}

/* ===== 语言切换：小地球仪 + 菜单 ===== */
.lr-globe{position:absolute;left:6%;bottom:12%;z-index:8;background:none;border:0;padding:0;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;filter:drop-shadow(2px 3px 0 rgba(0,0,0,.42));transition:transform .18s}
.lr-globe:hover{transform:translateY(-3px) scale(1.08)}
.lr-globe .gl-ball{font-size:clamp(24px,2.7vw,48px);line-height:1;animation:globeSpin 7s linear infinite}
.lr-globe .gl-base{width:62%;height:5px;margin-top:-2px;background:#3a2750;border:2px solid #1a1228;border-radius:0 0 3px 3px}
@keyframes globeSpin{0%{transform:rotateY(0)}100%{transform:rotateY(360deg)}}
@media(prefers-reduced-motion:reduce){.lr-globe .gl-ball{animation:none}}
.lang-back{position:fixed;inset:0;z-index:200;background:rgba(8,6,16,.55);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .16s}
.lang-back.show{opacity:1;pointer-events:auto}
.lang-menu{position:fixed;left:50%;top:50%;transform:translate(-50%,-46%) scale(.96);z-index:210;
  opacity:0;pointer-events:none;transition:opacity .16s,transform .16s;
  display:flex;flex-direction:column;gap:8px;min-width:220px;padding:18px;
  background:#171020;border:4px solid var(--px-line,#090611);box-shadow:8px 8px 0 rgba(0,0,0,.55)}
.lang-menu.show{opacity:1;pointer-events:auto;transform:translate(-50%,-50%) scale(1)}
.lang-menu .lm-hd{font-family:'Press Start 2P',monospace;font-size:10px;color:#9b8bff;text-align:center;
  margin-bottom:6px;letter-spacing:1px}
.lang-menu button{font-family:'Poppins';font-weight:700;font-size:14px;color:#e9e2ff;cursor:pointer;text-align:left;
  padding:10px 14px;background:#21172e;border:3px solid var(--px-line,#090611);box-shadow:4px 4px 0 rgba(0,0,0,.45);
  transition:transform .12s,border-color .12s}
.lang-menu button:hover{transform:translate(-1px,-2px);border-color:#ff9bc7}
.lang-menu button.on{background:linear-gradient(120deg,#9b8bff,#ff84bd);color:#fff;border-color:transparent}
