/* ============================================================
   Vox Caeli — shared stylesheet (elevated dawn theme)
   ============================================================ */
:root{
  --bg:#FBF9F5; --bg-warm:#FDF6EC; --surface:#FFFFFF; --surface-2:#FBF5EE;
  --primary:#7D562D; --primary-deep:#5C3E1F;
  --accent:#D4A373; --accent-2:#C8956A; --accent-soft:#E8D5C4; --gold:#E9C893;
  --ink:#3A322B; --ink-soft:#6F665C; --muted:#A2978A;
  --border:#ECE2D7; --line:#F2EBE1;
  --r-hero:40px; --r-card:26px; --r-sm:14px; --r-pill:9999px;
  --shadow-sm:0 4px 18px rgba(125,86,45,.07);
  --shadow-md:0 18px 50px rgba(125,86,45,.13);
  --shadow-lg:0 30px 80px rgba(92,62,31,.18);
  --serif:'Noto Serif KR',Georgia,serif;
  --sans:'Inter','Noto Sans KR','Apple SD Gothic Neo','Malgun Gothic',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --latin:'Cormorant Garamond','Noto Serif KR',Georgia,serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --player-h:92px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;
  line-height:1.6;overflow-x:hidden;padding-bottom:calc(var(--player-h) + 10px)}
body::before{content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(1100px 620px at 78% -8%, rgba(233,200,147,.40), transparent 60%),
  radial-gradient(900px 520px at 10% 4%, rgba(232,213,196,.42), transparent 62%),
  linear-gradient(180deg,#FDF7EE 0%,#FBF9F5 38%,#FAF6F0 100%)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--accent-soft);color:var(--primary-deep)}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.reveal{opacity:0;transform:translateY(26px);transition:.8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:60;transition:.4s var(--ease)}
header.nav .bar{display:flex;align-items:center;justify-content:space-between;padding:16px 0;transition:.4s var(--ease)}
header.nav.scrolled{background:rgba(251,249,245,.80);backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:9px;font-family:var(--serif);font-weight:700;font-size:1.42rem;color:var(--primary);letter-spacing:.01em}
.brand .star{color:var(--accent);font-size:1.05em;animation:twinkle 4s ease-in-out infinite}
nav.links{display:flex;align-items:center;gap:34px}
nav.links a{font-weight:500;font-size:.96rem;color:var(--ink-soft);position:relative;transition:.25s}
nav.links a.active{color:var(--primary)}
nav.links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));border-radius:2px;transition:.3s var(--ease)}
nav.links a:hover::after,nav.links a.active::after{width:100%}
nav.links a:hover{color:var(--primary)}
.lang{display:flex;gap:2px;align-items:center;margin-left:8px;padding:5px 6px;border:1px solid var(--border);
  border-radius:var(--r-pill);background:rgba(255,255,255,.55);font-size:.74rem}
.lang button{border:0;background:transparent;cursor:pointer;font-family:var(--sans);font-weight:600;color:var(--muted);
  padding:3px 9px;border-radius:var(--r-pill);transition:.2s;letter-spacing:.04em}
.lang button.on{background:var(--primary);color:#fff}
.lang button:not(.on):hover{color:var(--primary)}
.burger{display:none;border:0;background:transparent;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger span{width:24px;height:2px;background:var(--primary);border-radius:2px;transition:.3s}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:.98rem;
  border:0;cursor:pointer;border-radius:var(--r-pill);padding:15px 28px;transition:.3s var(--ease)}
.btn-primary{background:linear-gradient(135deg,var(--accent) 0%,var(--primary) 92%);color:#fff;box-shadow:0 12px 30px rgba(125,86,45,.30)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(125,86,45,.40)}
.btn-ghost{background:rgba(255,255,255,.6);color:var(--primary);border:1px solid var(--border)}
.btn-ghost:hover{background:#fff;transform:translateY(-3px);box-shadow:var(--shadow-sm)}

/* ---------- HERO (home) ---------- */
.hero{position:relative;padding:54px 0 30px}
.hero-card{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
  background:linear-gradient(140deg,#fff 0%,#FFFDFA 60%,#FCF5EC 100%);border:1px solid var(--line);
  border-radius:var(--r-hero);box-shadow:var(--shadow-lg);padding:60px;overflow:hidden}
.hero-card::before{content:"";position:absolute;top:-40%;right:-6%;width:60%;height:160%;
  background:conic-gradient(from 200deg at 60% 30%, transparent 0deg, rgba(233,200,147,.22) 30deg, transparent 70deg);filter:blur(8px);pointer-events:none}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-weight:600;letter-spacing:.32em;font-size:.72rem;
  text-transform:uppercase;color:var(--accent-2);margin-bottom:22px}
.eyebrow .star{animation:twinkle 3.4s ease-in-out infinite}
.hero h1{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:clamp(2.5rem,5.2vw,4rem);line-height:1.16;letter-spacing:-.01em}
.hero .latin{font-family:var(--latin);font-style:italic;font-size:1.18rem;color:var(--accent-2);margin-top:14px}
.hero p.lead{margin-top:18px;max-width:430px;color:var(--ink-soft);font-size:1.04rem}
.hero .cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.hero-art{position:relative}
.hero-art .frame{position:relative;border-radius:30px;overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:1/1;background:var(--surface-2)}
.hero-art .frame img{width:100%;height:100%;object-fit:cover;transition:1.6s var(--ease);transform:scale(1.04)}
.hero-art:hover .frame img{transform:scale(1.1)}
.hero-art .frame::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%, rgba(255,247,230,.55), transparent 55%)}
.hero-play{position:absolute;bottom:18px;left:18px;display:flex;align-items:center;gap:12px;background:rgba(255,253,250,.82);
  backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.7);padding:9px 18px 9px 9px;border-radius:var(--r-pill);box-shadow:var(--shadow-md);cursor:pointer;transition:.3s}
.hero-play:hover{transform:translateY(-2px)}
.hero-play .disc{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,var(--accent),var(--primary))}
.hero-play .meta{line-height:1.25}
.hero-play .meta b{font-family:var(--serif);font-size:.92rem;color:var(--primary);display:block}
.hero-play .meta small{font-size:.72rem;color:var(--muted)}
.float-star{position:absolute;color:var(--gold);pointer-events:none;opacity:0;animation:floatStar 7s ease-in-out infinite}

/* ---------- PAGE HEADER (subpages) ---------- */
.pagehead{position:relative;padding:64px 0 30px;text-align:center}
.pagehead .eyebrow{justify-content:center}
.pagehead h1{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:clamp(2rem,4.4vw,3rem);line-height:1.2}
.pagehead p{color:var(--ink-soft);margin-top:12px;font-size:1rem}
.crumb{display:inline-flex;align-items:center;gap:7px;color:var(--accent-2);font-weight:600;font-size:.85rem;margin-bottom:18px}
.crumb:hover{color:var(--primary)}

/* ---------- SECTION SHELL ---------- */
section.block{padding:52px 0}
.head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px;gap:20px}
.head h2{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:1.85rem;display:flex;align-items:center;gap:11px;letter-spacing:-.01em}
.head h2 .star{color:var(--accent);font-size:.8em}
.head .more{font-size:.88rem;color:var(--accent-2);font-weight:600;display:inline-flex;gap:6px;transition:.25s}
.head .more:hover{gap:11px;color:var(--primary)}

/* ---------- CARD RAIL / GRID ---------- */
.rail{display:grid;grid-auto-flow:column;grid-auto-columns:236px;gap:22px;overflow-x:auto;padding:6px 2px 22px;
  scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:var(--accent-soft) transparent}
.rail::-webkit-scrollbar{height:8px}
.rail::-webkit-scrollbar-thumb{background:var(--accent-soft);border-radius:8px}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:24px}
.scard{scroll-snap-align:start;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);
  overflow:hidden;cursor:pointer;transition:.4s var(--ease);position:relative}
.scard:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);border-color:var(--accent-soft)}
.thumb{position:relative;aspect-ratio:1/1;background:linear-gradient(135deg,#F3EADF,#EBDECF);overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .7s var(--ease)}
.thumb img.loaded{opacity:1}
.thumb .shimmer{position:absolute;inset:0;background:linear-gradient(100deg,#F1E7DB 30%,#F8F0E6 50%,#F1E7DB 70%);background-size:200% 100%;animation:shimmer 1.5s infinite}
.thumb img.loaded ~ .shimmer{display:none}
.play-ov{position:absolute;inset:0;display:grid;place-items:center;opacity:0;transition:.35s;background:linear-gradient(180deg,transparent 40%,rgba(92,62,31,.45))}
.scard:hover .play-ov{opacity:1}
.play-ov .pbtn{width:54px;height:54px;border-radius:50%;background:rgba(255,253,250,.92);display:grid;place-items:center;color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(8px);transition:.35s}
.scard:hover .play-ov .pbtn{transform:none}
.scard .info{padding:15px 16px 18px}
.scard .info b{font-family:var(--serif);font-weight:600;font-size:1rem;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.scard .info .sub{display:flex;align-items:center;justify-content:space-between;margin-top:7px;font-size:.78rem;color:var(--muted)}
.badge{background:var(--surface-2);color:var(--accent-2);border:1px solid var(--line);padding:3px 10px;border-radius:var(--r-pill);font-weight:600;font-size:.7rem}

/* ---------- DUO (most played + albums) ---------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:48px}
.rank{display:flex;flex-direction:column;gap:10px}
.rrow{display:flex;align-items:center;gap:16px;padding:12px 14px;border-radius:var(--r-sm);cursor:pointer;transition:.25s;border:1px solid transparent}
.rrow:hover{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-sm)}
.rrow .no{font-family:var(--serif);font-size:1.2rem;color:var(--accent-2);width:26px;text-align:center;font-weight:600}
.rrow .rt{width:48px;height:48px;border-radius:11px;overflow:hidden;flex:0 0 auto;background:var(--surface-2)}
.rrow .rt img{width:100%;height:100%;object-fit:cover}
.rrow .rmeta{flex:1;min-width:0}
.rrow .rmeta b{font-family:var(--serif);font-weight:600;font-size:.98rem;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rrow .rmeta small{font-size:.76rem;color:var(--muted)}
.rrow .rtime{font-size:.8rem;color:var(--muted);font-variant-numeric:tabular-nums}
.rrow .eq{display:none;gap:2px;align-items:flex-end;height:15px}
.rrow.playing .eq{display:flex}
.rrow.playing .no{display:none}
.eq i{width:3px;background:var(--accent);border-radius:2px;animation:eq .9s ease-in-out infinite}
.eq i:nth-child(2){animation-delay:.2s}.eq i:nth-child(3){animation-delay:.4s}.eq i:nth-child(4){animation-delay:.1s}

.albums{display:flex;flex-direction:column;gap:18px}
.acard{display:flex;gap:18px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:16px;cursor:pointer;transition:.4s var(--ease)}
.acard:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:var(--accent-soft)}
.acard .ac-art{width:100px;height:100px;border-radius:18px;overflow:hidden;flex:0 0 auto;box-shadow:var(--shadow-sm)}
.acard .ac-art img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease)}
.acard:hover .ac-art img{transform:scale(1.08)}
.acard .ac-info b{font-family:var(--serif);font-weight:700;font-size:1.22rem;color:var(--primary);display:block}
.acard .ac-info .ac-sub{font-size:.82rem;color:var(--muted);margin:5px 0 9px}
.acard .ac-info p{font-size:.86rem;color:var(--ink-soft);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-width:340px}

/* ---------- ALBUM GRID (albums.html) ---------- */
.albumgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:28px}
.abig{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;cursor:pointer;transition:.4s var(--ease)}
.abig:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--accent-soft)}
.abig .ab-cover{aspect-ratio:1/1;overflow:hidden;position:relative}
.abig .ab-cover img{width:100%;height:100%;object-fit:cover;transition:.7s var(--ease)}
.abig:hover .ab-cover img{transform:scale(1.07)}
.abig .ab-body{padding:20px 22px 24px}
.abig .ab-body b{font-family:var(--serif);font-weight:700;font-size:1.3rem;color:var(--primary);display:block}
.abig .ab-body .ab-sub{font-size:.82rem;color:var(--muted);margin:6px 0 10px}
.abig .ab-body p{font-size:.88rem;color:var(--ink-soft);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- SONG LIST (songs.html / album.html) ---------- */
.songlist{display:flex;flex-direction:column;gap:6px}
.slrow{display:grid;grid-template-columns:36px 52px 1fr auto auto;align-items:center;gap:16px;padding:11px 16px;
  border-radius:var(--r-sm);cursor:pointer;transition:.22s;border:1px solid transparent}
.slrow:hover{background:var(--surface);border-color:var(--line);box-shadow:var(--shadow-sm)}
.slrow .sx{font-family:var(--serif);color:var(--accent-2);font-weight:600;text-align:center;font-variant-numeric:tabular-nums}
.slrow .st{width:52px;height:52px;border-radius:11px;overflow:hidden;background:var(--surface-2)}
.slrow .st img{width:100%;height:100%;object-fit:cover}
.slrow .sm{min-width:0}
.slrow .sm b{font-family:var(--serif);font-weight:600;font-size:1rem;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.slrow .sm small{font-size:.78rem;color:var(--muted)}
.slrow .sp{font-size:.8rem;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}
.slrow .sd{font-size:.82rem;color:var(--muted);font-variant-numeric:tabular-nums}
.slrow.playing .sx{display:none}
.slrow .eq{display:none;gap:2px;align-items:flex-end;height:15px;justify-content:center}
.slrow.playing .eq{display:flex}

/* ---------- SONG DETAIL (song.html) ---------- */
.song-hero{display:grid;grid-template-columns:340px 1fr;gap:46px;align-items:start;padding:30px 0 10px}
.song-cover{position:relative;border-radius:30px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:1/1;background:var(--surface-2)}
.song-cover img{width:100%;height:100%;object-fit:cover}
.song-cover .glow{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%, rgba(255,247,230,.5), transparent 55%)}
.song-meta .album-tag{display:inline-flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--line);
  color:var(--accent-2);font-weight:600;font-size:.78rem;padding:5px 14px;border-radius:var(--r-pill)}
.song-meta h1{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:clamp(1.9rem,3.8vw,2.7rem);line-height:1.2;margin:16px 0 10px}
.song-meta .stats{display:flex;gap:18px;color:var(--muted);font-size:.9rem;margin-bottom:24px}
.song-actions{display:flex;gap:12px;flex-wrap:wrap}
.story{margin-top:44px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-card);padding:30px 34px;box-shadow:var(--shadow-sm)}
.story h3,.lyrics-block h3{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:1.3rem;display:flex;align-items:center;gap:10px;margin-bottom:16px}
.story h3 .star,.lyrics-block h3 .star{color:var(--accent);font-size:.85em}
.story p{color:var(--ink-soft);font-size:1rem;line-height:1.85;white-space:pre-wrap}
.lyrics-block{margin-top:30px;background:linear-gradient(160deg,#FFFDFA,#FCF5EC);border:1px solid var(--line);border-radius:var(--r-card);padding:30px 34px;box-shadow:var(--shadow-sm)}
.lyrics{display:flex;flex-direction:column;gap:4px}
.lyric-line{padding:9px 4px;border-radius:8px;transition:.2s}
.lyric-line.latin{font-family:var(--latin);font-style:italic;font-size:1.18rem;color:var(--primary);line-height:1.5}
.lyric-line.kor{color:var(--ink-soft);font-size:.96rem;line-height:1.6;margin-bottom:6px}
.lyric-pair{padding:8px 12px;border-radius:10px;transition:.2s}
.lyric-pair:hover{background:rgba(212,163,115,.10)}
.song-nav{display:flex;justify-content:space-between;gap:16px;margin-top:36px}
.song-nav a{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);padding:16px 20px;transition:.3s var(--ease);min-width:0}
.song-nav a:hover{box-shadow:var(--shadow-sm);border-color:var(--accent-soft);transform:translateY(-2px)}
.song-nav a small{display:block;color:var(--muted);font-size:.74rem;margin-bottom:4px}
.song-nav a b{font-family:var(--serif);color:var(--primary);font-weight:600;font-size:.98rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.song-nav a.next{text-align:right}
.song-nav a.disabled{opacity:.4;pointer-events:none}

/* ---------- VISION ---------- */
.vision{position:relative;margin:30px 0 10px;padding:72px 0;text-align:center;overflow:hidden}
.vision::before{content:"";position:absolute;inset:0;z-index:-1;border-radius:var(--r-hero);
  background:radial-gradient(120% 120% at 50% 0%, rgba(233,200,147,.30), transparent 60%),linear-gradient(160deg,#FCF5EB,#FBF9F5)}
.vision .divider{width:54px;height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);margin:0 auto 26px}
.vision .verse{font-family:var(--latin);font-style:italic;font-size:1.5rem;color:var(--accent-2);margin-bottom:14px}
.vision h3{font-family:var(--serif);font-weight:700;color:var(--primary);font-size:clamp(1.5rem,3.4vw,2.2rem);line-height:1.4;max-width:760px;margin:0 auto 18px}
.vision p{max-width:560px;margin:0 auto;color:var(--ink-soft);font-size:1.02rem}
.vision .seal{display:inline-flex;margin-top:26px;align-items:center;gap:10px;color:var(--accent-2);font-weight:600;letter-spacing:.2em;font-size:.74rem;text-transform:uppercase}

/* ---------- FOOTER ---------- */
footer.foot{padding:60px 0 40px;text-align:center;border-top:1px solid var(--line);margin-top:30px}
footer.foot .brand{justify-content:center;margin-bottom:14px}
footer.foot .verse{font-family:var(--latin);font-style:italic;color:var(--ink-soft);font-size:1.02rem}
footer.foot .flang{display:flex;gap:18px;justify-content:center;margin:20px 0;font-size:.84rem;color:var(--muted)}
footer.foot .flang a{cursor:pointer}
footer.foot .flang a:hover{color:var(--primary)}
footer.foot .copy{font-size:.78rem;color:var(--muted);margin-top:10px}

/* ---------- PLAYER ---------- */
.player{position:fixed;left:0;right:0;bottom:0;z-index:90;height:var(--player-h);background:rgba(252,248,242,.86);
  backdrop-filter:blur(22px) saturate(1.5);-webkit-backdrop-filter:blur(22px) saturate(1.5);border-top:1px solid var(--border);
  box-shadow:0 -16px 50px rgba(92,62,31,.12);transform:translateY(120%);transition:.55s var(--ease)}
.player.up{transform:none}
.player .pin{max-width:1200px;margin:0 auto;height:100%;padding:0 24px;display:grid;grid-template-columns:minmax(180px,1fr) 2.2fr minmax(120px,1fr);align-items:center;gap:18px}
.np{display:flex;align-items:center;gap:14px;min-width:0}
.np .cov{width:58px;height:58px;border-radius:13px;overflow:hidden;flex:0 0 auto;box-shadow:var(--shadow-sm);background:var(--surface-2)}
.np .cov img{width:100%;height:100%;object-fit:cover}
.np .nm{min-width:0}
.np .nm b{font-family:var(--serif);font-weight:600;font-size:.96rem;color:var(--ink);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np .nm small{font-size:.76rem;color:var(--muted)}
.ctrls{display:flex;flex-direction:column;align-items:center;gap:7px}
.ctrls .btns{display:flex;align-items:center;gap:18px}
.ctrls button{border:0;background:transparent;cursor:pointer;color:var(--ink-soft);display:grid;place-items:center;transition:.2s;padding:4px}
.ctrls button:hover{color:var(--primary);transform:scale(1.12)}
.ctrls .main{width:46px;height:46px;border-radius:50%;color:#fff;background:linear-gradient(135deg,var(--accent),var(--primary));box-shadow:0 8px 20px rgba(125,86,45,.32)}
.ctrls .main:hover{transform:scale(1.07)}
.ctrls .rep.on{color:var(--accent)}
.seek{display:flex;align-items:center;gap:11px;width:100%;max-width:520px}
.seek .t{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums;width:34px;text-align:center}
input[type=range]{-webkit-appearance:none;appearance:none;height:5px;border-radius:5px;cursor:pointer;
  background:linear-gradient(90deg,var(--accent) var(--p,0%),var(--accent-soft) var(--p,0%));flex:1;outline:none}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 2px 6px rgba(125,86,45,.3);transition:.15s}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.25)}
input[type=range]::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:#fff;border:2px solid var(--accent)}
.vol{display:flex;align-items:center;gap:10px;justify-content:flex-end}
.vol input[type=range]{max-width:96px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:900px){
  .hero-card{grid-template-columns:1fr;padding:40px 30px;gap:30px}
  .hero-art{order:-1;max-width:380px;margin:0 auto}
  .duo{grid-template-columns:1fr;gap:40px}
  .song-hero{grid-template-columns:1fr;gap:28px}
  .song-cover{max-width:340px;margin:0 auto}
  nav.links{display:none}
  .burger{display:flex}
  nav.links.open{display:flex;position:absolute;top:64px;right:20px;flex-direction:column;background:rgba(252,248,242,.97);
    backdrop-filter:blur(16px);padding:20px 26px;border-radius:18px;box-shadow:var(--shadow-md);border:1px solid var(--line);gap:18px;z-index:80}
}
@media(max-width:680px){
  .wrap{padding:0 18px}
  .player .pin{grid-template-columns:1fr auto;gap:12px;padding:0 14px}
  .seek{display:none}
  .vol{display:none}
  .ctrls{grid-column:2}
  .ctrls .btns{gap:14px}
  .hero h1{font-size:2.3rem}
  .vision{padding:54px 0}
  .slrow{grid-template-columns:28px 46px 1fr auto;gap:12px}
  .slrow .sp{display:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}

@keyframes twinkle{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.45;transform:scale(.82)}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes eq{0%,100%{height:4px}50%{height:15px}}
@keyframes floatStar{0%{opacity:0;transform:translateY(10px) scale(.6)}25%{opacity:.9}75%{opacity:.7}100%{opacity:0;transform:translateY(-26px) scale(1)}}

.lyrics-plain{white-space:pre-wrap;color:var(--ink-soft);font-size:1.04rem;line-height:1.9;font-family:var(--sans)}

/* 재생 중 표시 (하단 플레이어) */
.np{min-width:0}
.np .np-now{display:none;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2);font-weight:700;margin-bottom:1px}
.player.up .np .np-now{display:block}
.np .nm b{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.25}
.np .cov{position:relative}
.cov-eq{position:absolute;right:3px;bottom:3px;display:none;gap:2px;align-items:flex-end;height:11px;padding:2px 3px;border-radius:5px;background:rgba(92,62,31,.55)}
.player.playing .cov-eq{display:flex}
.cov-eq i{width:2px;background:#fff;border-radius:1px;animation:eq .9s ease-in-out infinite}
.cov-eq i:nth-child(2){animation-delay:.25s}
.cov-eq i:nth-child(3){animation-delay:.45s}
