:root{
  --bg:#0c0805;--bg2:#150e08;--bg3:#1e1510;
  --cream:#f0dfc8;--cream2:#d4c0a8;--muted:rgba(240,223,200,0.5);
  --gold:#c9932b;--gold2:#e8b84b;--pink:#c96882;--sage:#7aaa8a;--warm:#c97050;
  --glass:rgba(255,235,200,0.04);--glass-b:rgba(255,235,200,0.1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--cream);font-family:'Lato','Helvetica Neue','Arial',sans-serif;overflow-x:hidden;min-height:100vh;}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:9990;opacity:0.35;}

@font-face {
  font-family: 'YanMing';
  src: url('YanMing-Handwriting.woff2') format('woff2');
  font-display: swap;
}

/* ═══ STARS ═══ */
.stars-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden;}
/* Hide stars in press section */
#p-press .stars-canvas, body.press-active .stars-canvas{display:none;}
.star{position:absolute;border-radius:50%;background:#fff;animation:starTwinkle var(--dur,3s) ease-in-out var(--delay,0s) infinite alternate;}
@keyframes starTwinkle{
  0%{opacity:var(--lo,0.1);transform:scale(1);}
  100%{opacity:var(--hi,0.7);transform:scale(1.3);}
}
/* Shooting star */
.shooting-star{
  position:absolute;top:0;left:0;width:2px;height:2px;
  background:linear-gradient(90deg,var(--sc,rgba(255,255,255,0.9)),transparent);
  border-radius:50%;
  animation:shoot var(--sdur,3s) linear var(--sdelay,5s) infinite;
  opacity:0;
}
@keyframes shoot{
  0%  {opacity:0;transform:translate(var(--sx),var(--sy)) rotate(var(--srot)) scaleX(1);}
  5%  {opacity:1;}
  45% {opacity:0.85;transform:translate(calc(var(--sx) + var(--dx) * 0.8),calc(var(--sy) + var(--dy) * 0.8)) rotate(var(--srot)) scaleX(80);}
  65% {opacity:0;transform:translate(calc(var(--sx) + var(--dx)),calc(var(--sy) + var(--dy))) rotate(var(--srot)) scaleX(80);}
  66% {opacity:0;transform:translate(var(--sx),var(--sy)) rotate(var(--srot)) scaleX(1);}
  100%{opacity:0;transform:translate(var(--sx),var(--sy)) rotate(var(--srot)) scaleX(1);}
}


/* ═══ HOLIDAY SYSTEM ═══ */
#holiday-banner{position:fixed;top:72px;left:50%;transform:translateX(-50%);z-index:400;padding:3px 16px;white-space:nowrap;font-family:'Lora','Georgia',serif;font-style:italic;font-size:0.64rem;letter-spacing:0.1em;color:rgba(255,255,255,0.5);background:rgba(12,8,5,0.6);border-radius:20px;border:1px solid rgba(255,255,255,0.07);opacity:0;transition:opacity 1.5s ease;pointer-events:none;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);}
#holiday-banner.visible{opacity:1;}
#holiday-debug{position:fixed;bottom:180px;left:14px;z-index:999;background:#1a1008;border:1px solid rgba(201,147,43,0.3);border-radius:10px;padding:10px 12px;font-family:'Lato',sans-serif;display:none;min-width:158px;}
#holiday-debug.show{display:block;}
#holiday-debug .dbg-t{color:rgba(201,147,43,0.5);font-size:0.57rem;letter-spacing:0.15em;text-transform:uppercase;margin-bottom:7px;}
#holiday-debug button{display:block;width:100%;margin:3px 0;padding:5px 8px;background:rgba(201,147,43,0.08);border:1px solid rgba(201,147,43,0.18);border-radius:6px;color:#d4c0a8;font-size:0.62rem;cursor:pointer;text-align:left;}
#holiday-debug button.dbg-on{border-color:#c9932b;color:#e8b84b;background:rgba(201,147,43,0.2);}

/* NAV */
#main-nav{position:fixed;top:0;left:0;right:0;z-index:500;display:flex;align-items:center;justify-content:space-between;padding:16px 52px;background:rgba(12,8,5,0.96);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid rgba(201,147,43,0.12);}
.nav-logo{font-family:'Playfair Display','Georgia',serif;font-size:1.3rem;font-weight:500;color:var(--gold);text-decoration:none;display:flex;align-items:baseline;gap:10px;}
.nav-logo .zh{font-family:'Noto Serif SC','STSong','SimSun',serif;font-size:0.85rem;color:var(--muted);letter-spacing:0.2em;}
.nav-links{display:flex;gap:4px;list-style:none;align-items:center;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:0.7rem;letter-spacing:0.18em;text-transform:uppercase;padding:7px 12px;border-radius:6px;transition:all 0.2s;}
.nav-links a:hover,.nav-links a.active{color:var(--cream);background:var(--glass);}
.nav-links a.active{color:var(--gold2);}
.nav-links a.apk-link{color:var(--sage);border:1px solid rgba(122,170,138,0.25);font-size:0.65rem;}
.nav-links a.apk-link:hover{color:#a0d4b0;border-color:rgba(122,170,138,0.5);}
.nav-links a.studio-link{color:var(--warm);border:1px solid rgba(201,112,80,0.25);font-size:0.65rem;}
.nav-links a.studio-link:hover{color:#e8906a;border-color:rgba(201,112,80,0.5);}
#apk-toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(20px);z-index:600;background:rgba(30,21,16,0.97);border:1px solid rgba(122,170,138,0.3);border-radius:12px;padding:14px 24px;text-align:center;opacity:0;pointer-events:none;transition:all 0.35s;max-width:280px;}
#apk-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
#apk-toast .toast-icon{font-size:1.4rem;margin-bottom:6px;}
#apk-toast .toast-title{font-family:'Playfair Display','Georgia',serif;font-size:0.95rem;color:var(--sage);margin-bottom:3px;}
#apk-toast .toast-sub{font-size:0.7rem;color:var(--muted);line-height:1.5;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--cream2);transition:all 0.3s;}

/* PAGES */
.page{display:none;min-height:100vh;padding-top:70px;position:relative;z-index:1;}
.page.active{display:block;}
.page-inner{max-width:1100px;margin:0 auto;padding:60px 52px 150px;}
.page-header{margin-bottom:48px;}
.page-header .eyebrow{font-family:'Caveat','Comic Sans MS',cursive;font-size:1.1rem;color:var(--gold);margin-bottom:10px;}
.page-header h1{font-family:'Playfair Display','Georgia',serif;font-size:clamp(2rem,5vw,3.2rem);font-weight:500;line-height:1.1;}
.page-header h1 em{color:var(--pink);font-style:italic;}
.page-header p{margin-top:10px;font-size:0.88rem;color:var(--muted);max-width:480px;line-height:1.75;}

/* HOME */
#p-home{background:radial-gradient(ellipse 80% 60% at 50% 40%,rgba(201,147,43,0.05) 0%,transparent 70%);}
.home-hero{min-height:calc(100vh - 70px);display:grid;grid-template-columns:1fr 420px;align-items:center;gap:52px;padding:50px 52px;max-width:1200px;margin:0 auto;}
.hero-left{display:flex;flex-direction:column;align-items:flex-start;}
.hero-eyebrow{font-family:'Caveat','Comic Sans MS',cursive;font-size:1.05rem;color:var(--gold);margin-bottom:6px;opacity:0;animation:fadeUp 0.8s ease 0.2s forwards;}
.hero-zh-above{font-family:'Noto Serif SC','STSong','SimSun',serif;font-size:clamp(1rem,2.2vw,1.5rem);color:rgba(240,223,200,0.45);letter-spacing:0.55em;font-weight:300;margin-bottom:4px;opacity:0;animation:fadeUp 0.8s ease 0.35s forwards;}
.hero-name-block{position:relative;display:inline-block;opacity:0;animation:fadeUp 0.8s ease 0.5s forwards;}
.hero-title{font-family:'Playfair Display','Georgia',serif;font-size:clamp(4rem,9vw,7rem);font-weight:500;line-height:0.9;color:var(--cream);position:relative;z-index:2;}
.hero-title em{color:var(--gold2);font-style:italic;}
.name-light{position:absolute;top:50%;left:55%;transform:translate(-50%,-50%);width:320px;height:180px;pointer-events:none;z-index:1;}
.name-light::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 55% at 50% 50%,rgba(255,220,100,0.22) 0%,rgba(232,184,75,0.12) 35%,rgba(201,147,43,0.05) 60%,transparent 80%);border-radius:50%;filter:blur(14px);animation:lightBreathe 4s ease-in-out infinite alternate;will-change:opacity,transform;}
.name-light::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:70px;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(255,235,140,0.35) 0%,rgba(255,210,80,0.15) 45%,transparent 75%);border-radius:50%;filter:blur(6px);animation:lightBreathe 4s ease-in-out 1.2s infinite alternate;}
@keyframes lightBreathe{0%{opacity:0.7;transform:scale(0.93);}100%{opacity:1;transform:scale(1.07);}}
.name-sweep{position:absolute;top:0;left:-60%;width:50%;height:100%;background:linear-gradient(105deg,transparent 0%,rgba(255,235,150,0.05) 40%,rgba(255,228,100,0.18) 50%,rgba(255,235,150,0.05) 60%,transparent 100%);z-index:3;pointer-events:none;animation:nameSweep 6s ease-in-out 1.5s infinite;will-change:transform;}
@keyframes nameSweep{0%{transform:translateX(0%);opacity:0;}8%{opacity:1;}65%{transform:translateX(340%);opacity:1;}66%{opacity:0;}100%{transform:translateX(340%);opacity:0;}}
.hero-status{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-size:0.68rem;letter-spacing:0.06em;font-family:'Lato',sans-serif;color:rgba(240,223,200,0.42);opacity:0;animation:fadeUp 0.8s ease 1s forwards;}
.hero-status-dot{width:6px;height:6px;border-radius:50%;background:#7aaa8a;flex-shrink:0;animation:statusPulse 2.5s ease-in-out infinite;}
.hero-status-dot.off{background:rgba(240,223,200,0.2);animation:none;}
@keyframes statusPulse{0%,100%{box-shadow:0 0 0 0 rgba(122,170,138,0.5);}50%{box-shadow:0 0 0 5px rgba(122,170,138,0);}}
.hero-welcome{margin-top:14px;font-family:'Caveat','Comic Sans MS',cursive;font-size:1rem;color:rgba(240,223,200,0.4);letter-spacing:0.06em;line-height:1.7;opacity:0;animation:fadeUp 0.8s ease 0.7s forwards;}
.hero-roles{display:flex;flex-wrap:wrap;gap:8px;margin-top:20px;opacity:0;animation:fadeUp 0.8s ease 0.85s forwards;}
.role-tag{font-size:0.67rem;letter-spacing:0.22em;text-transform:uppercase;padding:6px 14px;border-radius:20px;border:1px solid rgba(201,147,43,0.25);color:var(--cream2);background:rgba(201,147,43,0.06);}
.hero-bio{margin-top:20px;font-size:0.93rem;line-height:1.85;color:var(--muted);max-width:480px;opacity:0;animation:fadeUp 0.8s ease 1s forwards;}
.hero-bio strong{color:var(--cream2);}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px;opacity:0;animation:fadeUp 0.8s ease 1.1s forwards;}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}

.hero-right{display:flex;flex-direction:column;gap:18px;}
.featured-card{background:var(--bg3);border:1px solid rgba(201,147,43,0.15);border-radius:16px;padding:26px;position:relative;overflow:hidden;}
.featured-card::before{content:'';position:absolute;top:0;right:0;width:180px;height:180px;background:radial-gradient(circle,rgba(201,147,43,0.07),transparent 70%);pointer-events:none;}
.fc-label{font-size:0.58rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.fc-label::after{content:'';flex:1;height:1px;background:rgba(201,147,43,0.2);}
.fc-title{font-family:'Playfair Display','Georgia',serif;font-size:1.5rem;font-weight:500;margin-bottom:6px;}
.fc-desc{font-size:0.8rem;color:var(--muted);line-height:1.7;margin-bottom:18px;}
.fc-platforms{display:flex;gap:7px;flex-wrap:wrap;}
.fc-plat{font-size:0.62rem;letter-spacing:0.12em;padding:5px 11px;border-radius:20px;background:rgba(201,147,43,0.08);border:1px solid rgba(201,147,43,0.2);color:var(--cream2);text-decoration:none;transition:all 0.2s;}
.fc-plat:hover{background:rgba(201,147,43,0.18);color:var(--gold);}
.activity-card{background:var(--bg3);border:1px solid var(--glass-b);border-radius:16px;padding:20px 24px;}
.activity-title{font-size:0.62rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--muted);margin-bottom:12px;}
.activity-list{display:flex;flex-direction:column;gap:9px;}
.activity-item{display:flex;align-items:center;gap:11px;font-size:0.8rem;color:var(--cream2);}
.activity-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;}
.activity-date{margin-left:auto;font-size:0.68rem;color:var(--muted);white-space:nowrap;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;padding:12px 26px;border-radius:8px;text-decoration:none;cursor:pointer;border:none;transition:all 0.28s;font-weight:700;}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--warm));color:#0c0805;box-shadow:0 4px 24px rgba(201,147,43,0.25);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(201,147,43,0.4);}
.btn-ghost{background:transparent;color:var(--cream2);border:1px solid var(--glass-b);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);}
.btn-ghost:hover{border-color:var(--gold2);color:var(--gold2);}

/* GIFT SONG */
.gift-song-block{margin-bottom:40px;}
.gift-song-card{background:linear-gradient(135deg,rgba(201,112,80,0.04),rgba(122,170,138,0.03));border:1px solid rgba(201,112,80,0.18);border-radius:18px;overflow:hidden;cursor:pointer;transition:border-color 0.3s;}
.gift-song-card:hover{border-color:rgba(201,112,80,0.35);}
.gift-song-top{display:flex;align-items:center;gap:16px;padding:22px 26px;}
.gift-icon{font-size:1.6rem;flex-shrink:0;}
.gift-info{flex:1;}
.gift-title{font-family:'Playfair Display','Georgia',serif;font-size:1.15rem;color:var(--cream);margin-bottom:4px;}
.gift-sub{font-size:0.68rem;color:var(--muted);font-style:italic;}
/* Open state for gift song */
#song-7.open .gift-song-card .song-lyrics-wrap{max-height:3000px;}
#song-7.open .gift-song-card .song-toggle{transform:rotate(180deg);}

/* ALBUM BLOCK */
.album-block{margin-bottom:48px;}
.album-header{display:flex;align-items:center;gap:22px;padding:20px 0 24px;cursor:pointer;border-bottom:1px solid rgba(255,255,255,0.05);margin-bottom:24px;}
.album-cover-wrap{position:relative;flex-shrink:0;}
.album-cover{width:90px;height:90px;border-radius:10px;object-fit:cover;display:block;box-shadow:0 8px 32px rgba(0,0,0,0.5);}
.album-cover-glow{position:absolute;inset:-4px;border-radius:14px;background:radial-gradient(circle,rgba(201,112,80,0.25),transparent 70%);pointer-events:none;z-index:-1;}
.album-info{flex:1;}
.album-eyebrow{font-family:'Lato',sans-serif;font-size:0.55rem;letter-spacing:0.3em;text-transform:uppercase;color:rgba(201,112,80,0.5);margin-bottom:5px;}
.album-title{font-family:'Playfair Display','Georgia',serif;font-size:1.4rem;color:var(--cream);font-weight:500;margin-bottom:4px;}
.album-meta{font-size:0.65rem;color:var(--muted);letter-spacing:0.08em;margin-bottom:8px;}
.album-toggle-hint{font-size:0.6rem;letter-spacing:0.15em;color:rgba(201,147,43,0.4);text-transform:uppercase;transition:color 0.2s;}
.album-header:hover .album-toggle-hint{color:rgba(201,147,43,0.7);}
.album-songs{overflow:hidden;transition:max-height 0.6s cubic-bezier(0.4,0,0.2,1);}
.album-songs.collapsed{max-height:0;}

/* LYRICS */
.lyrics-page-deco{position:absolute;top:80px;right:52px;opacity:0.08;pointer-events:none;transform:rotate(-12deg);z-index:0;}
.songs-list{display:flex;flex-direction:column;gap:14px;position:relative;z-index:1;}
.song-item{background:var(--bg3);border:1px solid var(--glass-b);border-radius:14px;overflow:hidden;transition:border-color 0.3s,box-shadow 0.3s;}
.song-item:hover{border-color:rgba(201,147,43,0.28);box-shadow:0 6px 30px rgba(0,0,0,0.28);}
.song-header{display:flex;align-items:center;padding:20px 26px;cursor:pointer;gap:14px;}
.song-num{font-family:'Playfair Display','Georgia',serif;font-size:1.7rem;font-weight:400;color:rgba(201,147,43,0.2);min-width:32px;}
.song-info{flex:1;}
.song-name{font-family:'Playfair Display','Georgia',serif;font-size:1.2rem;font-weight:500;margin-bottom:4px;}
.song-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.song-badge{font-size:0.57rem;letter-spacing:0.18em;text-transform:uppercase;padding:3px 9px;border-radius:12px;font-weight:700;}
.badge-released{background:rgba(122,170,138,0.15);color:var(--sage);border:1px solid rgba(122,170,138,0.3);}
.badge-active{background:rgba(201,104,130,0.12);color:var(--pink);border:1px solid rgba(201,104,130,0.3);}
.badge-held{background:rgba(201,147,43,0.1);color:var(--gold);border:1px solid rgba(201,147,43,0.25);}
.badge-album{background:rgba(201,112,80,0.1);color:var(--warm);border:1px solid rgba(201,112,80,0.25);}
.song-desc-short{font-size:0.76rem;color:var(--muted);margin-top:2px;}
.song-toggle{font-size:1.1rem;color:var(--muted);transition:transform 0.3s;flex-shrink:0;}
.song-item.open .song-toggle{transform:rotate(180deg);}
.song-lyrics-wrap{max-height:0;overflow:hidden;transition:max-height 0.5s cubic-bezier(0.4,0,0.2,1);}
.song-item.open .song-lyrics-wrap{max-height:3000px;}

/* ── Journal / Notebook aesthetic ── */
.song-lyrics-inner{
  padding:28px 24px 28px 24px;
  border-top:1px solid var(--glass-b);
  background:linear-gradient(160deg,#1c1409 0%,#150f06 100%);
  border-radius:0 0 14px 14px;
  position:relative;
  overflow:hidden;
}
/* Left ruled margin line — like a notebook */
.song-lyrics-inner::before{
  content:'';
  position:absolute;
  top:0;bottom:0;left:48px;
  width:1px;
  background:rgba(201,147,43,0.12);
  pointer-events:none;
}
/* Faint horizontal lines — ruled paper */
.song-lyrics-inner::after{
  content:'';
  position:absolute;
  inset:0;
  background-image:repeating-linear-gradient(
    to bottom,
    transparent 0px,
    transparent 31px,
    rgba(201,147,43,0.04) 31px,
    rgba(201,147,43,0.04) 32px
  );
  pointer-events:none;
}

.lyrics-section{margin-bottom:22px;position:relative;z-index:1;padding-left:62px;}
.lyrics-section-label{
  font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;
  color:rgba(201,147,43,0.5);margin-bottom:6px;
  font-family:'Lato','Helvetica Neue','Arial',sans-serif;
}
.lyrics-text{
  font-family:'Lora','Georgia',serif;
  font-size:1rem;
  line-height:2;
  color:rgba(240,223,200,0.82);
  white-space:pre-wrap;
  letter-spacing:0.01em;
}
.lyrics-locked{position:relative;overflow:hidden;border-radius:8px;min-height:200px;}
.lyrics-locked .lyrics-text{filter:blur(9px);user-select:none;pointer-events:none;opacity:0.32;min-height:180px;}
.lyrics-lock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:2;background:rgba(12,8,5,0.15);border-radius:8px;}
.lock-icon{font-size:1.8rem;}
/* TEASER */
.lt{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:3;padding:0 24px;}
.lt-fade-top{position:absolute;top:0;left:0;right:0;height:42%;background:linear-gradient(to bottom,rgba(18,12,7,0.97) 0%,rgba(18,12,7,0.7) 55%,transparent 100%);z-index:1;}
.lt-fade-bot{position:absolute;bottom:0;left:0;right:0;height:42%;background:linear-gradient(to top,rgba(18,12,7,0.97) 0%,rgba(18,12,7,0.7) 55%,transparent 100%);z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:14px;gap:3px;}
.lt-ghost{font-family:'Lora','Georgia',serif;font-size:0.82rem;font-style:italic;color:var(--cream2);text-align:center;line-height:1.7;max-width:320px;overflow:hidden;height:1.3em;white-space:nowrap;position:relative;z-index:2;}
.lt-ghost-top{-webkit-mask-image:linear-gradient(to top,transparent 0%,rgba(0,0,0,0.55) 100%);mask-image:linear-gradient(to top,transparent 0%,rgba(0,0,0,0.55) 100%);margin-bottom:3px;}
.lt-ghost-bot{-webkit-mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,0.55) 100%);mask-image:linear-gradient(to bottom,transparent 0%,rgba(0,0,0,0.55) 100%);margin-top:3px;}
.lt-hook{font-family:'Lora','Georgia',serif;font-size:1rem;font-style:italic;color:var(--cream);text-align:center;line-height:2;position:relative;z-index:4;padding:4px 16px;}
.lt-lock{display:flex;flex-direction:column;align-items:center;gap:3px;z-index:2;position:relative;}
.lock-text{font-family:'Playfair Display','Georgia',serif;font-size:0.95rem;font-style:italic;color:var(--cream2);text-align:center;}
.lock-sub{font-size:0.7rem;color:var(--muted);letter-spacing:0.1em;text-align:center;}
.lyrics-copyright{font-size:0.6rem;color:var(--muted);letter-spacing:0.12em;margin-top:18px;padding-top:12px;border-top:1px solid var(--glass-b);font-family:'Lato','Helvetica Neue','Arial',sans-serif;line-height:1.6;}
.lyrics-credits{font-size:0.65rem;color:rgba(201,147,43,0.4);letter-spacing:0.08em;font-family:'Lora','Georgia',serif;font-style:italic;line-height:1.8;margin-bottom:14px;padding-left:0;}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 2fr;gap:52px;margin-top:40px;align-items:start;}
.about-photo-real{
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:4/5;
  position:relative;
  box-shadow:0 20px 60px rgba(0,0,0,0.5), 0 0 0 1px rgba(201,147,43,0.15);
}
.about-photo-real img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top;
  display:block;
  transition:transform 0.5s ease;
}
.about-photo-real:hover img{
  transform:scale(1.03);
}
/* warm golden overlay at bottom */
.about-photo-real::after{
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:35%;
  background:linear-gradient(to top, rgba(12,8,5,0.6), transparent);
  pointer-events:none;
}
.about-photo-placeholder{aspect-ratio:3/4;border-radius: 12px;background:var(--bg3);border:1px dashed rgba(201,147,43,0.2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--muted);font-size:0.73rem;letter-spacing:0.12em;text-align:center;padding:20px;position:relative;overflow:hidden;}
.about-photo-placeholder::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(201,147,43,0.04),transparent);}
.photo-icon{font-size:2.8rem;margin-bottom:4px;}
.about-quick-facts{margin-top:18px;display:flex;flex-direction:column;gap:9px;}
.qf-row{display:flex;justify-content:space-between;align-items:center;padding:7px 13px;background:var(--bg3);border-radius:8px;border:1px solid var(--glass-b);}
.qf-label{font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);}
.qf-val{font-size:0.8rem;color:var(--cream2);font-weight:700;}
.about-section{margin-bottom:36px;}
.about-section-title{font-family:'Playfair Display','Georgia',serif;font-size:1.3rem;font-style:italic;color:var(--gold);margin-bottom:12px;}
.about-text{font-size:0.92rem;line-height:1.88;color:var(--muted);}
.about-text strong{color:var(--cream2);}
.about-text p{margin-bottom:10px;}
.interests-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;}
.interest-pill{padding:11px 14px;background:var(--bg3);border-radius:10px;border:1px solid var(--glass-b);font-size:0.8rem;color:var(--cream2);display:flex;align-items:center;gap:9px;transition:border-color 0.2s;}
.interest-pill:hover{border-color:rgba(201,147,43,0.28);}

/* PLATFORMS */
.platforms-region{margin-bottom:44px;}
.region-title{font-size:0.62rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--muted);margin-bottom:18px;padding-bottom:9px;border-bottom:1px solid var(--glass-b);}
.platforms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:10px;}
.plat-card{background:var(--bg3);border:1px solid var(--glass-b);border-radius:12px;padding:16px 18px;text-decoration:none;display:flex;align-items:center;gap:12px;transition:all 0.28s;position:relative;overflow:hidden;}
.plat-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--plat-color,rgba(201,147,43,0.08)),transparent);opacity:0;transition:opacity 0.3s;border-radius:12px;}
.plat-card:hover{border-color:rgba(201,147,43,0.3);transform:translateY(-3px);box-shadow:0 8px 26px rgba(0,0,0,0.28);}
.plat-card:hover::before{opacity:1;}
.plat-icon{font-size:1.1rem;flex-shrink:0;width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.06);}
.plat-name{font-size:0.83rem;font-weight:700;color:var(--cream2);margin-bottom:2px;}
.plat-region{font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);}

/* CONTACT */
.contact-wrap{max-width:600px;margin-top:40px;}
.cf-title{font-family:'Playfair Display','Georgia',serif;font-size:1.3rem;font-style:italic;color:var(--gold);margin-bottom:20px;}
.cf-group{margin-bottom:14px;}
.cf-label{font-size:0.62rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;display:block;}
.cf-input,.cf-textarea,.cf-select{width:100%;background:var(--bg3);border:1px solid var(--glass-b);border-radius:8px;padding:12px 14px;color:var(--cream);font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.88rem;outline:none;transition:border-color 0.25s;}
.cf-input:focus,.cf-textarea:focus,.cf-select:focus{border-color:var(--gold);}
.cf-input::placeholder,.cf-textarea::placeholder{color:var(--muted);}
.cf-textarea{min-height:110px;resize:vertical;}
.cf-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;}
.cf-select option{background:var(--bg3);}

/* PRESS */
.press-lock{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:65vh;gap:20px;position:relative;overflow:hidden;}
.press-light-bg{position:absolute;top:30%;left:50%;transform:translate(-50%,-50%);width:500px;height:400px;background:radial-gradient(ellipse 60% 50% at 50% 50%,rgba(201,147,43,0.12) 0%,rgba(201,147,43,0.05) 45%,transparent 70%);filter:blur(30px);pointer-events:none;z-index:0;animation:lightBreathe 5s ease-in-out infinite alternate;}
.press-lock>*:not(.press-light-bg){position:relative;z-index:1;}
.press-lock-icon{font-size:3.5rem;animation:float 3s ease-in-out infinite;}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.press-lock h2{font-family:'Playfair Display','Georgia',serif;font-size:1.9rem;font-weight:500;}
.press-lock p{font-size:0.87rem;color:var(--muted);max-width:380px;line-height:1.75;}
.press-input-wrap{display:flex;border:1px solid var(--glass-b);border-radius:10px;overflow:hidden;width:100%;max-width:340px;background:var(--bg3);}
.press-input{flex:1;background:transparent;border:none;padding:13px 16px;color:var(--cream);font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.88rem;outline:none;}
.press-input::placeholder{color:var(--muted);}
.press-submit{padding:13px 18px;background:linear-gradient(135deg,var(--gold),var(--warm));border:none;color:#0c0805;cursor:pointer;font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.72rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;transition:opacity 0.2s;}
.press-submit:hover{opacity:0.85;}
.press-error{font-size:0.76rem;color:var(--pink);display:none;}
.press-content{display:none;}
.press-content.unlocked{display:block;}
.press-bio-hero{background:linear-gradient(135deg,rgba(201,147,43,0.1),rgba(201,112,80,0.06));border:1px solid rgba(201,147,43,0.2);border-radius:18px;padding:36px 40px;margin-bottom:36px;position:relative;overflow:hidden;}
.press-bio-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:220px;height:220px;background:radial-gradient(circle,rgba(201,147,43,0.12),transparent 65%);pointer-events:none;}
.pbh-label{font-size:0.6rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.pbh-name{font-family:'Playfair Display','Georgia',serif;font-size:2.2rem;font-weight:500;margin-bottom:6px;}
.pbh-name-zh{font-family:'Noto Serif SC','STSong','SimSun',serif;font-size:1.1rem;color:var(--muted);letter-spacing:0.3em;margin-bottom:18px;}
.pbh-short{font-size:0.9rem;color:var(--cream2);line-height:1.8;max-width:600px;}
.pbh-short strong{color:var(--gold2);}
.pbh-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;}
.press-bio-full{display:none;font-size:0.88rem;color:var(--cream2);line-height:1.88;margin-top:20px;padding-top:18px;border-top:1px solid var(--glass-b);white-space:pre-line;}
.press-bio-full.expanded{display:block;}
.press-section{margin-bottom:44px;}
.press-section-title{font-family:'Playfair Display','Georgia',serif;font-size:1.25rem;font-style:italic;color:var(--gold);margin-bottom:16px;padding-bottom:9px;border-bottom:1px solid var(--glass-b);}
.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:11px;}
.file-card{background:var(--bg3);border:1px solid var(--glass-b);border-radius:10px;padding:16px 18px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all 0.25s;}
.file-card:hover{border-color:rgba(201,147,43,0.35);box-shadow:0 5px 20px rgba(0,0,0,0.28);}
.file-icon{font-size:1.5rem;flex-shrink:0;}
.file-name{font-size:0.83rem;font-weight:700;color:var(--cream2);}
.file-type{font-size:0.62rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-top:2px;}
.press-links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;}
.press-link-item{background:var(--bg3);border:1px solid var(--glass-b);border-radius:10px;padding:14px 16px;text-decoration:none;display:flex;align-items:center;gap:10px;transition:all 0.25s;}
.press-link-item:hover{border-color:rgba(201,147,43,0.3);transform:translateY(-2px);}
.pl-icon{font-size:1.2rem;}
.pl-name{font-size:0.82rem;font-weight:700;color:var(--cream2);}
.pl-sub{font-size:0.6rem;color:var(--muted);margin-top:1px;}

/* DOC MODAL */
#doc-modal{position:fixed;inset:0;z-index:700;background:rgba(12,8,5,0.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;}
#doc-modal.show{opacity:1;pointer-events:all;}
.doc-box{background:var(--bg2);border:1px solid rgba(201,147,43,0.2);border-radius:18px;width:90%;max-width:700px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;transform:translateY(24px);transition:transform 0.3s;}
#doc-modal.show .doc-box{transform:translateY(0);}
.doc-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--glass-b);flex-shrink:0;}
.doc-title{font-family:'Playfair Display','Georgia',serif;font-size:1.1rem;font-weight:500;}
.doc-header-btns{display:flex;gap:8px;align-items:center;}
.doc-close{background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;}
.doc-close:hover{color:var(--cream);}
.doc-body{flex:1;overflow-y:auto;padding:28px 32px;}
.doc-body::-webkit-scrollbar{width:4px;}
.doc-body::-webkit-scrollbar-thumb{background:rgba(201,147,43,0.3);border-radius:2px;}
.doc-dl-btn{padding:9px 20px;background:linear-gradient(135deg,var(--gold),var(--warm));border:none;border-radius:7px;color:#0c0805;font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.68rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;}
.doc-dl-btn:hover{opacity:0.85;}

/* NEWSLETTER MODAL */
#newsletter-modal{position:fixed;inset:0;z-index:600;background:rgba(12,8,5,0.88);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity 0.3s;}
#newsletter-modal.show{opacity:1;pointer-events:all;}
.nl-box{background:var(--bg2);border:1px solid rgba(201,104,130,0.25);border-radius:18px;padding:40px;max-width:440px;width:90%;text-align:center;transform:translateY(20px);transition:transform 0.3s;position:relative;}
#newsletter-modal.show .nl-box{transform:translateY(0);}
.nl-close{position:absolute;top:14px;right:18px;background:none;border:none;color:var(--muted);font-size:1.3rem;cursor:pointer;}
.nl-icon{font-size:2.2rem;margin-bottom:14px;}
.nl-title{font-family:'Playfair Display','Georgia',serif;font-size:1.6rem;margin-bottom:7px;}
.nl-sub{font-size:0.83rem;color:var(--muted);line-height:1.7;margin-bottom:22px;}
.nl-box{position:relative;width:92%;max-width:400px;background:linear-gradient(160deg,#1a1008 0%,#0c0805 100%);border:1px solid rgba(201,147,43,0.25);border-radius:20px;padding:36px 28px 28px;overflow:hidden;}
.nl-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,#c9932b,#e8b84b,#c9932b,transparent);}
.nl-form{display:flex;flex-direction:column;gap:13px;}
.nl-input{background:rgba(255,255,255,0.04);border:1px solid rgba(201,147,43,0.18);border-radius:10px;padding:13px 16px;color:var(--cream);font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.88rem;outline:none;transition:all 0.3s;}
.nl-input:focus{border-color:rgba(201,147,43,0.55);background:rgba(255,255,255,0.07);box-shadow:0 0 0 3px rgba(201,147,43,0.08);}
.nl-input::placeholder{color:rgba(212,192,168,0.35);}
.nl-submit{padding:13px;background:linear-gradient(135deg,var(--pink),var(--warm));border:none;border-radius:8px;color:#fff;font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.77rem;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:opacity 0.2s;}
.nl-submit:hover{opacity:0.88;}
.nl-note{font-size:0.67rem;color:var(--muted);line-height:1.6;padding:10px 12px;background:rgba(255,255,255,0.03);border-radius:6px;border:1px solid var(--glass-b);text-align:left;}
.nl-note strong{color:var(--gold);}
.nl-success{display:none;text-align:center;padding:16px 0;}
.nl-success-icon{font-size:2.8rem;margin-bottom:10px;}
.nl-success-text{font-family:'Playfair Display','Georgia',serif;font-size:1.15rem;color:var(--sage);}
.nl-success-sub{font-size:0.78rem;color:var(--muted);margin-top:5px;line-height:1.7;}

/* MINI PLAYER */
#mini-player{position:fixed;bottom:0;left:0;right:0;z-index:400;background:rgba(18,12,7,0.97);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(201,147,43,0.15);padding:11px 36px;display:flex;align-items:center;gap:18px;transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);}
.player-info{display:flex;align-items:center;gap:12px;min-width:170px;flex:1;}
.player-thumb{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,var(--gold),var(--warm));display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;}
.player-track .p-title{font-size:0.82rem;font-weight:700;color:var(--cream);}
.player-track .p-artist{font-size:0.68rem;color:var(--muted);}
.player-controls{display:flex;align-items:center;flex:2;flex-direction:column;}
.player-btns{display:flex;align-items:center;gap:12px;margin-bottom:4px;}
.p-btn{background:none;border:none;color:var(--muted);font-size:0.95rem;cursor:pointer;transition:color 0.2s,transform 0.15s;padding:4px;}
.p-btn:hover{color:var(--cream);transform:scale(1.1);}
.p-btn.play-pause{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--warm));color:#0c0805;font-size:0.85rem;display:flex;align-items:center;justify-content:center;}
.p-btn.play-pause:hover{transform:scale(1.05);box-shadow:0 4px 14px rgba(201,147,43,0.4);}
.p-btn-mix{padding:5px 14px;border-radius:6px;background:rgba(181,123,238,0.12);border:1px solid rgba(181,123,238,0.3);color:#d4aaff;font-size:0.6rem;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;cursor:pointer;transition:all 0.2s;white-space:nowrap;}
.p-btn-mix:hover{background:rgba(181,123,238,0.22);color:#eeaaff;}
.p-btn-mix.active{background:rgba(201,147,43,0.15);border-color:var(--gold);color:var(--gold2);}
.player-progress-wrap{width:100%;max-width:380px;display:flex;align-items:center;gap:9px;}
.p-time{font-size:0.62rem;color:var(--muted);min-width:32px;}
.progress-bar{flex:1;height:3px;background:rgba(255,255,255,0.1);border-radius:3px;cursor:pointer;position:relative;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(to right,var(--gold),var(--warm));border-radius:3px;width:0%;transition:width 0.2s;}
.mix-highlight{position:absolute;top:0;height:100%;background:rgba(181,123,238,0.35);border-radius:3px;pointer-events:none;}
.mix-label{font-size:0.6rem;letter-spacing:0.15em;color:rgba(181,123,238,0.8);text-transform:uppercase;margin-top:2px;height:14px;text-align:center;}
.player-right{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;}
.volume-wrap{display:flex;align-items:center;gap:7px;}
.volume-icon{font-size:0.85rem;color:var(--muted);}
.volume-slider{width:65px;height:3px;-webkit-appearance:none;appearance:none;background:rgba(255,255,255,0.14);border-radius:3px;cursor:pointer;outline:none;}
.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:11px;border-radius:50%;background:var(--gold);}
.p-hide-btn{font-size:0.68rem;background:none;border:none;color:var(--muted);cursor:pointer;padding:3px 7px;}
.p-hide-btn:hover{color:var(--cream);}


#pwa-install-btn{display:none !important;}


/* NEWSLETTER FLOAT */
#newsletter-btn{position:fixed;right:22px;bottom:84px;z-index:450;background:linear-gradient(135deg,var(--pink),var(--warm));border:none;border-radius:50px;padding:9px 18px;color:#fff;font-family:'Lato','Helvetica Neue','Arial',sans-serif;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;font-weight:700;cursor:pointer;box-shadow:0 4px 18px rgba(201,104,130,0.3);transition:all 0.3s;}
#newsletter-btn:hover{transform:translateY(-3px);box-shadow:0 7px 24px rgba(201,104,130,0.45);}

/* FOOTER */
#site-footer{position:relative;z-index:1;text-align:center;padding:40px 24px 120px;border-top:1px solid rgba(201,147,43,0.08);}
.footer-name{font-family:'Playfair Display','Georgia',serif;font-size:1.6rem;font-weight:300;color:var(--muted);margin-bottom:6px;}
.footer-name span{font-family:'Noto Serif SC','STSong','SimSun',serif;margin-left:10px;}
.footer-copyright{font-size:0.66rem;letter-spacing:0.1em;color:rgba(240,223,200,0.28);margin-top:12px;line-height:1.75;max-width:700px;margin-left:auto;margin-right:auto;}

/* MISC */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* PROTECTION */
img, .about-photo-real img {
  -webkit-user-drag: none;
  -khtml-user-drag: none;
  -moz-user-drag: none;
  -webkit-user-select: none;
  user-select: none;
  pointer-events: none;
}
.lyrics-text, .lyrics-locked .lyrics-text {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  font-family: 'YanMing', Georgia, serif;
  font-size: 0.58rem;
line-height: 2.2;
letter-spacing: 0.05em;
word-spacing: 0.15em;
}
body {
  -webkit-touch-callout: none;
}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg);}
::-webkit-scrollbar-thumb{background:rgba(201,147,43,0.25);border-radius:3px;}

/* RESPONSIVE */
@media(max-width:860px){
  #main-nav{padding:14px 18px;}
  .nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;right:0;background:rgba(12,8,5,0.98);padding:10px 18px;gap:3px;border-bottom:1px solid var(--glass-b);}
  .nav-links.open{display:flex;}
  .hamburger{display:flex;}
  .home-hero{grid-template-columns:1fr;padding:36px 18px;gap:28px;}
  .hero-right{display:none;}
  .hero-title{font-size:clamp(3.5rem,14vw,5rem);}
  .page-inner{padding:44px 18px 150px;}
  .about-grid{grid-template-columns:1fr;gap:28px;}
  .song-lyrics-inner{padding-left:16px;}
  .song-lyrics-inner::before{left:36px;}
  .lyrics-section{padding-left:48px;}
  #mini-player{padding:9px 14px;flex-wrap:wrap;gap:8px;}
  .player-controls{flex:100%;order:3;}
  .player-right{flex:1;}
  #newsletter-btn{right:14px;bottom:120px;}
  .interests-grid{grid-template-columns:1fr;}
}
/* EMBEDDED FONTS */
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:100 900;font-display:swap;src:url('https://fonts.gstatic.com/s/playfairdisplay/v37/nuFvD-vYSZviVYUb_rj3ij__anPXJzDwcbmjWBN2PKdFvXDXbtM.woff2') format('woff2'),url('PlayfairDisplay.woff2') format('woff2');}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:100 900;font-display:swap;src:url('https://fonts.gstatic.com/s/playfairdisplay/v37/nuFvD-vYSZviVYUb_rj3ij__anPXJzDwcbmjWBN2PKd3vXDXbtM.woff2') format('woff2'),url('PlayfairDisplay-Italic.woff2') format('woff2');}
@font-face{font-family:'Lato';font-style:normal;font-weight:400;font-display:swap;src:url('https://fonts.gstatic.com/s/lato/v24/S6uyw4BMUTPHjx4wXiWtFCc.woff2') format('woff2'),url('Lato-Regular.woff2') format('woff2');}
@font-face{font-family:'Lato';font-style:normal;font-weight:700;font-display:swap;src:url('https://fonts.gstatic.com/s/lato/v24/S6u9w4BMUTPHh6UVSwiPGQ3q5d0.woff2') format('woff2'),url('Lato-Bold.woff2') format('woff2');}
@font-face{font-family:'Lato';font-style:italic;font-weight:400;font-display:swap;src:url('https://fonts.gstatic.com/s/lato/v24/S6u8w4BMUTPHjxsAXC-v.woff2') format('woff2'),url('Lato-Italic.woff2') format('woff2');}
@font-face{
  font-family:'Caveat';
  font-style:normal;
  font-weight:400 700;
  font-display:swap;
  src:url('Caveat.woff2') format('woff2');
}
@font-face{font-family:'Lora';font-style:normal;font-weight:100 900;font-display:swap;src:url('https://fonts.gstatic.com/s/lora/v35/0QI6MX1D_JOxE7fSMfj8Yl8Or0w.woff2') format('woff2'),url('Lora.woff2') format('woff2');}
@font-face{font-family:'Lora';font-style:italic;font-weight:100 900;font-display:swap;src:url('Lora-Italic.woff2') format('woff2');}

  @font-face{font-family:'Noto Serif SC';font-weight:300 400;src:local('Noto Serif CJK SC'),local('Source Han Serif SC'),local('STSong'),local('SimSun');font-display:swap;}


/* ===== HERO AURORA GLOW ===== */
.hero-name-block::before {
  content: '';
  position: absolute;
  inset: -40px -60px;
  background: radial-gradient(ellipse 70% 60% at 50% 55%,
    rgba(201,147,43,0.13) 0%,
    rgba(201,112,80,0.07) 40%,
    transparent 70%);
  animation: auroraBreath 5s ease-in-out infinite;
  pointer-events: none;
  z-index: 1;
  border-radius: 50%;
}
@keyframes auroraBreath {
  0%,100% { opacity: 0.6; transform: scale(1); }
  50%      { opacity: 1;   transform: scale(1.08); }
}

/* ===== HERO CARDS — premium feel ===== */
.featured-card {
  background: linear-gradient(135deg, rgba(201,147,43,0.08), rgba(201,112,80,0.04));
  border: 1px solid rgba(201,147,43,0.18);
  border-radius: 16px;
  padding: 24px 26px;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
  position: relative;
  overflow: hidden;
}
.featured-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,147,43,0.4), transparent);
}
.featured-card:hover {
  border-color: rgba(201,147,43,0.35);
  box-shadow: 0 8px 40px rgba(201,147,43,0.08);
}

.activity-card {
  background: rgba(255,235,200,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px;
  padding: 20px 24px;
}
.activity-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  font-size: 0.8rem;
  color: rgba(240,223,200,0.55);
  font-family: 'Lato', sans-serif;
  transition: color 0.2s;
}
.activity-item:last-child { border-bottom: none; }
.activity-item:hover { color: rgba(240,223,200,0.85); }
.activity-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
.activity-date {
  margin-left: auto;
  font-size: 0.68rem;
  letter-spacing: 0.08em;
  opacity: 0.5;
}
.activity-title {
  font-size: 0.6rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(201,147,43,0.4);
  font-family: 'Lato', sans-serif;
  margin-bottom: 10px;
}
.fc-label {
  font-size: 0.58rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: rgba(201,147,43,0.5);
  font-family: 'Lato', sans-serif;
  margin-bottom: 10px;
}
.fc-title {
  font-family: 'Playfair Display', 'Georgia', serif;
  font-size: 1.3rem;
  color: var(--cream);
  margin-bottom: 10px;
  font-style: italic;
}
.fc-desc {
  font-size: 0.8rem;
  line-height: 1.75;
  color: var(--muted);
  margin-bottom: 16px;
}
.fc-platforms {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}
.fc-plat {
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  color: var(--gold);
  text-decoration: none;
  padding: 5px 12px;
  border: 1px solid rgba(201,147,43,0.25);
  border-radius: 20px;
  font-family: 'Lato', sans-serif;
  transition: all 0.2s;
}
.fc-plat:hover {
  background: rgba(201,147,43,0.12);
  border-color: rgba(201,147,43,0.5);
  color: var(--gold2);
}

/* ===== BYPASS TOOLTIP ===== */
#bypass-tooltip {
  position: fixed;
  top: 58px;
  left: 20px;
  z-index: 9999;
  background: rgba(12,8,5,0.97);
  border: 1px solid rgba(201,147,43,0.35);
  border-radius: 10px;
  padding: 12px 16px;
  font-family: monospace;
  font-size: 0.68rem;
  color: rgba(201,147,43,0.85);
  letter-spacing: 0.08em;
  backdrop-filter: blur(12px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  user-select: all;
  max-width: 320px;
  line-height: 1.6;
}
#bypass-tooltip.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}
#bypass-tooltip .bp-label {
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(201,147,43,0.4);
  margin-bottom: 6px;
}
#bypass-tooltip .bp-url {
  color: rgba(201,147,43,0.9);
  word-break: break-all;
}

/* ===== SCROLL HINT ===== */
.scroll-hint {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  opacity: 0;
  animation: fadeUp 0.8s ease 1.8s forwards;
  pointer-events: none;
}
.scroll-hint-line {
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, rgba(201,147,43,0.5), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
.scroll-hint-text {
  font-size: 0.5rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: rgba(201,147,43,0.3);
  font-family: 'Lato', sans-serif;
}
@keyframes scrollPulse {
  0%,100% { opacity: 0.4; }
  50%      { opacity: 1; }
}

/* ===== ABOUT PAGE — redesign ===== */
.about-photo-wrap{
  position:relative;border-radius:16px;overflow:hidden;margin-bottom:24px;
}
.about-photo-wrap::before{
  content:'';position:absolute;inset:-1px;
  background:linear-gradient(135deg,rgba(201,147,43,0.25),rgba(201,112,80,0.12),transparent 60%);
  border-radius:16px;z-index:1;pointer-events:none;
}
.about-photo-wrap::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 50% at 50% 20%,rgba(201,147,43,0.07),transparent);
  z-index:2;pointer-events:none;
}
.about-photo-wrap img{
  width:100%;display:block;border-radius:16px;
  filter:sepia(6%) contrast(1.04) brightness(0.97);
  transition:filter 0.4s ease;
}
.about-photo-wrap:hover img{filter:sepia(0%) contrast(1.07) brightness(1.01);}

.about-stat-accent{
  display:inline-flex;align-items:baseline;gap:8px;
  margin:4px 0 20px;
}
.about-stat-num{
  font-family:'Playfair Display',serif;
  font-size:3rem;color:rgba(201,147,43,0.2);
  font-style:italic;line-height:1;
}
.about-stat-label{
  font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;
  color:rgba(201,147,43,0.25);font-family:'Lato',sans-serif;
}

.about-hl{
  color:rgba(201,112,80,0.85);
  font-style:italic;
}

.about-quote{
  margin:4px 0 22px;
  padding:18px 22px;
  border-left:2px solid rgba(201,147,43,0.28);
  background:rgba(201,147,43,0.04);
  border-radius:0 10px 10px 0;
  position:relative;
}
.about-quote::before{
  content:'"';
  position:absolute;top:-10px;left:14px;
  font-family:'Playfair Display',serif;
  font-size:3rem;color:rgba(201,147,43,0.12);line-height:1;
}
.about-quote p{
  font-family:'Playfair Display','Georgia',serif;
  font-style:italic;
  font-size:1.05rem;
  color:rgba(240,223,200,0.82);
  line-height:1.75;
}

.about-text p{
  font-size:0.93rem;line-height:2;
  color:rgba(240,223,200,0.7);
  margin-bottom:16px;
}
.about-text p:last-child{margin-bottom:0;}

.interest-pill{
  font-size:0.72rem;font-family:'Lato',sans-serif;
  color:rgba(240,223,200,0.55);
  padding:6px 14px;border-radius:20px;
  border:1px solid rgba(255,255,255,0.07);
  background:rgba(255,255,255,0.02);
  transition:all 0.2s;letter-spacing:0.03em;
}
.interest-pill:hover{
  border-color:rgba(201,147,43,0.28);
  color:rgba(240,223,200,0.88);
  background:rgba(201,147,43,0.05);
}

/* ===== STORY PAGE ===== */
.story-wrap{max-width:640px;margin:0 auto;padding-bottom:60px;}

.story-block{
  display:grid;
  grid-template-columns:36px 1fr;
  gap:20px;
  padding:36px 0;
  border-bottom:1px solid rgba(255,255,255,0.04);
  align-items:start;
}
.story-block:last-of-type{border-bottom:none;}

.story-block-accent{
  background:rgba(201,147,43,0.03);
  border-radius:12px;
  padding:28px 24px;
  border:1px solid rgba(201,147,43,0.08);
  margin:8px -24px;
  grid-template-columns:36px 1fr;
}

.story-num{
  font-family:'Playfair Display',serif;
  font-size:1.6rem;font-style:italic;
  color:rgba(201,147,43,0.2);
  line-height:1.2;
  padding-top:4px;
  user-select:none;
}

.story-text p{
  font-family:'IM Fell English','Georgia',serif;
  font-size:0.93rem;line-height:2.05;
  color:rgba(240,223,200,0.68);
  margin-bottom:16px;
}
.story-text p:last-child{margin-bottom:0;}
.story-em{
  font-style:italic;
  color:rgba(240,223,200,0.85) !important;
  border-left:2px solid rgba(201,147,43,0.25);
  padding-left:16px;
  margin-left:0;
}

.story-zh{
  font-family:'Noto Serif SC',serif;font-weight:300;
  font-size:1.2rem;letter-spacing:0.5em;
  color:rgba(201,147,43,0.25);
  text-align:center;margin-top:48px;
}
.story-zh-trans{
  text-align:center;margin-top:10px;
  font-family:'IM Fell English',serif;font-style:italic;
  font-size:0.78rem;color:rgba(240,223,200,0.25);
  letter-spacing:0.05em;
}

/* ═══ WATERMARK ═══ */
.watermark-layer{position:fixed;inset:0;z-index:99998;pointer-events:none;overflow:hidden;opacity:0.022;}
.watermark-layer span{position:absolute;font-family:'Playfair Display','Georgia',serif;font-size:1.1rem;letter-spacing:0.3em;color:rgba(201,147,43,1);white-space:nowrap;transform:rotate(-35deg);user-select:none;-webkit-user-select:none;}

/* ═══ GALLERY — Page Peel · Yan Ming 颜明 ═══ */
#gal-page { position:fixed;inset:0;z-index:502;background:linear-gradient(160deg,#1e170a 0%,#160f05 40%,#120c03 100%);overflow-y:auto;overscroll-behavior:contain;display:none; }
#gal-page::before { content:'';position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 80% 55% at 65% -5%,rgba(232,184,75,0.13) 0%,transparent 60%),radial-gradient(ellipse 50% 40% at 10% 80%,rgba(201,112,80,0.08) 0%,transparent 55%); }
#gal-page.gal-open { display:block; }
.gal-hdr { position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;padding:15px 22px;background:rgba(22,14,4,0.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(232,184,75,0.1); }
.gal-hdr-title { font-family:'Playfair Display','Georgia',serif;font-size:1.2rem;color:var(--gold2); }
.gal-hdr-title em { font-style:italic;color:var(--cream2); }
.gal-x { background:none;border:1px solid rgba(232,184,75,0.15);border-radius:50%;width:34px;height:34px;color:var(--muted);font-size:0.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s; }
.gal-x:hover { border-color:rgba(232,184,75,0.4);color:var(--cream); }
.gal-body { position:relative;z-index:1;padding:20px 18px 60px; }
.gal-sec { font-size:0.45rem;letter-spacing:0.35em;text-transform:uppercase;color:rgba(232,184,75,0.35);margin:24px 0 14px;display:flex;align-items:center;gap:10px; }
.gal-sec::after { content:'';flex:1;height:1px;background:linear-gradient(90deg,rgba(232,184,75,0.12),transparent); }
.gal-scattered { position:relative;height:310px;overflow:hidden; }
.gal-sc { position:absolute;border:5px solid rgba(240,223,200,0.08);border-bottom-width:20px;border-radius:2px;overflow:visible;cursor:pointer;box-shadow:3px 7px 22px rgba(0,0,0,0.45);transition:transform 0.32s cubic-bezier(0.34,1.56,0.64,1),box-shadow 0.3s; }
.gal-sc:hover { transform:rotate(0deg) scale(1.1) translateY(-8px)!important;box-shadow:6px 18px 40px rgba(0,0,0,0.65);z-index:50!important; }
.gal-sc-ph { width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:5px; }
.gal-sc-ph-i { font-size:1.4rem;opacity:0.45; }
.gal-sc-ph-l { font-size:0.37rem;letter-spacing:0.09em;text-transform:uppercase;color:rgba(232,184,75,0.3); }
.gal-sc-cap { position:absolute;bottom:-14px;left:0;right:0;text-align:center;font-family:'Lora','Georgia',serif;font-style:italic;font-size:0.42rem;color:rgba(240,223,200,0.85);line-height:19px; }
.gal-film-outer { overflow:hidden;height:178px;background:rgba(8,5,2,0.94);border-radius:6px;cursor:grab; }
.gal-film-outer:hover .gal-filmstrip { animation-play-state:paused; }
.gal-filmstrip { display:flex;width:max-content;animation:galRoll 24s linear infinite; }
@keyframes galRoll { from{transform:translateX(0);}to{transform:translateX(-33.33%);} }
.gal-ff { flex-shrink:0;width:112px;height:178px;border-left:3px solid #050302;border-right:3px solid #050302;position:relative;display:flex;align-items:center;justify-content:center;background:rgba(10,6,2,0.96); }
.gal-ff::before,.gal-ff::after { content:'';position:absolute;left:50%;transform:translateX(-50%);width:82%;height:10px;background:repeating-linear-gradient(90deg,transparent 0,transparent 5px,rgba(0,0,0,1) 5px,rgba(0,0,0,1) 13px); }
.gal-ff::before{top:4px;}.gal-ff::after{bottom:4px;}
.gal-ff-ph { width:92px;height:120px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;background:rgba(12,7,2,0.9); }
.gal-ff-i { font-size:1.3rem;opacity:0.42; }
.gal-ff-l { font-size:0.34rem;letter-spacing:0.09em;text-transform:uppercase;color:rgba(232,184,75,0.28); }
.gal-ff-n { position:absolute;bottom:14px;right:4px;font-size:0.32rem;color:rgba(232,184,75,0.1);font-family:monospace; }
.gal-pol-row { display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:4px; }
.gal-pol { width:112px;background:rgba(240,225,200,0.05);border:1px solid rgba(240,225,200,0.07);border-radius:2px;padding:7px 7px 20px;position:relative;cursor:pointer;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1),box-shadow 0.3s;box-shadow:2px 4px 16px rgba(0,0,0,0.38); }
.gal-pol::before { content:'📌';position:absolute;top:-9px;left:50%;transform:translateX(-50%);font-size:0.62rem;opacity:0.32; }
.gal-pol:nth-child(odd){transform:rotate(-2.3deg);}.gal-pol:nth-child(even){transform:rotate(1.9deg);}
.gal-pol:hover { transform:rotate(0deg) scale(1.1)!important;z-index:10; }
.gal-pol-photo { width:100%;aspect-ratio:1;overflow:hidden;position:relative; }
.gal-pol-ph { width:100%;height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;background:rgba(16,10,3,0.88); }
.gal-pol-ph-i { font-size:1.3rem;opacity:0.42; }
.gal-pol-cap { position:absolute;bottom:3px;left:0;right:0;text-align:center;font-family:'Lora','Georgia',serif;font-style:italic;font-size:0.41rem;color:rgba(240,223,200,0.78); }
.gal-orbs { position:relative;height:260px;overflow-x:auto;overflow-y:visible;scrollbar-width:none;-webkit-overflow-scrolling:touch; }
.gal-orbs::-webkit-scrollbar{display:none;}
.gal-orb { position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px;cursor:pointer;overflow:hidden;animation:galObf var(--od,6s) ease-in-out var(--odl,0s) infinite alternate;transition:transform 0.32s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes galObf { from{transform:translateY(0);}to{transform:translateY(-11px);} }
.gal-orb:hover { transform:scale(1.12) translateY(-5px)!important;z-index:20; }
.gal-orb-ph { width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px; }
.gal-orb-ph-i { font-size:1.3rem;opacity:0.42; }
.gal-orb-ph-l { font-size:0.34rem;letter-spacing:0.08em;text-transform:uppercase;color:rgba(232,184,75,0.3);text-align:center;padding:0 5px; }
.gal-press-const { padding:26px 18px;text-align:center;border-radius:10px;background:repeating-linear-gradient(-45deg,rgba(232,184,75,0.025) 0,rgba(232,184,75,0.025) 8px,transparent 8px,transparent 18px);border:1px solid rgba(232,184,75,0.08); }
.gal-pc-i { font-size:1.5rem;opacity:0.38;margin-bottom:8px; }
.gal-pc-t { font-family:'Playfair Display','Georgia',serif;font-size:0.94rem;color:rgba(232,184,75,0.38);margin-bottom:5px; }
.gal-pc-s { font-family:'Lora','Georgia',serif;font-style:italic;font-size:0.68rem;color:var(--muted);line-height:1.75;opacity:0.6; }

/* ── MY SUNSHINE — quiet waiting corner ── */
.gal-sunshine {
  margin-top:44px;
  padding:28px 20px 36px;
  position:relative;
  text-align:center;
}
/* Soft divider line */
.gal-sunshine::before {
  content:'';
  display:block;
  width:48px;height:1px;
  background:linear-gradient(90deg,transparent,rgba(245,200,66,0.18),transparent);
  margin:0 auto 28px;
}
/* The empty frame — like a polaroid waiting to be filled */
.gal-sun-frame {
  width:148px;height:148px;
  margin:0 auto 22px;
  position:relative;
  border:1px solid rgba(245,200,66,0.22);
  border-radius:3px;
  background:linear-gradient(135deg,rgba(245,200,66,0.07),rgba(201,112,80,0.04));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 28px rgba(0,0,0,0.25);
}
/* Warm glow behind the frame */
.gal-sun-frame::before {
  content:'';
  position:absolute;inset:-12px;
  background:radial-gradient(ellipse,rgba(245,200,66,0.06),transparent 70%);
  pointer-events:none;
  animation:sunGlow 5s ease-in-out infinite alternate;
}
@keyframes sunGlow {
  from { opacity:0.5; }
  to   { opacity:1; }
}
/* The sun symbol inside */
.gal-sun-icon {
  font-size:2.2rem;
  opacity:0.5;
  animation:sunGlow 5s ease-in-out infinite alternate;
}
/* Tiny label under frame */
.gal-sun-label {
  font-family:'Lora','Georgia',serif;
  font-style:italic;
  font-size:0.65rem;
  color:rgba(245,200,66,0.55);
  letter-spacing:0.1em;
  line-height:1.9;
}
/* The soft phrase */
.gal-sun-phrase {
  font-family:'Lora','Georgia',serif;
  font-style:italic;
  font-size:0.72rem;
  color:rgba(240,223,200,0.42);
  line-height:1.95;
  max-width:260px;
  margin:14px auto 0;
}

/* Canvas */
#gal-canvas-wrap { position:fixed;inset:0;z-index:503;display:none;pointer-events:none; }
#gal-canvas-wrap.gal-active { display:block; }
#gal-canvas-wrap canvas { position:absolute;inset:0;width:100%;height:100%;display:block; }

/* Glowing dot hint */
#gal-hint { position:fixed;top:58px;right:6px;z-index:499;pointer-events:none;opacity:0;transition:opacity 0.8s;display:flex;align-items:center;justify-content:center;width:22px;height:22px; }
#gal-hint.on { opacity:1; }
.gal-hint-dot { width:auto;height:auto;border-radius:0;background:none;box-shadow:none;font-size:1.1rem;line-height:1;color:#e8b84b;text-shadow:0 0 10px rgba(232,184,75,0.7),0 0 24px rgba(232,184,75,0.3);animation:galDotPulse 2.8s ease-in-out infinite;display:block;user-select:none; }
@keyframes galDotPulse { 0%,100%{transform:scale(1);opacity:0.7;}50%{transform:scale(1.35);opacity:1;} }

/* Corner touch */
#gal-touch { position:fixed;top:56px;right:0;width:70px;height:70px;border-radius:0 0 0 70px;z-index:501;cursor:grab;background:transparent; }

/* new-style.css — Yan Ming 颜明 */
@import url('https://fonts.googleapis.com/css2?family=Special+Elite&display=swap');

/* ── AURA CANVAS ── */
#aura-canvas {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
}
body.press-active #aura-canvas { display: none; }

/* ── PRESS LETTER POPUP ── */
#press-letter-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(12,8,5,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 800;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  transition: opacity 0.4s ease;
}
#press-letter-overlay.visible { opacity: 1; }

.pl-modal {
  background: linear-gradient(160deg, rgba(28,20,14,0.98), rgba(18,12,8,0.98));
  border: 1px solid rgba(201,147,43,0.2);
  border-radius: 18px;
  padding: 40px 36px;
  max-width: 480px;
  width: 100%;
  position: relative;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 40px rgba(201,147,43,0.04);
  animation: plIn 0.4s cubic-bezier(0.22,1,0.36,1) both;
}
@keyframes plIn { from { transform: translateY(18px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

.pl-close {
  position: absolute;
  top: 14px; right: 16px;
  background: none;
  border: none;
  color: rgba(212,192,168,0.35);
  font-size: 1rem;
  cursor: pointer;
  padding: 6px 8px;
  transition: color 0.2s;
}
.pl-close:hover { color: rgba(212,192,168,0.7); }

.pl-deco {
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 14px;
  filter: drop-shadow(0 0 10px rgba(201,147,43,0.3));
}
.pl-title {
  font-family: 'Playfair Display','Georgia',serif;
  font-size: 1.25rem;
  color: rgba(201,147,43,0.9);
  text-align: center;
  letter-spacing: 0.08em;
  font-weight: 700;
}
.pl-divider {
  width: 40px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201,147,43,0.4), transparent);
  margin: 14px auto;
}
.pl-body p {
  font-family: 'Lora','Georgia',serif;
  font-style: italic;
  font-size: 0.85rem;
  color: rgba(240,223,200,0.65);
  line-height: 1.85;
  margin-bottom: 10px;
}
.pl-sign {
  color: rgba(201,147,43,0.75) !important;
  margin-top: 18px !important;
  font-style: italic;
}
.pl-btn {
  display: block;
  width: 100%;
  margin-top: 22px;
  padding: 13px;
  background: linear-gradient(135deg, rgba(201,147,43,0.85), rgba(201,112,80,0.85));
  border: none;
  border-radius: 10px;
  color: #0c0805;
  font-family: 'Lato',sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity 0.2s;
}
.pl-btn:hover { opacity: 0.85; }

/* ── ACCESSIBILITY WIDGET ── */
#a11y-wrap {
  position: fixed;
  bottom: 175px;
  left: 14px;
  z-index: 390;
}
#a11y-trigger {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(28,20,14,0.85);
  border: 1px solid rgba(201,147,43,0.2);
  color: rgba(201,147,43,0.6);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  transition: all 0.2s;
}
#a11y-trigger:hover { border-color: rgba(201,147,43,0.5); color: rgba(201,147,43,0.9); }

#a11y-panel {
  position: absolute;
  bottom: 44px;
  left: 0;
  background: rgba(22,15,10,0.97);
  border: 1px solid rgba(201,147,43,0.18);
  border-radius: 12px;
  padding: 14px 12px;
  min-width: 160px;
  display: none;
  flex-direction: column;
  gap: 6px;
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}
#a11y-panel.open { display: flex; }

.a11y-label {
  font-size: 0.58rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(201,147,43,0.4);
  margin-bottom: 4px;
}
.a11y-btn {
  background: rgba(201,147,43,0.06);
  border: 1px solid rgba(201,147,43,0.12);
  border-radius: 7px;
  color: rgba(240,223,200,0.6);
  font-size: 0.72rem;
  padding: 7px 10px;
  cursor: pointer;
  text-align: left;
  transition: all 0.2s;
}
.a11y-btn:hover, .a11y-btn.active {
  background: rgba(201,147,43,0.14);
  border-color: rgba(201,147,43,0.3);
  color: rgba(240,223,200,0.9);
}

/* ── DAY MODE ── */
body.a11y-day {
  background: #f0ebe0 !important;
}
body.a11y-day #main-nav {
  background: rgba(240,235,224,0.97) !important;
  border-bottom-color: rgba(150,100,30,0.2) !important;
}
body.a11y-day .nav-logo,
body.a11y-day .nav-links a,
body.a11y-day .hamburger span {
  color: #1a1008 !important;
  background: none !important;
}
body.a11y-day .page {
  background: #f0ebe0 !important;
}
body.a11y-day p,
body.a11y-day h1,
body.a11y-day h2,
body.a11y-day h3,
body.a11y-day h4,
body.a11y-day li,
body.a11y-day span,
body.a11y-day div {
  color: #1a1008 !important;
}
body.a11y-day .featured-card,
body.a11y-day .activity-card,
body.a11y-day .about-quick-facts,
body.a11y-day .about-section,
body.a11y-day .album-block,
body.a11y-day .press-section,
body.a11y-day .press-bio-hero,
body.a11y-day .plat-card,
body.a11y-day .nl-box {
  background: #e4ddd3 !important;
  border-color: rgba(150,100,30,0.2) !important;
}
body.a11y-day #stars-canvas,
body.a11y-day #aura-canvas {
  opacity: 0.08 !important;
}
body.a11y-day footer {
  background: #e4ddd3 !important;
  color: #1a1008 !important;
}
.a11y-btn-big {
  font-weight: 700;
  border-color: rgba(201,147,43,0.35) !important;
  color: rgba(240,223,200,0.9) !important;
}
/* ── ACCESSIBILITY MODES ── */
body.a11y-contrast {
  --bg: #000 !important;
  --bg2: #0a0a0a !important;
  --bg3: #111 !important;
  --cream: #fff !important;
  --cream2: #eee !important;
  --gold: #ffd700 !important;
}
body.a11y-light {
  filter: invert(1) hue-rotate(180deg);
}
body.a11y-light img,
body.a11y-light canvas,
body.a11y-light video {
  filter: invert(1) hue-rotate(180deg);
}
body.a11y-motion *, body.a11y-motion *::before, body.a11y-motion *::after {
  animation-duration: 0.001ms !important;
  transition-duration: 0.001ms !important;
}
body.a11y-dyslexia, body.a11y-dyslexia p, body.a11y-dyslexia div {
  font-family: 'Arial', sans-serif !important;
  letter-spacing: 0.05em !important;
  word-spacing: 0.1em !important;
  line-height: 1.9 !important;
}
body.a11y-spacing * {
  letter-spacing: 0.1em !important;
  word-spacing: 0.15em !important;
  line-height: 1.95 !important;
}
body.a11y-links a {
  text-decoration: underline !important;
  outline: 1px solid rgba(201,147,43,0.5) !important;
  border-radius: 2px;
}
body.a11y-cursor, body.a11y-cursor * {
  cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Ccircle cx='8' cy='8' r='6' fill='rgba(201,147,43,0.8)'/%3E%3C/svg%3E") 8 8, auto !important;
}

/* ── PRESS LIGHT MODE ── */
/* TODO: press light toggle CSS — disabled until feature is fixed */


/* ── AI DEMO PREVIEW ── */
.demo-preview-wrap {
  margin: 16px 0 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.demo-play-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(201,147,43,0.06);
  border: 1px solid rgba(201,147,43,0.2);
  border-radius: 20px;
  padding: 7px 16px;
  cursor: pointer;
  transition: all 0.2s;
  width: fit-content;
}
.demo-play-btn:hover {
  background: rgba(201,147,43,0.12);
  border-color: rgba(201,147,43,0.4);
}
.demo-play-btn.playing {
  background: rgba(201,147,43,0.14);
  border-color: rgba(201,147,43,0.5);
}
.demo-icon { font-size: 0.9rem; }
.demo-label {
  font-family: 'Lato', sans-serif;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  color: rgba(201,147,43,0.75);
}
.demo-notice {
  font-family: 'Special Elite', cursive;
  font-size: 0.65rem;
  color: rgba(240,223,200,0.2);
  letter-spacing: 0.04em;
}

/* ── VAULT ── */
#vault-trigger {
  position: fixed;
  left: 0; top: 50%;
  transform: translateY(-50%);
  z-index: 400;
  display: none;
}
.vault-tab {
  background: rgba(14,10,6,0.92);
  border: 1px solid rgba(201,147,43,0.18);
  border-left: none;
  border-radius: 0 10px 10px 0;
  padding: 18px 10px;
  display: flex; flex-direction: column;
  align-items: center; gap: 10px;
  backdrop-filter: blur(10px);
  cursor: pointer;
  transition: all 0.3s;
  box-shadow: 4px 0 20px rgba(0,0,0,0.3);
}
.vault-tab:hover {
  background: rgba(28,18,10,0.97);
  border-color: rgba(201,147,43,0.35);
  padding-right: 14px;
}
.vault-icon { font-size: 1rem; }
.vault-text {
  font-family: 'Special Elite', cursive;
  font-size: 0.52rem; letter-spacing: 0.18em;
  color: rgba(201,147,43,0.45);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}
.vault-count {
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(201,147,43,0.12);
  border: 1px solid rgba(201,147,43,0.28);
  font-size: 0.52rem; color: rgba(201,147,43,0.6);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Lato', sans-serif;
}
#vault-overlay {
  position: fixed; inset: 0; z-index: 499;
  background: rgba(0,0,0,0);
  pointer-events: none;
  transition: background 0.4s;
}
#vault-overlay.on {
  background: rgba(0,0,0,0.5);
  pointer-events: auto;
}
#vault-drawer {
  position: fixed;
  left: -360px; top: 0;
  width: 320px; height: 100vh;
  z-index: 500;
  background: rgba(10,7,4,0.99);
  border-right: 1px solid rgba(201,147,43,0.1);
  box-shadow: 8px 0 40px rgba(0,0,0,0.7);
  transition: left 0.45s cubic-bezier(0.22,1,0.36,1);
  overflow-y: auto;
}
#vault-drawer.open { left: 0; }
.vault-header {
  padding: 32px 22px 18px;
  border-bottom: 1px solid rgba(201,147,43,0.07);
  position: sticky; top: 0;
  background: rgba(10,7,4,0.99);
  z-index: 1;
}
.vault-header-top {
  display: flex; align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.vault-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.15rem; color: rgba(232,184,75,0.85);
  font-weight: 400;
}
.vault-close {
  background: none; border: none;
  color: rgba(240,223,200,0.25);
  font-size: 1rem; cursor: pointer;
  padding: 4px 8px; transition: color 0.2s;
}
.vault-close:hover { color: rgba(240,223,200,0.6); }
.vault-subtitle {
  font-family: 'Special Elite', cursive;
  font-size: 0.58rem; letter-spacing: 0.1em;
  color: rgba(201,147,43,0.25);
  line-height: 1.7;
}
.vault-list { padding: 12px 0 80px; }
.vault-song {
  padding: 16px 22px;
  border-bottom: 1px solid rgba(201,147,43,0.05);
  transition: background 0.2s;
  cursor: pointer;
}
.vault-song:hover { background: rgba(201,147,43,0.04); }
.vs-top {
  display: flex; align-items: center; gap: 12px;
}
.vs-lock { font-size: 0.75rem; color: rgba(201,147,43,0.3); flex-shrink: 0; }
.vs-info { flex: 1; }
.vs-name {
  font-family: 'Playfair Display', serif;
  font-size: 0.92rem; color: rgba(240,223,200,0.7);
  font-style: italic;
}
.vs-year {
  font-size: 0.57rem; letter-spacing: 0.12em;
  color: rgba(201,147,43,0.28);
  margin-top: 3px;
}
.vs-arrow {
  font-size: 0.75rem; color: rgba(201,147,43,0.2);
  transition: transform 0.3s, color 0.2s;
}
.vs-demo {
  max-height: 0; overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.22,1,0.36,1);
}
.vs-demo.open { max-height: 600px; }
.vs-demo-inner {
  padding: 14px 0 4px 26px;
  display: flex; flex-direction: column; gap: 8px;
}
.vs-play-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(201,147,43,0.07);
  border: 1px solid rgba(201,147,43,0.18);
  border-radius: 16px; padding: 6px 14px;
  cursor: pointer; transition: all 0.2s; width: fit-content;
}
.vs-play-btn:hover, .vs-play-btn.playing {
  background: rgba(201,147,43,0.14);
  border-color: rgba(201,147,43,0.38);
}
.vs-play-icon { font-size: 0.8rem; }
.vs-play-label {
  font-weight: 400;
  font-size: 0.64rem; letter-spacing: 0.08em;
  color: rgba(201,147,43,0.7);
}
.vs-demo-note {
  font-family: 'Special Elite', cursive;
  font-size: 0.57rem; color: rgba(240,223,200,0.14);
  letter-spacing: 0.04em;
}
@keyframes catFlip{
  from{opacity:0;transform:rotateY(-90deg) scale(0.85);}
  to{opacity:1;transform:rotateY(0deg) scale(1);}
}
.song-date {
  font-family: 'Caveat', cursive;
font-size: 0.75rem;
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  color: rgba(201,147,43,0.35);
  text-transform: uppercase;
  margin-bottom: 3px;
}