/* ==========================================================
   OrbiPlay Design System — Clean v5
   Tema: Branco puro | Acento: #f3c639 | Fundo: #f7f8fa
   ========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ── TOKENS ────────────────────────────────────────────── */
:root {
  --bg:          #f7f8fa;
  --surface:     #ffffff;
  --hover:       #f0f1f4;
  --active:      #e4e5e9;

  --accent:      #f3c639;
  --accent-dark: #c99a00;
  --accent-dim:  rgba(243,198,57,.12);
  --accent-bdr:  rgba(243,198,57,.35);

  --text:        #111111;
  --text-2:      #444444;
  --text-3:      #777777;
  --text-4:      #aaaaaa;

  --border:      rgba(0,0,0,.08);
  --border-2:    rgba(0,0,0,.14);

  --blue:  #2563eb;
  --red:   #dc2626;
  --green: #16a34a;

  --sh-sm: 0 1px 4px rgba(0,0,0,.07);
  --sh:    0 4px 16px rgba(0,0,0,.09);
  --sh-lg: 0 12px 40px rgba(0,0,0,.12);

  --r4:  4px;  --r8:  8px;  --r12: 12px;
  --r16: 16px; --r24: 24px; --pill: 999px;

  --nav-h:     64px;
  --bar-h:     44px;
  --player-h:  80px;
  --sidebar-w: 240px;
  --max-w:     1320px;

  --ease:   cubic-bezier(.4,0,.2,1);
  --spring: cubic-bezier(.34,1.56,.64,1);
  --t1: .12s; --t2: .22s;

  --ff-display: 'Outfit', sans-serif;
  --ff-body:    'Plus Jakarta Sans', sans-serif;

  /* Compat aliases — used across legacy pages */
  --b1:          rgba(0,0,0,.07);
  --gold:        #d4a017;
  --gold-border: rgba(212,160,23,.28);
  --t3:          #777777;
  --t4:          #aaaaaa;
  --t2:          #444444;
  --t1-color:    #111111;
}

/* ── RESET ─────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:hidden; max-width:100vw; }
body {
  background:var(--bg); color:var(--text);
  font-family:var(--ff-body); font-size:15px; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; background:none; border:none; color:inherit; }
input,select,textarea { font-family:inherit; }
ul,ol { list-style:none; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:#ddd; border-radius:4px; }


/* ── BRAND MARK ─────────────────────────────────────────── */
.brand {
  font-family:var(--ff-display);
  font-size:24px;
  font-weight:900;
  letter-spacing:-.04em;
  background:linear-gradient(135deg,#c99a00,#f3c639);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  display:inline-block;
}
a.brand, button.brand { cursor:pointer; transition:opacity var(--t1); }
a.brand:hover, button.brand:hover { opacity:.85; }
.music-top-bar .brand { font-size:21px; }
/* ── LOADER ────────────────────────────────────────────── */
#loader {
  position:fixed; inset:0; z-index:9999; background:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  transition:opacity .5s var(--ease),visibility .5s var(--ease);
}
#loader.hide { opacity:0; visibility:hidden; pointer-events:none; }
.loader-brand {
  font-family:var(--ff-display); font-size:28px; font-weight:900; letter-spacing:-.04em;
  background:linear-gradient(135deg,#c99a00,#f3c639);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  margin-bottom:24px;
}
.dots-loader { display:flex; gap:8px; }
.dots-loader span {
  width:10px; height:10px; border-radius:50%; background:var(--accent);
  animation:dotB 1.2s infinite ease-in-out;
}
.dots-loader span:nth-child(2) { animation-delay:.2s; }
.dots-loader span:nth-child(3) { animation-delay:.4s; }
@keyframes dotB { 0%,80%,100%{transform:scale(.8);opacity:.4;} 40%{transform:scale(1.3);opacity:1;} }
.loader-text { margin-top:14px; font-size:13px; color:var(--text-4); }

/* ── APP BAR ───────────────────────────────────────────── */
.app-bar, .app-download-bar {
  height:var(--bar-h); background:var(--accent);
  display:flex; align-items:center; justify-content:center; gap:12px; padding:0 20px;
  position:fixed; top:0; left:0; right:0; z-index:301;
}
.app-bar__text, .app-download-bar__text { font-size:13px; font-weight:600; color:#5a3d00; }
.app-bar__btn, .app-download-bar__btn {
  font-family:var(--ff-display); font-size:11px; font-weight:800;
  text-transform:uppercase; letter-spacing:.07em;
  color:#5a3d00; padding:5px 16px;
  background:rgba(255,255,255,.45); border:1.5px solid rgba(0,0,0,.14);
  border-radius:var(--pill); transition:background var(--t1);
}
.app-bar__btn:hover, .app-download-bar__btn:hover { background:rgba(255,255,255,.7); }

/* ── TOPBAR ────────────────────────────────────────────── */
.topbar {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--nav-h);
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border); box-shadow:var(--sh-sm);
  display:flex; align-items:center; justify-content:space-between; padding:0 32px;
}
.topbar.has-app-bar { top:var(--bar-h); }
.topbar.scrolled { box-shadow:var(--sh); }
.nav-left { display:flex; align-items:center; gap:28px; }
.nav-right { display:flex; align-items:center; gap:8px; }

/* Brand */


.nav-links { display:flex; align-items:center; gap:2px; }
.nav-link {
  font-size:14px; font-weight:500; color:var(--text-3);
  padding:7px 12px; border-radius:var(--r8); transition:all var(--t1);
}
.nav-link:hover { color:var(--text); background:var(--hover); }
.nav-link.active { color:var(--text); font-weight:600; }

/* Pills */
.pill {
  font-family:var(--ff-display); font-size:13.5px; font-weight:600;
  color:var(--text-3); padding:8px 18px; border-radius:var(--pill);
  border:1.5px solid transparent; transition:all var(--t2);
}
.pill:hover { color:var(--text); background:var(--hover); border-color:var(--border-2); }
.pill.brand-pill, .pill.brand {
  background:var(--accent) !important; color:#111 !important;
  -webkit-text-fill-color:#111 !important;
  -webkit-background-clip:unset !important;
  background-clip:unset !important;
  border-color:var(--accent) !important; font-weight:700;
}
.pill.brand-pill:hover, .pill.brand:hover { background:var(--accent-dark) !important; border-color:var(--accent-dark) !important; }

.settings-pill {
  display:flex; align-items:center; gap:7px;
  font-size:13px; font-weight:600; color:var(--text-2);
  padding:7px 16px; border-radius:var(--pill);
  border:1.5px solid var(--border-2); background:var(--surface);
  transition:all var(--t1);
}
.settings-pill:hover { background:var(--hover); color:var(--text); }
.settings-pill__icon { display:flex; align-items:center; }
.settings-pill__icon svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:1.8; transition:transform .4s; }
.settings-pill:hover .settings-pill__icon svg { transform:rotate(60deg); }

.lang-wrap { position:relative; }
.lang-icon {
  width:36px; height:36px; border-radius:50%; border:1.5px solid var(--border-2);
  display:flex; align-items:center; justify-content:center; color:var(--text-3); transition:all var(--t1);
}
.lang-icon:hover { color:var(--text); background:var(--hover); }
.lang-icon svg { width:16px; height:16px; }
.lang-menu {
  position:absolute; top:calc(100% + 8px); right:0;
  background:var(--surface); border:1.5px solid var(--border);
  border-radius:var(--r12); padding:6px; min-width:170px;
  box-shadow:var(--sh-lg); z-index:400; display:none; flex-direction:column; gap:2px;
}
.lang-menu.open { display:flex; }
.lang-menu button { font-size:13px; font-weight:500; color:var(--text-2); padding:9px 13px; border-radius:var(--r8); text-align:left; transition:all var(--t1); }
.lang-menu button:hover { color:var(--text); background:var(--hover); }
.lang-menu button.active { color:var(--accent-dark); font-weight:700; }

/* ── BUTTONS ───────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  font-family:var(--ff-display); font-size:14.5px; font-weight:700;
  padding:12px 28px; border-radius:var(--pill);
  border:1.5px solid transparent; cursor:pointer; white-space:nowrap;
  transition:all var(--t2) var(--ease); flex-shrink:0;
}
.btn.primary { background:var(--accent); color:#111; border-color:var(--accent); }
.btn.primary:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-1px); box-shadow:0 4px 16px rgba(243,198,57,.4); }
.btn.secondary { background:var(--hover); color:var(--text-2); border-color:var(--border-2); }
.btn.secondary:hover { background:var(--active); color:var(--text); }
.btn.outline { background:transparent; color:var(--text-2); border-color:var(--border-2); }
.btn.outline:hover { background:var(--hover); color:var(--text); }
.btn.sm { font-size:12.5px; padding:8px 18px; }
.btn.lg { font-size:16px; padding:15px 36px; }
.btn.full { width:100%; }
.btn:disabled { opacity:.45; cursor:not-allowed; transform:none !important; box-shadow:none !important; }

/* ── PAGE ──────────────────────────────────────────────── */
.page { position:relative; min-height:100vh; overflow-x:hidden; }
/* shell pushes content below fixed bars */
.shell { position:relative; z-index:2; overflow-x:hidden; padding-top:calc(var(--bar-h) + var(--nav-h)); }
/* Pages without app-bar (auth, music) */
.shell.no-bar { padding-top:var(--nav-h); }
.container { max-width:var(--max-w); margin:0 auto; padding:0 32px; }
/* Remove wall/bg — hidden globally */
.bg, .bg-glow-1, .bg-glow-2, .wall, .poster { display:none !important; }

/* ── HERO ──────────────────────────────────────────────── */
.hero-wrap { background:#fff; padding:72px 0 56px; border-bottom:1px solid var(--border); overflow-x:hidden; }
.hero-body {
  max-width:var(--max-w); margin:0 auto; padding:0 32px;
  display:grid; grid-template-columns:1fr 400px; gap:60px; align-items:center;
}
.hero-label { display:inline-flex; align-items:center; gap:8px; margin-bottom:16px; }
.hero-label-dot { width:7px; height:7px; border-radius:50%; background:var(--accent); animation:pulse 2.2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{box-shadow:0 0 0 0 rgba(243,198,57,.5)} 50%{box-shadow:0 0 0 8px rgba(243,198,57,0)} }
.hero-label-text { font-family:var(--ff-display); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:var(--accent-dark); }
.hero-title { font-family:var(--ff-display); font-size:clamp(2rem,4.5vw,3.8rem); font-weight:900; line-height:1.06; letter-spacing:-.04em; color:var(--text); margin-bottom:18px; }
.hero-title .accent { color:var(--accent-dark); }
.hero-desc { font-size:16px; color:var(--text-3); line-height:1.7; max-width:500px; margin-bottom:32px; width:100%; }
.hero-email-wrap {
  display:flex; gap:8px; background:var(--bg); border:1.5px solid var(--border-2);
  border-radius:var(--pill); padding:6px 6px 6px 20px; margin-bottom:12px;
  box-shadow:var(--sh-sm); transition:border-color var(--t2);
  min-width:0; width:100%; box-sizing:border-box;
}
.hero-email-wrap:focus-within { border-color:var(--accent); box-shadow:0 0 0 3px rgba(243,198,57,.18); }
.hero-email-wrap input { flex:1; background:none; border:none; outline:none; font-size:15px; color:var(--text); }
.hero-email-wrap input::placeholder { color:var(--text-4); }
.hero-actions { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.hero-stats { display:flex; gap:16px; margin-top:28px; flex-wrap:wrap; min-width:0; }
.hero-stat { display:flex; flex-direction:column; gap:2px; }
.hero-stat strong { font-family:var(--ff-display); font-size:24px; font-weight:900; color:var(--text); }
.hero-stat span { font-size:11px; color:var(--text-4); text-transform:uppercase; letter-spacing:.09em; }
.hero-divider { width:1px; background:var(--border); align-self:stretch; margin:4px 0; }
.hero-col-right {}

/* Spotlight card */
.spotlight-card { background:var(--surface); border-radius:var(--r16); overflow:hidden; border:1.5px solid var(--border); box-shadow:var(--sh-lg); }
.spotlight-poster { aspect-ratio:16/9; overflow:hidden; position:relative; background:var(--hover); }
.spotlight-poster img { width:100%; height:100%; object-fit:cover; transition:transform 1.2s; }
.spotlight-card:hover .spotlight-poster img { transform:scale(1.04); }
.spotlight-poster::after { content:''; position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 55%); }
.spotlight-info { padding:14px 18px 18px; }
.spotlight-kicker { font-family:var(--ff-display); font-size:9.5px; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-dark); margin-bottom:5px; }
.spotlight-name { font-family:var(--ff-display); font-size:18px; font-weight:800; color:var(--text); margin-bottom:4px; }
.spotlight-text { font-size:12.5px; color:var(--text-3); display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:10px; }
.spotlight-tags { display:flex; gap:6px; flex-wrap:wrap; }
.spotlight-tag { font-size:10.5px; font-weight:600; color:var(--text-3); padding:3px 9px; background:var(--hover); border-radius:var(--pill); }
.spotlight-tag.score { color:var(--accent-dark); font-weight:700; }
.plans-mini { background:var(--bg); border:1.5px solid var(--border); border-radius:var(--r12); padding:14px 16px; margin-top:10px; }
.plans-mini-label { font-family:var(--ff-display); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.13em; color:var(--text-4); margin-bottom:8px; }
.plan-mini-row { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:var(--r8); cursor:pointer; transition:background var(--t1); }
.plan-mini-row:hover { background:var(--hover); }
.plan-mini-name { font-family:var(--ff-display); font-size:13px; font-weight:700; min-width:58px; color:var(--text); }
.plan-mini-desc { font-size:11px; color:var(--text-3); flex:1; }
.plan-mini-price { font-family:var(--ff-display); font-size:13px; font-weight:800; color:var(--accent-dark); }
.plan-mini-price small { font-size:10px; color:var(--text-4); font-family:var(--ff-body); font-weight:400; }

/* ── CONTENT SECTIONS ──────────────────────────────────── */
.content-section { padding:52px 0; }
.sec-container { max-width:var(--max-w); margin:0 auto; padding:0 32px; width:100%; box-sizing:border-box; }
.sec-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:20px; }
.sec-title { font-family:var(--ff-display); font-size:22px; font-weight:800; color:var(--text); }
.sec-title span { color:var(--accent-dark); }
.sec-sub { font-size:12.5px; color:var(--text-3); margin-top:3px; }
.sec-link { font-size:12px; font-weight:700; color:var(--text-3); text-transform:uppercase; letter-spacing:.07em; display:flex; align-items:center; gap:4px; transition:color var(--t1); }
.sec-link:hover { color:var(--text); }
.sec-link svg { width:13px; height:13px; }

/* ── RAILS ─────────────────────────────────────────────── */
.rail { display:flex; gap:10px; overflow-x:auto; padding-bottom:6px; scrollbar-width:none; }
.rail::-webkit-scrollbar { display:none; }
.card {
  flex:0 0 160px; border-radius:var(--r8); overflow:hidden;
  background:var(--surface); cursor:pointer; border:1px solid var(--border);
  transition:transform var(--t2) var(--spring),box-shadow var(--t2);
}
.card:hover { transform:scale(1.05); box-shadow:var(--sh-lg); border-color:var(--border-2); }
.card-poster { aspect-ratio:2/3; overflow:hidden; position:relative; background:var(--hover); }
.card-poster img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.card:hover .card-poster img { transform:scale(1.06); }
.card-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.5) 0%,transparent 50%); opacity:0; transition:opacity var(--t2); }
.card:hover .card-overlay { opacity:1; }
.card-play-btn {
  position:absolute; bottom:10px; left:50%; transform:translateX(-50%) translateY(6px);
  background:var(--accent); color:#111; font-family:var(--ff-display); font-size:10px; font-weight:800;
  letter-spacing:.05em; text-transform:uppercase; padding:5px 14px; border-radius:var(--pill);
  opacity:0; white-space:nowrap; transition:opacity var(--t2),transform var(--t2) var(--spring);
}
.card:hover .card-play-btn { opacity:1; transform:translateX(-50%) translateY(0); }
.card-info { padding:8px 10px 12px; }
.card-title { font-size:12.5px; font-weight:700; color:var(--text); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.card-meta { font-size:10.5px; color:var(--text-4); }
.card-land {
  flex:0 0 260px; border-radius:var(--r8); overflow:hidden;
  background:var(--surface); cursor:pointer; border:1px solid var(--border);
  transition:transform var(--t2) var(--spring),box-shadow var(--t2);
}
.card-land:hover { transform:scale(1.03); box-shadow:var(--sh-lg); }
.card-land-img { aspect-ratio:16/9; overflow:hidden; background:var(--hover); }
.card-land-img img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.card-land:hover .card-land-img img { transform:scale(1.05); }
.card-land-info { padding:9px 12px 12px; }
.card-land-title { font-size:12.5px; font-weight:700; color:var(--text); margin-bottom:2px; }
.card-land-meta { font-size:10.5px; color:var(--text-4); }

/* ── FEATURES ──────────────────────────────────────────── */
.features-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.feat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r12); padding:22px 20px; transition:all var(--t2); }
.feat-card:hover { border-color:var(--accent-bdr); box-shadow:var(--sh); transform:translateY(-2px); }
.feat-icon { width:46px; height:46px; border-radius:var(--r12); background:var(--hover); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; margin-bottom:14px; }
.feat-icon svg { width:22px; height:22px; stroke:var(--text-3); fill:none; stroke-width:1.6; }
.feat-icon.gold-icon { background:var(--accent-dim); border-color:var(--accent-bdr); }
.feat-icon.gold-icon svg { stroke:var(--accent-dark); }
.feat-card-title { font-family:var(--ff-display); font-size:15px; font-weight:800; color:var(--text); margin-bottom:7px; }
.feat-card-desc { font-size:13px; color:var(--text-3); line-height:1.6; }
.inner-eyebrow { font-family:var(--ff-display); font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:var(--accent-dark); }
.inner-title { font-family:var(--ff-display); font-size:clamp(26px,3.5vw,36px); font-weight:900; letter-spacing:-.04em; line-height:1.08; color:var(--text); }
.inner-hero { padding:64px 0; text-align:center; background:#fff; border-bottom:1px solid var(--border); }
.inner-hero-bg { display:none; }
.inner-desc { font-size:16px; color:var(--text-3); margin-top:12px; }

/* ── PLANS ─────────────────────────────────────────────── */
.plans-hero { background:var(--surface); padding:56px 0 48px; text-align:center; border-bottom:1px solid var(--border); }
.plans-hero h1 { font-family:var(--ff-display); font-size:clamp(28px,4vw,42px); font-weight:900; letter-spacing:-.04em; color:var(--text); margin-bottom:12px; }
.plans-hero p { font-size:15px; color:var(--text-3); max-width:520px; margin:0 auto; }
.plans-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:14px; max-width:1100px; margin:0 auto; padding:48px 32px 80px; }
.plan-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r16); padding:28px 24px; display:flex; flex-direction:column; gap:16px; position:relative; transition:all var(--t2); }
.plan-card:hover { border-color:var(--border-2); transform:translateY(-4px); box-shadow:var(--sh-lg); }
.plan-card.featured { border-color:var(--accent-bdr); background:linear-gradient(160deg,var(--accent-dim) 0%,var(--surface) 60%); }
.plan-badge-tag { position:absolute; top:16px; right:16px; font-family:var(--ff-display); font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:#111; padding:3px 10px; background:var(--accent); border-radius:var(--pill); }
.plan-tag { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); margin-bottom:-4px; }
.plan-name { font-family:var(--ff-display); font-size:22px; font-weight:900; color:var(--text); }
.plan-desc { font-size:13px; color:var(--text-3); line-height:1.6; flex:1; }
.plan-price { font-family:var(--ff-display); font-size:36px; font-weight:900; color:var(--accent-dark); letter-spacing:-.04em; }
.plan-price small { font-size:14px; color:var(--text-4); font-family:var(--ff-body); font-weight:400; }
.plan-divider { height:1px; background:var(--border); }
.plan-feats { display:flex; flex-direction:column; gap:8px; }
.plan-feat { display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--text-2); }
.plan-check { width:16px; height:16px; border-radius:50%; flex-shrink:0; margin-top:3px; background:var(--accent-dim); border:1px solid var(--accent-bdr); display:flex; align-items:center; justify-content:center; }
.plan-check svg { width:8px; height:8px; stroke:var(--accent-dark); stroke-width:2.5; fill:none; }
.plan-check.green-check { background:rgba(22,163,74,.1); border-color:rgba(22,163,74,.3); }
.plan-check.green-check svg { stroke:var(--green); }
.plan-cta-btn { display:block; text-align:center; background:var(--accent); color:#111; font-family:var(--ff-display); font-size:13.5px; font-weight:800; padding:12px 22px; border-radius:var(--pill); border:1.5px solid var(--accent); transition:all var(--t2) var(--spring); }
.plan-cta-btn:hover { background:var(--accent-dark); border-color:var(--accent-dark); transform:translateY(-2px); box-shadow:0 4px 16px rgba(243,198,57,.4); }
.plan-cta-btn.outline-cta { background:transparent; color:var(--text-2); border-color:var(--border-2); }
.plan-cta-btn.outline-cta:hover { background:var(--hover); box-shadow:none; }

/* ── AUTH ──────────────────────────────────────────────── */
.auth-wrap { display:grid; grid-template-columns:1fr 460px; min-height:calc(100vh - var(--bar-h) - var(--nav-h)); }
.auth-left { background:linear-gradient(145deg,#16213e,#0f3460); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:60px 40px; gap:32px; }
.auth-wordmark { font-family:var(--ff-display); font-size:28px; font-weight:900; color:var(--accent); }
.auth-left-title { font-family:var(--ff-display); font-size:clamp(22px,2.8vw,30px); font-weight:800; color:#fff; line-height:1.15; text-align:center; max-width:360px; }
.auth-left-desc { font-size:14px; color:rgba(255,255,255,.65); text-align:center; line-height:1.7; max-width:340px; }
.auth-feats { display:flex; flex-direction:column; gap:12px; width:100%; max-width:340px; }
.auth-feat { display:flex; align-items:center; gap:12px; }
.auth-feat-icon { width:38px; height:38px; border-radius:var(--r8); flex-shrink:0; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; }
.auth-feat-icon svg { width:18px; height:18px; stroke:rgba(255,255,255,.7); fill:none; stroke-width:1.6; }
.auth-feat-icon.gold { background:rgba(243,198,57,.15); border-color:rgba(243,198,57,.3); }
.auth-feat-icon.gold svg { stroke:var(--accent); }
.auth-feat-text strong { font-size:13px; font-weight:700; color:#fff; display:block; }
.auth-feat-text span { font-size:11.5px; color:rgba(255,255,255,.55); }
.auth-right { background:var(--surface); display:flex; align-items:center; justify-content:center; padding:48px 32px; }
.auth-card { width:100%; max-width:380px; }
.auth-eyebrow { font-family:var(--ff-display); font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-dark); margin-bottom:8px; display:block; }
.auth-card h1 { font-family:var(--ff-display); font-size:28px; font-weight:900; color:var(--text); margin-bottom:8px; }
.auth-card p { font-size:14px; color:var(--text-3); margin-bottom:24px; }
.enter-form { display:flex; flex-direction:column; gap:10px; }
.enter-form input, .enter-password-input {
  display:block; width:100%; background:var(--bg); border:1.5px solid var(--border-2);
  border-radius:var(--r8); padding:12px 16px; font-size:14.5px; color:var(--text); outline:none; transition:all var(--t2);
}
.enter-form input::placeholder, .enter-password-input::placeholder { color:var(--text-4); }
.enter-form input:focus, .enter-password-input:focus { border-color:var(--accent); background:var(--surface); box-shadow:0 0 0 3px rgba(243,198,57,.18); }
.enter-result { margin-top:10px; padding:12px 14px; border-radius:var(--r8); font-size:13px; line-height:1.5; display:none; }
.enter-result.is-error { background:rgba(220,38,38,.08); border:1px solid rgba(220,38,38,.25); color:#991b1b; display:block; }
.enter-result.is-success { background:rgba(22,163,74,.08); border:1px solid rgba(22,163,74,.25); color:#166534; display:block; }
.enter-result.is-info { background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.22); color:#1e40af; display:block; }
.auth-divider { display:flex; align-items:center; gap:12px; color:var(--text-4); font-size:12px; margin:4px 0; }
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1px; background:var(--border); }
.auth-note { font-size:13px; color:var(--text-3); }
.auth-note a { color:var(--accent-dark); font-weight:600; }

/* Signup */
.signup-wrap { max-width:560px; margin:0 auto; padding:48px 32px 80px; }
.signup-form { display:flex; flex-direction:column; gap:12px; }
.signup-form label { display:flex; flex-direction:column; gap:5px; }
.signup-form label span { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); }
.signup-form input, .signup-form select { background:var(--bg); border:1.5px solid var(--border-2); border-radius:var(--r8); padding:11px 14px; font-size:14px; color:var(--text); outline:none; transition:all var(--t2); }
.signup-form input::placeholder { color:var(--text-4); }
.signup-form input:focus, .signup-form select:focus { border-color:var(--accent); background:var(--surface); box-shadow:0 0 0 3px rgba(243,198,57,.18); }
#signupResult { margin-top:4px; padding:12px 14px; border-radius:var(--r8); font-size:13px; line-height:1.5; display:none; }
#signupResult.is-error { background:rgba(220,38,38,.08); border:1px solid rgba(220,38,38,.25); color:#991b1b; display:block; }
#signupResult.is-success { background:rgba(22,163,74,.08); border:1px solid rgba(22,163,74,.25); color:#166534; display:block; }
#signupResult.is-info { background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.22); color:#1e40af; display:block; }

/* ── FAQ ───────────────────────────────────────────────── */
.faq-inner { max-width:720px; margin:0 auto; padding:0 32px; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-question { width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 0; text-align:left; font-size:15.5px; font-weight:700; color:var(--text); }
.faq-icon { width:26px; height:26px; border-radius:50%; background:var(--hover); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:16px; color:var(--text-3); transition:all var(--t2); flex-shrink:0; }
.faq-question[aria-expanded="true"] .faq-icon { background:var(--accent-dim); border-color:var(--accent-bdr); color:var(--accent-dark); transform:rotate(45deg); }
.faq-answer { font-size:14.5px; color:var(--text-3); line-height:1.7; padding-bottom:20px; display:none; }
.faq-item.open .faq-answer { display:block; }

/* ── FOOTER ────────────────────────────────────────────── */
footer { background:var(--surface); border-top:1px solid var(--border); padding:52px 0 0; }
.footer-grid { max-width:var(--max-w); margin:0 auto; padding:0 32px; display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:40px; }
.footer-brand { margin-bottom:10px; }
.footer-brand-text { font-size:13px; color:var(--text-4); margin-top:8px; max-width:220px; }
.footer-col-title { font-family:var(--ff-display); font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--text-4); margin-bottom:14px; }
.footer-link { display:block; font-size:13.5px; color:var(--text-3); padding:4px 0; transition:color var(--t1); }
.footer-link:hover { color:var(--text); }
.footer-bottom { max-width:var(--max-w); margin:0 auto; border-top:1px solid var(--border); padding:20px 32px; display:flex; align-items:center; justify-content:space-between; margin-top:40px; }
.footer-copy { font-size:12.5px; color:var(--text-4); }
.footer-links { display:flex; gap:16px; }
.footer-links a { font-size:12.5px; color:var(--text-4); transition:color var(--t1); }
.footer-links a:hover { color:var(--text-3); }

/* ── COOKIE ────────────────────────────────────────────── */
.cookie-banner { position:fixed; bottom:0; left:0; right:0; z-index:700; background:var(--surface); border-top:1px solid var(--border); box-shadow:0 -4px 20px rgba(0,0,0,.08); display:flex; align-items:center; justify-content:space-between; padding:16px 24px; gap:16px; }
.cookie-banner[hidden] { display:none; }
.cookie-banner__title { font-size:14px; font-weight:800; color:var(--text); margin-bottom:3px; }
.cookie-banner__text { font-size:12.5px; color:var(--text-3); }
.cookie-banner__link { color:var(--accent-dark); font-weight:600; background:none; border:none; cursor:pointer; font-size:inherit; }
.cookie-banner__actions { display:flex; gap:8px; flex-shrink:0; }
.cookie-btn { font-family:var(--ff-body); font-size:13px; font-weight:700; padding:8px 18px; border-radius:var(--pill); cursor:pointer; transition:all var(--t1); }
.cookie-btn--ghost { background:transparent; border:1.5px solid var(--border-2); color:var(--text-3); }
.cookie-btn--ghost:hover { background:var(--hover); color:var(--text); }
.cookie-btn--brand { background:var(--accent); border:1.5px solid var(--accent); color:#111; }
.cookie-btn--brand:hover { background:var(--accent-dark); border-color:var(--accent-dark); }
.cookie-modal { position:fixed; inset:0; z-index:800; background:rgba(0,0,0,.35); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; }
.cookie-modal[aria-hidden="true"] { display:none; }
.cookie-modal__card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r16); padding:28px; max-width:480px; width:90%; box-shadow:var(--sh-lg); }
.cookie-modal__header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.cookie-modal__title { font-family:var(--ff-display); font-size:18px; font-weight:900; color:var(--text); }
.cookie-modal__close { font-size:18px; color:var(--text-3); padding:2px 6px; }
.cookie-modal__intro { font-size:13.5px; color:var(--text-3); margin-bottom:16px; }
.cookie-terms { display:flex; flex-direction:column; gap:12px; }
.cookie-terms section h3 { font-size:13px; font-weight:800; color:var(--text); margin-bottom:4px; }
.cookie-terms section p { font-size:12.5px; color:var(--text-3); }
.cookie-modal__footer { display:flex; gap:8px; justify-content:flex-end; margin-top:20px; }

/* ── SETTINGS MODAL ────────────────────────────────────── */
.settings-overlay { position:fixed; inset:0; z-index:800; background:rgba(0,0,0,.3); backdrop-filter:blur(8px); display:flex; align-items:flex-end; justify-content:flex-end; }
.settings-overlay[hidden] { display:none; }
.settings-backdrop { position:absolute; inset:0; }
.settings-panel { position:relative; z-index:1; width:100%; max-width:600px; height:100vh; background:var(--surface); border-left:1px solid var(--border); overflow-y:auto; display:flex; flex-direction:column; animation:slideIn .3s var(--ease) both; }
@keyframes slideIn { from{transform:translateX(100%)} to{transform:translateX(0)} }
.settings-panel::-webkit-scrollbar { width:4px; }
.settings-hdr { position:sticky; top:0; z-index:10; background:var(--surface); border-bottom:1px solid var(--border); padding:22px 26px; display:flex; align-items:flex-start; justify-content:space-between; gap:16px; }
.settings-tag { font-family:var(--ff-display); font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-dark); padding:3px 11px; background:var(--accent-dim); border:1px solid var(--accent-bdr); border-radius:var(--pill); display:inline-block; margin-bottom:8px; }
.settings-hdr h2 { font-family:var(--ff-display); font-size:22px; font-weight:900; color:var(--text); margin-bottom:3px; }
.settings-hdr p { font-size:12.5px; color:var(--text-3); }
.settings-hdr-actions { display:flex; align-items:center; gap:7px; flex-shrink:0; }
.settings-logout-btn { font-size:12.5px; font-weight:600; color:var(--text-3); padding:7px 14px; border:1.5px solid var(--border-2); border-radius:var(--pill); transition:all var(--t1); }
.settings-logout-btn:hover { color:var(--text); background:var(--hover); }
.settings-close-btn { width:36px; height:36px; border-radius:50%; border:1.5px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-3); transition:all var(--t1); }
.settings-close-btn:hover { border-color:var(--border-2); color:var(--text); background:var(--hover); }
.settings-body { display:flex; flex-direction:column; gap:14px; padding:20px 26px 48px; }
.settings-card { background:var(--bg); border:1.5px solid var(--border); border-radius:var(--r12); padding:20px 22px; }
.settings-card-title { margin-bottom:16px; }
.settings-card-title h3 { font-family:var(--ff-display); font-size:16px; font-weight:800; color:var(--text); margin-bottom:2px; }
.settings-card-title span { font-size:12px; color:var(--text-3); }
.settings-form { display:flex; flex-direction:column; gap:12px; }
.settings-form label { display:flex; flex-direction:column; gap:4px; }
.settings-form label span { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); }
.settings-form input { background:var(--surface); border:1.5px solid var(--border-2); border-radius:var(--r8); padding:11px 14px; font-size:14px; color:var(--text); outline:none; transition:all var(--t2); }
.settings-form input::placeholder { color:var(--text-4); }
.settings-form input:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(243,198,57,.18); }
.settings-form input:disabled { background:var(--hover); color:var(--text-4); cursor:not-allowed; }
.settings-form-actions { display:flex; gap:9px; margin-top:4px; flex-wrap:wrap; }
.settings-form-actions .btn { flex:1; min-width:110px; font-size:13px; padding:10px 16px; }
.settings-feedback { margin-top:10px; padding:11px 14px; border-radius:var(--r8); font-size:13px; line-height:1.5; }
.settings-feedback[hidden] { display:none; }
.settings-feedback.is-success { background:rgba(22,163,74,.08); border:1px solid rgba(22,163,74,.25); color:#166534; }
.settings-feedback.is-error { background:rgba(220,38,38,.08); border:1px solid rgba(220,38,38,.25); color:#991b1b; }
.settings-feedback.is-info { background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.22); color:#1e40af; }
.plan-status-row { display:grid; grid-template-columns:repeat(3,1fr); gap:9px; margin-bottom:16px; }
.plan-status-box { background:var(--surface); border:1px solid var(--border); border-radius:var(--r8); padding:12px 14px; }
.plan-status-box span { font-size:9.5px; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); display:block; margin-bottom:3px; }
.plan-status-box strong { font-size:14.5px; font-weight:800; color:var(--text); }
.unlocked-feats { margin-top:10px; }
.unlocked-feats h4 { font-size:11.5px; font-weight:700; color:var(--text-2); margin-bottom:8px; }
.unlock-chips { display:flex; flex-wrap:wrap; gap:5px; }
.unlock-chip { font-size:10px; font-weight:700; padding:3px 9px; border-radius:var(--pill); background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.2); color:var(--blue); }
.settings-tools { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.tool-card { display:flex; flex-direction:column; gap:4px; padding:14px 16px; border-radius:var(--r12); border:1.5px solid var(--border); background:var(--surface); text-align:left; cursor:pointer; transition:all var(--t1); }
.tool-card:hover { border-color:var(--border-2); background:var(--hover); transform:translateY(-1px); }
.tool-card strong { font-size:13.5px; font-weight:800; color:var(--text); }
.tool-card span { font-size:11.5px; color:var(--text-3); }
.tool-card.danger:hover { border-color:rgba(220,38,38,.3); background:rgba(220,38,38,.04); }
.upgrade-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:10px; }
.plan-upgrade-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r12); padding:16px 14px; }
.plan-upgrade-card.is-current { border-color:var(--accent-bdr); background:var(--accent-dim); }
.plan-upgrade-card__top { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.plan-upgrade-card__top strong { font-family:var(--ff-display); font-size:15px; font-weight:800; color:var(--text); }
.plan-upgrade-card__top span { font-size:10.5px; color:var(--text-4); }
.plan-upgrade-card p { font-size:12px; color:var(--text-3); margin-bottom:10px; }
.plan-upgrade-card ul { font-size:11.5px; color:var(--text-2); display:flex; flex-direction:column; gap:4px; margin-bottom:12px; padding-left:12px; list-style:disc; }
.coming-soon-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:10px; }
.cs-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r12); padding:14px; display:flex; flex-direction:column; gap:6px; }
.cs-badge { font-size:9px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--blue); padding:2px 8px; background:rgba(37,99,235,.08); border:1px solid rgba(37,99,235,.2); border-radius:var(--pill); display:inline-block; }
.cs-card h4 { font-size:14px; font-weight:800; color:var(--text); }
.cs-card p { font-size:11.5px; color:var(--text-3); flex:1; line-height:1.5; }
.gate-section { min-height:calc(100vh - 64px); display:flex; align-items:center; justify-content:center; padding:40px; }
.gate-card { text-align:center; background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r24); padding:48px 40px; max-width:440px; width:100%; box-shadow:var(--sh-lg); }
.gate-card h1 { font-family:var(--ff-display); font-size:32px; font-weight:900; color:var(--accent-dark); margin-bottom:12px; }
.gate-card p { font-size:15px; color:var(--text-3); }
.app-status-card { text-align:center; background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r24); padding:48px 40px; max-width:440px; width:100%; box-shadow:var(--sh-lg); }
.music-gate-section { min-height:calc(100vh - 64px); display:flex; align-items:center; justify-content:center; padding:40px; }

/* ── MUSIC APP ─────────────────────────────────────────── */
body.music-app-page { overflow:hidden; background:var(--bg); }
.music-page-wrap { display:flex; flex-direction:column; height:100vh; overflow:hidden; }

.music-top-bar {
  position:sticky; top:0; z-index:200; height:60px; flex-shrink:0;
  background:rgba(255,255,255,.97); backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border); box-shadow:var(--sh-sm);
  display:flex; flex-direction:row; align-items:center; justify-content:space-between;
  padding:0 20px; gap:12px;
}


.music-body { flex:1; display:flex; overflow:hidden; }
.music-layout { display:grid; grid-template-columns:var(--sidebar-w) 1fr; width:100%; overflow:hidden; height:calc(100vh - 60px - var(--player-h)); }

/* Sidebar */
.sidebar { background:var(--surface); border-right:1px solid var(--border); overflow-y:auto; overflow-x:hidden; display:flex; flex-direction:column; grid-column:1; grid-row:1; padding-bottom:20px; }
.sidebar::-webkit-scrollbar { width:3px; }
.sidebar::-webkit-scrollbar-thumb { background:#e0e0e0; }
.sidebar-logo { padding:18px 16px 6px; }
.sidebar-logo-mark { font-family:var(--ff-display); font-size:18px; font-weight:900; background:linear-gradient(135deg,#c99a00,#f3c639); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.sidebar-nav { padding:4px 8px; }
.sidebar-nav-item { display:flex; align-items:center; gap:10px; padding:10px 12px; border-radius:var(--r8); font-size:14px; font-weight:600; color:var(--text-3); cursor:pointer; transition:all var(--t1); position:relative; }
.sidebar-nav-item:hover { color:var(--text); background:var(--hover); }
.sidebar-nav-item.active { color:var(--text); background:var(--accent-dim); }
.sidebar-nav-item.active::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:3px; height:18px; background:var(--accent); border-radius:0 3px 3px 0; }
.sidebar-nav-icon { width:20px; height:20px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.sidebar-nav-icon svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.8; }
.sidebar-section { padding:16px 8px 6px; }
.sidebar-section-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.14em; color:var(--text-4); padding:0 10px; margin-bottom:6px; }
.genre-chips { display:flex; flex-wrap:wrap; gap:5px; padding:0 8px 8px; }
.genre-chip { font-size:11px; font-weight:600; color:var(--text-3); padding:4px 11px; border-radius:var(--pill); border:1px solid var(--border); cursor:pointer; background:var(--surface); transition:all var(--t1); }
.genre-chip:hover { color:var(--text); border-color:var(--border-2); }
.genre-chip.active { background:var(--accent-dim); border-color:var(--accent-bdr); color:var(--accent-dark); }
.artist-list { padding:0 8px; display:flex; flex-direction:column; gap:2px; }
.artist-item { display:flex; align-items:center; gap:8px; padding:7px 10px; border-radius:var(--r8); font-size:13px; font-weight:500; color:var(--text-3); cursor:pointer; transition:all var(--t1); }
.artist-item:hover { color:var(--text); background:var(--hover); }
.sidebar-plan { margin:10px 8px 0; background:var(--accent-dim); border:1px solid var(--accent-bdr); border-radius:var(--r12); padding:14px; }
.sidebar-plan-name { font-family:var(--ff-display); font-size:15px; font-weight:900; color:var(--accent-dark); margin-bottom:3px; }
.sidebar-plan-desc { font-size:11.5px; color:var(--text-3); margin-bottom:8px; }

/* Music main */
.music-main { background:var(--bg); overflow-y:auto; overflow-x:hidden; grid-column:2; grid-row:1; isolation:isolate; }
.music-main::-webkit-scrollbar { width:4px; }
.music-main::-webkit-scrollbar-thumb { background:#ddd; }

.music-hero-band { padding:28px 24px 22px; background:linear-gradient(180deg,var(--accent-dim) 0%,transparent 100%); border-bottom:1px solid var(--border); display:flex; flex-direction:column; gap:16px; }
.music-hero-head { display:flex; align-items:flex-start; gap:16px; }
.music-hero-art { width:68px; height:68px; border-radius:var(--r12); flex-shrink:0; background:var(--accent-dim); border:1.5px solid var(--accent-bdr); display:flex; align-items:center; justify-content:center; box-shadow:0 4px 14px rgba(243,198,57,.25); overflow:hidden; }
.music-hero-art svg { width:28px !important; height:28px !important; flex-shrink:0; }
.music-hero-art svg { width:28px; height:28px; stroke:var(--accent-dark); fill:none; stroke-width:1.5; }
.music-hero-plan-tag { font-family:var(--ff-display); font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--accent-dark); margin-bottom:4px; }
.music-hero-title { font-family:var(--ff-display); font-size:clamp(22px,3vw,30px); font-weight:900; letter-spacing:-.04em; color:var(--text); margin-bottom:4px; }
.music-hero-sub { font-size:13px; color:var(--text-3); }
.music-search { display:block; width:100%; max-width:500px; background:var(--surface); border:1.5px solid var(--border-2); border-radius:var(--r8); padding:11px 16px; font-size:14px; color:var(--text); outline:none; transition:all var(--t2); box-shadow:var(--sh-sm); }
.music-search::placeholder { color:var(--text-4); }
.music-search:focus { border-color:var(--accent); box-shadow:0 0 0 3px rgba(243,198,57,.18); background:var(--surface); }
.now-playing-mini { display:flex; align-items:center; gap:13px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r12); padding:10px 14px; max-width:420px; box-shadow:var(--sh-sm); }
.now-playing-art { width:44px; height:44px; border-radius:var(--r8); flex-shrink:0; overflow:hidden; background:var(--hover); display:flex; align-items:center; justify-content:center; }
.now-playing-art img { width:100%; height:100%; object-fit:cover; }
.now-playing-tag { font-size:9.5px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--accent-dark); margin-bottom:2px; }
.now-playing-title { font-size:13.5px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:260px; }
.now-playing-artist { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:260px; }
.client-chips { display:flex; gap:8px; flex-wrap:wrap; }
.client-chip { background:var(--surface); border:1px solid var(--border); border-radius:var(--r8); padding:7px 12px; }
.client-chip-lbl { font-size:9px; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); }
.client-chip-val { font-size:13px; font-weight:800; color:var(--text); }
.music-sec { padding:0 24px 20px; }
.music-sec-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:14px; padding-top:20px; }
.music-sec-title { font-family:var(--ff-display); font-size:19px; font-weight:800; color:var(--text); }
.music-sec-sub { font-size:12px; color:var(--text-3); margin-top:2px; }
.music-sec-more { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); transition:color var(--t1); }
.music-sec-more:hover { color:var(--text); }

/* Featured grid */
.feat-music-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.feat-track-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r12); overflow:hidden; cursor:pointer; transition:all var(--t2) var(--spring); }
.feat-track-card:hover { transform:translateY(-3px); border-color:var(--border-2); box-shadow:var(--sh); }
.feat-track-card.is-playing { border-color:var(--accent-bdr); background:var(--accent-dim); }
.feat-track-art { aspect-ratio:1; overflow:hidden; position:relative; background:var(--hover); display:flex; align-items:center; justify-content:center; }
.feat-track-art > svg { width:28px !important; height:28px !important; flex-shrink:0; }
.feat-track-art img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.feat-play-btn { position:absolute; bottom:8px; right:8px; width:36px; height:36px; border-radius:50%; background:var(--accent); color:#111; display:flex; align-items:center; justify-content:center; transform:translateY(8px) scale(.8); opacity:0; transition:all var(--t2) var(--spring); box-shadow:0 4px 12px rgba(243,198,57,.4); }
.feat-play-btn svg { width:14px; height:14px; fill:#111; }
.feat-track-card:hover .feat-play-btn { opacity:1; transform:translateY(0) scale(1); }
.feat-track-info { padding:10px 12px 12px; }
.feat-track-name { font-size:12.5px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:2px; }
.feat-track-artist { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.feat-track-genre { font-size:9px; color:var(--accent-dark); font-weight:800; text-transform:uppercase; letter-spacing:.06em; margin-top:3px; }

/* Track table */
.track-table { display:flex; flex-direction:column; }
.track-thead { display:grid; grid-template-columns:36px 1fr 130px 85px 52px 60px; gap:10px; padding:6px 14px; border-bottom:1px solid var(--border); margin-bottom:4px; }
.track-thead span { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); }
.track-row { display:grid; grid-template-columns:36px 1fr 130px 85px 50px 90px; gap:10px; align-items:center; padding:7px 14px; border-radius:var(--r8); cursor:pointer; transition:background var(--t1); }
.track-row:hover { background:var(--hover); }
.track-row.playing { background:var(--accent-dim); }
.track-row.playing .track-name { color:var(--accent-dark); font-weight:800; }
.track-idx { font-size:12.5px; color:var(--text-4); text-align:center; }
.track-main { display:flex; align-items:center; gap:10px; min-width:0; }
.track-thumb { width:38px; height:38px; border-radius:var(--r4); flex-shrink:0; overflow:hidden; background:var(--hover); }
.track-thumb img { width:100%; height:100%; object-fit:cover; }
.track-info { min-width:0; }
.track-name { font-size:13.5px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.track-artist { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.track-album { font-size:12px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.track-genre-tag { font-size:10px; color:var(--text-4); padding:2px 8px; background:var(--hover); border-radius:var(--pill); white-space:nowrap; }
.track-dur { font-size:12px; color:var(--text-3); text-align:right; }
.track-actions { display:flex; align-items:center; gap:4px; justify-content:flex-end; }
.track-play-btn, .track-add-pl, .track-rem-pl { width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; border:1px solid var(--border); color:var(--text-3); opacity:0; transition:all var(--t1); flex-shrink:0; font-size:15px; font-weight:700; }
.track-play-btn svg { width:11px; height:11px; fill:currentColor; }
.track-row:hover .track-play-btn,
.track-row:hover .track-add-pl,
.track-row:hover .track-rem-pl,
.track-row.playing .track-play-btn { opacity:1; }
.track-row:hover .track-play-btn,
.track-row.playing .track-play-btn { background:var(--accent); border-color:var(--accent); color:#111; }
.track-add-pl:hover { background:var(--accent-dim); border-color:var(--accent-bdr); color:var(--accent-dark); }
.track-rem-pl:hover { background:rgba(220,38,38,.08); border-color:rgba(220,38,38,.3); color:var(--red); }
.empty-state { text-align:center; padding:48px 20px; font-size:14px; color:var(--text-4); }

/* Player bar */
.player-bar { position:fixed; bottom:0; left:0; right:0; z-index:400; height:var(--player-h); background:rgba(255,255,255,.98); backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px); border-top:1px solid var(--border); box-shadow:0 -4px 20px rgba(0,0,0,.08); display:flex; align-items:center; justify-content:space-between; padding:0 20px; gap:14px; }
.player-bar[hidden] { display:none; }
.player-now { display:flex; align-items:center; gap:12px; width:240px; flex-shrink:0; min-width:0; }
.player-art { width:48px; height:48px; border-radius:var(--r8); flex-shrink:0; overflow:hidden; background:var(--hover); }
.player-art img { width:100%; height:100%; object-fit:cover; }
.player-now-info { min-width:0; }
.player-track-title { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; margin-bottom:1px; }
.player-track-artist { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.player-center { display:flex; flex-direction:column; align-items:center; gap:6px; flex:1; min-width:0; }
.player-btns { display:flex; align-items:center; gap:10px; }
.pbtn { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--text-3); transition:all var(--t1); flex-shrink:0; }
.pbtn svg { width:14px; height:14px; fill:currentColor; }
.pbtn:hover { color:var(--text); transform:scale(1.1); }
.pbtn.pbtn-main { width:40px; height:40px; background:#111; color:#fff; box-shadow:0 3px 10px rgba(0,0,0,.18); }
.pbtn.pbtn-main svg { width:16px; height:16px; fill:#fff; }
.pbtn.pbtn-main:hover { background:var(--accent); box-shadow:0 4px 14px rgba(243,198,57,.4); }
.pbtn.pbtn-main:hover svg { fill:#111; }
.player-progress { display:flex; align-items:center; gap:8px; width:100%; max-width:480px; }
.player-time { font-size:10.5px; color:var(--text-4); flex-shrink:0; min-width:30px; text-align:center; }
.player-range { flex:1; -webkit-appearance:none; appearance:none; height:3px; border-radius:2px; background:var(--active); outline:none; cursor:pointer; transition:height var(--t1); }
.player-range:hover { height:5px; }
.player-range::-webkit-slider-thumb { -webkit-appearance:none; width:12px; height:12px; border-radius:50%; background:#111; cursor:pointer; transition:background var(--t1); }
.player-range:hover::-webkit-slider-thumb { background:var(--accent); }
.player-right { display:flex; align-items:center; gap:9px; width:180px; justify-content:flex-end; flex-shrink:0; }
.vol-wrap { display:flex; align-items:center; gap:7px; }
.vol-wrap svg { width:15px; height:15px; stroke:var(--text-3); fill:none; flex-shrink:0; }
.vol-range { width:80px; -webkit-appearance:none; appearance:none; height:3px; border-radius:2px; background:var(--active); outline:none; cursor:pointer; }
.vol-range::-webkit-slider-thumb { -webkit-appearance:none; width:11px; height:11px; border-radius:50%; background:var(--text-3); cursor:pointer; }

/* Mobile nav */
.mobile-nav { display:none; position:fixed; bottom:0; left:0; right:0; z-index:500; background:rgba(255,255,255,.98); border-top:1px solid var(--border); box-shadow:0 -2px 12px rgba(0,0,0,.07); height:60px; align-items:center; justify-content:space-around; padding:0 8px; }
.mobile-nav-item { display:flex; flex-direction:column; align-items:center; gap:3px; padding:7px 12px; border-radius:var(--r8); cursor:pointer; color:var(--text-4); font-size:9.5px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; transition:color var(--t1); }
.mobile-nav-item:hover, .mobile-nav-item.active { color:var(--accent-dark); }
.mobile-nav-item svg { width:22px; height:22px; stroke:currentColor; fill:none; stroke-width:1.8; }

/* Library blocks */
.lib-block { padding:20px 24px; border-bottom:1px solid var(--border); }
.lib-block:last-child { border-bottom:none; }
.lib-block-hdr { display:flex; align-items:center; gap:12px; margin-bottom:14px; }
.lib-block-title { font-family:var(--ff-display); font-size:17px; font-weight:800; color:var(--text); flex:1; }
.lib-action-btn { font-size:12px; font-weight:700; color:var(--accent-dark); padding:5px 14px; border:1.5px solid var(--accent-bdr); border-radius:var(--pill); background:var(--accent-dim); transition:all var(--t1); }
.lib-action-btn:hover { background:var(--accent); color:#111; border-color:var(--accent); }
.lib-back-btn { font-size:12.5px; font-weight:600; color:var(--text-3); padding:5px 14px; border:1.5px solid var(--border); border-radius:var(--pill); background:var(--surface); transition:all var(--t1); }
.lib-back-btn:hover { color:var(--text); border-color:var(--border-2); }
.lib-empty { font-size:13px; color:var(--text-4); padding:12px 0; }






.lib-genre-grid { display:flex; flex-wrap:wrap; gap:8px; padding:2px 0; }
.lib-genre-card {
  padding:7px 16px; border-radius:var(--pill);
  border:1.5px solid var(--border); background:var(--surface);
  font-size:12.5px; font-weight:600; color:var(--text-2);
  cursor:pointer; transition:all var(--t1); white-space:nowrap;
  display:inline-block;
}
.lib-genre-card:hover { border-color:var(--accent-bdr); color:var(--accent-dark); background:var(--accent-dim); }
.lib-genre-card.is-active { background:var(--accent-dim); border-color:var(--accent-bdr); color:var(--accent-dark); font-weight:700; }
.lib-playlists-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); gap:12px; }
.lib-pl-card { background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r12); overflow:hidden; display:flex; flex-direction:column; transition:all var(--t2) var(--spring); }
.lib-pl-card:hover { border-color:var(--border-2); box-shadow:var(--sh); transform:translateY(-2px); }
.lib-pl-art { aspect-ratio:1; background:var(--accent-dim); display:flex; align-items:center; justify-content:center; overflow:hidden; cursor:pointer; }
.lib-pl-art img { width:100%; height:100%; object-fit:cover; }
.lib-pl-body { padding:10px 12px 4px; flex:1; cursor:pointer; }
.lib-pl-name { font-size:13.5px; font-weight:700; color:var(--text); margin-bottom:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.lib-pl-count { font-size:11px; color:var(--text-4); }
.lib-pl-actions { display:flex; gap:6px; padding:8px 10px; }
.lib-pl-play { background:var(--accent); border:1.5px solid var(--accent); color:#111; flex:1; font-size:12px; font-weight:700; padding:5px 10px; border-radius:var(--pill); cursor:pointer; transition:all var(--t1); }
.lib-pl-play:hover { background:var(--accent-dark); border-color:var(--accent-dark); }
.lib-pl-del { background:var(--surface); border:1.5px solid var(--border); color:var(--text-3); font-size:12px; font-weight:700; padding:5px 10px; border-radius:var(--pill); cursor:pointer; transition:all var(--t1); }
.lib-pl-del:hover { background:rgba(220,38,38,.08); border-color:rgba(220,38,38,.3); color:var(--red); }
.lib-pl-edit { background:var(--surface); border:1.5px solid var(--border); color:var(--text-3); font-size:12px; font-weight:700; padding:5px 10px; border-radius:var(--pill); cursor:pointer; transition:all var(--t1); }
.lib-pl-edit:hover { background:rgba(243,198,57,.1); border-color:var(--accent); color:var(--accent-dark); }

/* Misc */
body.modal-open { overflow:hidden; }
[data-reveal] { opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease),transform .6s var(--ease); }
[data-reveal].revealed { opacity:1; transform:translateY(0); }
[data-reveal-delay="1"]{transition-delay:.1s;} [data-reveal-delay="2"]{transition-delay:.2s;}
[data-reveal-delay="3"]{transition-delay:.3s;} [data-reveal-delay="4"]{transition-delay:.4s;}

/* ── RESPONSIVE ────────────────────────────────────────── */
@media (max-width:1280px) {
  :root { --sidebar-w:210px; }
  .footer-grid { grid-template-columns:1.5fr 1fr 1fr 1fr; }
  .hero-body { grid-template-columns:1fr 360px; gap:40px; }
}
@media (max-width:1100px) {
  .nav-links { display:none; }
  .hero-body { grid-template-columns:1fr; }
  .hero-col-right { display:none; }
  .track-thead,.track-row { grid-template-columns:36px 1fr 50px 90px; }
  .track-album,.track-genre-tag { display:none; }
}
@media (max-width:900px) {
  .sidebar { display:none !important; }
  .music-layout { grid-template-columns:1fr; height:calc(100vh - 60px - var(--player-h) - 60px); }
  .mobile-nav { display:flex; }
  .player-bar { bottom:60px; }
  .player-right { display:none; }
  .player-now { width:auto; flex:1; }
  .auth-left { display:none; }
  .auth-wrap { grid-template-columns:1fr; }
  .auth-right { min-height:calc(100vh - var(--bar-h) - var(--nav-h)); }
  .features-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .plan-status-row { grid-template-columns:1fr; }
  .settings-tools { grid-template-columns:1fr; }
  .feat-music-grid { grid-template-columns:repeat(3,1fr); }
}
@media (max-width:768px) {
  :root { --nav-h:58px; --player-h:72px; }
  .topbar { padding:0 14px; }
  .topbar .nav-links { display:none; }
  .container,.sec-container,.hero-body { padding-left:16px; padding-right:16px; }
  .music-hero-band { padding:18px 14px 16px; gap:12px; }
  .music-sec { padding:0 14px 16px; }
  .music-sec-head { padding-top:16px; }
  .feat-music-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
  .player-bar { padding:0 14px; gap:10px; }
  .player-progress { display:none; }
  .player-center { flex:0 0 auto; }
  .plans-grid { padding:32px 16px 60px; grid-template-columns:1fr 1fr; }
  .settings-body { padding:16px 18px 44px; }
  .settings-hdr { padding:18px 20px; }
  .settings-form-actions { flex-direction:column; }
  .settings-form-actions .btn { max-width:100%; }
  .footer-grid { padding:0 16px; gap:28px; }
  .faq-inner { padding:0 16px; }
  footer { padding-top:36px; }
  .upgrade-grid,.coming-soon-grid,.lib-playlists-grid { grid-template-columns:1fr 1fr; }
  .lib-block { padding:16px; }
}
@media (max-width:480px) {
  /* brand scales naturally */
  html, body { overflow-x:hidden; max-width:100%; }
  .pbtn.pbtn-skip { display:none; }
  .pbtn.pbtn-main { width:44px; height:44px; }
  .plans-grid { grid-template-columns:1fr; }
  .feat-music-grid { grid-template-columns:repeat(2,1fr); }
  .mobile-nav-item { padding:6px 8px; font-size:9px; min-width:44px; }
  .settings-panel { max-width:100%; }
  .now-playing-title,.now-playing-artist { max-width:200px; }
  /* HERO mobile fixes */
  .hero-wrap { padding:40px 0 36px; }
  .hero-body { padding:0 16px; gap:0; }
  .hero-col-right { display:none; }
  .hero-label { margin-bottom:12px; }
  .hero-title { font-size:clamp(1.7rem,8vw,2.2rem); margin-bottom:14px; }
  .hero-desc { font-size:14.5px; margin-bottom:22px; max-width:100%; }
  .hero-email-wrap { padding:5px 5px 5px 16px; }
  .hero-email-wrap input { font-size:14px; min-width:0; }
  .hero-email-wrap .btn { padding:9px 16px; font-size:13px; white-space:nowrap; flex-shrink:0; }
  .hero-actions { gap:8px; }
  .hero-actions .btn { font-size:13px; padding:10px 18px; }
  .hero-stats { gap:12px; margin-top:24px; flex-wrap:wrap; }
  .hero-stat strong { font-size:20px; }
  .hero-divider { display:none; }
  /* Sections */
  .content-section { padding:32px 0; }
  .sec-container { padding:0 14px; }
  .sec-title { font-size:19px; }
  /* Nav */
  .topbar { padding:0 14px; }
  .topbar .nav-links { display:none; }
  .pill { padding:7px 14px; font-size:13px; }
  .brand { font-size:20px !important; }
  .upgrade-grid,.coming-soon-grid,.lib-playlists-grid { grid-template-columns:1fr; }
}
@media (min-width:1440px) {
  :root { --sidebar-w:260px; }
  .feat-music-grid { grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); }
}

/* ── MISSING CLASSES — index.html ─────────────────────── */
.hero-col-left { max-width:600px; width:100%; min-width:0; }
.feat-title { font-family:var(--ff-display); font-size:15px; font-weight:800; color:var(--text); margin-bottom:7px; }
.feat-desc { font-size:13px; color:var(--text-3); line-height:1.6; }
.green-icon { background:rgba(22,163,74,.10) !important; border-color:rgba(22,163,74,.25) !important; }
.green-icon svg { stroke:#16a34a !important; }
.blue-icon { background:rgba(37,99,235,.10) !important; border-color:rgba(37,99,235,.25) !important; }
.blue-icon svg { stroke:#2563eb !important; }
.faq-section { padding:64px 0; background:var(--surface); border-top:1px solid var(--border); }
.faq-head { text-align:center; margin-bottom:40px; }
.faq-head h2 { font-family:var(--ff-display); font-size:clamp(24px,3vw,32px); font-weight:900; color:var(--text); margin-bottom:10px; }
.faq-head p { font-size:15px; color:var(--text-3); }
.faq-list { display:flex; flex-direction:column; }
.faq-plus { font-size:20px; font-weight:400; color:var(--text-4); transition:transform var(--t2); flex-shrink:0; }
.faq-item.open .faq-plus { transform:rotate(45deg); color:var(--accent-dark); }
.footer-wordmark { font-family:var(--ff-display); font-size:24px; font-weight:900; letter-spacing:-.04em; background:linear-gradient(135deg,#c99a00,#f3c639); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:10px; }
.footer-about { font-size:13px; color:var(--text-4); line-height:1.65; max-width:280px; margin-bottom:16px; }
.footer-socials { display:flex; gap:10px; }
.footer-social { width:36px; height:36px; border-radius:50%; border:1.5px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--text-3); transition:all var(--t1); }
.footer-social:hover { color:var(--text); border-color:var(--border-2); background:var(--hover); }
.footer-social svg { width:16px; height:16px; }
.footer-col h4 { font-family:var(--ff-display); font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--text-4); margin-bottom:14px; }
.footer-col .links { display:flex; flex-direction:column; gap:4px; }
.footer-col .links a { font-size:13.5px; color:var(--text-3); padding:3px 0; transition:color var(--t1); }
.footer-col .links a:hover { color:var(--text); }
.plans-mini-list { display:flex; flex-direction:column; }
.cookie-banner__content {}
.cookie-banner.show { display:flex; }
.cookie-modal.show { display:flex; }
.cookie-modal.show[aria-hidden="true"] { display:none; }
.music-badge { display:inline-block; font-family:var(--ff-display); font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--accent-dark); padding:4px 12px; background:var(--accent-dim); border:1px solid var(--accent-bdr); border-radius:var(--pill); margin-bottom:16px; }
.signup-result[style*="display:none"] { display:none !important; }







/* ── GLOBAL SVG CONTAINMENT ─────────────────────────────── */
svg { display:inline-block; vertical-align:middle; flex-shrink:0; }
.feat-play-btn svg, .track-play-btn svg, .pbtn svg,
.sidebar-nav-icon svg, .mobile-nav-item svg, .settings-pill__icon svg,
.lang-icon svg, 
/* Prevent any SVG from expanding beyond its parent */
.music-main svg:not(.feat-play-btn svg):not(.track-play-btn svg) {
  max-width:100%; max-height:100%;
}



/* ── ABSOLUTE SVG OVERFLOW PREVENTION ───────────────────── */
.music-page-wrap svg { max-width:none; }
.music-main svg { max-height:none; }
.player-bar { transform:translateZ(0); }
.pbtn.pbtn-main { overflow:hidden; }
.pbtn.pbtn-main svg { width:16px !important; height:16px !important; fill:#fff !important; display:block; }
.pbtn svg { width:14px !important; height:14px !important; display:block; }
.feat-play-btn svg { width:14px !important; height:14px !important; fill:#111 !important; display:block; }
.track-play-btn svg { width:11px !important; height:11px !important; fill:currentColor !important; display:block; }

/* ── LIBRARY: ARTIST CHIPS (compact pills) ──────────────── */
.lib-artists-row {
  display:flex;
  flex-direction:row;
  flex-wrap:wrap;
  gap:8px;
  padding:2px 0 10px;
}
.lib-artist-chip {
  display:inline-flex !important;
  flex-direction:row !important;
  align-items:center;
  gap:8px;
  cursor:pointer;
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--pill);
  padding:5px 14px 5px 5px;
  white-space:nowrap;
  transition:all var(--t1);
  max-width:180px;
  min-width:0;
  flex-shrink:0;
  /* CRITICAL: prevent block/grid expansion */
  width:auto !important;
  height:auto !important;
  aspect-ratio:unset !important;
}
.lib-artist-chip:hover {
  border-color:var(--border-2);
  background:var(--hover);
  transform:translateY(-1px);
}
.lib-artist-chip img {
  width:32px !important;
  height:32px !important;
  min-width:32px !important;
  min-height:32px !important;
  max-width:32px !important;
  max-height:32px !important;
  border-radius:50% !important;
  object-fit:cover !important;
  flex-shrink:0;
  display:block;
  border:1px solid var(--border);
}
.lib-artist-chip span {
  font-size:12px;
  font-weight:600;
  color:var(--text-2);
  overflow:hidden;
  text-overflow:ellipsis;
  max-width:110px;
  min-width:0;
  display:block;
}

/* ── ULTRA SMALL SCREENS ≤390px ─────────────────────────── */
@media (max-width:390px) {
  .hero-wrap { padding:32px 0 28px; }
  .hero-body { padding:0 14px !important; }
  .hero-title { font-size:1.65rem; letter-spacing:-.03em; }
  .hero-label-text { font-size:10px; }
  .hero-desc { font-size:14px; }
  .hero-email-wrap { padding:5px 5px 5px 14px; gap:6px; }
  .hero-email-wrap input { font-size:13.5px; }
  .hero-email-wrap .btn.primary { padding:9px 14px; font-size:12.5px; }
  .hero-stats { gap:10px; margin-top:20px; }
  .hero-stat strong { font-size:18px; }
  .hero-stat span { font-size:9.5px; }
  .hero-divider { display:none; }
  .sec-title { font-size:17px; }
  .sec-container { padding:0 12px; }
  .topbar { padding:0 12px; }
  .brand { font-size:18px !important; }
  .pill { padding:6px 12px; font-size:12.5px; }
  .content-section { padding:28px 0; }
  .features-grid { grid-template-columns:1fr; }
  .plans-grid { padding:24px 12px 48px; }
  .footer-grid { grid-template-columns:1fr; padding:0 14px; }
}


/* ── BANNERS ─────────────────────────────────────────────── */
.hero-banners {
  height:200px; min-height:200px; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 32px; transition:all .8s ease;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.banner-inner { display:flex; flex-direction:column; gap:6px; max-width:500px; }
.banner-tag { font-family:var(--ff-display); font-size:9.5px; font-weight:800; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.9); background:rgba(255,255,255,.15); padding:3px 10px; border-radius:var(--pill); display:inline-block; }
.banner-tag.dark { color:rgba(0,0,0,.7); background:rgba(0,0,0,.12); }
.banner-title { font-family:var(--ff-display); font-size:clamp(18px,2.5vw,26px); font-weight:900; color:#fff; line-height:1.1; }
.banner-title.dark { color:#111; }
.banner-sub { font-size:12.5px; color:rgba(255,255,255,.7); }
.banner-sub.dark { color:rgba(0,0,0,.55); }
.banner-btn { display:inline-flex; align-items:center; padding:8px 20px; border-radius:var(--pill); background:rgba(255,255,255,.95); color:#111; font-family:var(--ff-display); font-size:12px; font-weight:800; border:none; cursor:pointer; margin-top:4px; transition:all var(--t1); width:fit-content; }
.banner-btn:hover { background:#fff; transform:translateY(-1px); box-shadow:0 4px 12px rgba(0,0,0,.2); }
.banner-btn.dark { background:rgba(0,0,0,.85); color:#fff; }
.banner-btn.dark:hover { background:#111; }
.banner-dots { display:flex; gap:6px; flex-direction:column; }
.banner-dot { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.4); cursor:pointer; transition:all var(--t2); }
.banner-dot.active { background:rgba(255,255,255,.95); height:20px; border-radius:3px; }

/* ── FEAT TRACK: like button ────────────────────────────── */
.feat-like-btn {
  position:absolute; top:8px; right:8px;
  width:30px; height:30px; border-radius:50%;
  background:rgba(0,0,0,.35); display:flex; align-items:center; justify-content:center;
  opacity:0; transition:all var(--t2); border:none; cursor:pointer;
}
.feat-track-card:hover .feat-like-btn { opacity:1; }
.feat-like-btn.liked { opacity:1; background:rgba(229,62,62,.25); }
.feat-like-btn svg { display:block; }

/* ── PLAYER: extra controls ─────────────────────────────── */
.player-icon-btn {
  width:28px; height:28px; border-radius:50%; border:none;
  background:transparent; cursor:pointer; display:flex;
  align-items:center; justify-content:center; flex-shrink:0;
  color:var(--text-3); transition:all var(--t1);
}
.player-icon-btn:hover { color:var(--text); transform:scale(1.1); }
.player-icon-btn.liked { color:#e53e3e; }
.pbtn.active { color:var(--accent-dark) !important; }
.pbtn.active svg { stroke:var(--accent-dark) !important; }
.player-close-btn { margin-left:4px; opacity:.5; }
.player-close-btn:hover { opacity:1; color:var(--red); }

/* ── TRACK ACTIONS: like btn ────────────────────────────── */
.track-like-btn {
  width:28px; height:28px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:1px solid var(--border); color:var(--text-4);
  opacity:0; transition:all var(--t1); flex-shrink:0; background:transparent; cursor:pointer;
}
.track-row:hover .track-like-btn { opacity:1; }
.track-like-btn.liked { opacity:1; color:#e53e3e; border-color:rgba(229,62,62,.3); background:rgba(229,62,62,.06); }
.track-like-btn svg { display:block; }

/* ── QUEUE PANEL ────────────────────────────────────────── */
.queue-panel {
  position:fixed; right:0; bottom:var(--player-h); z-index:350;
  width:280px; max-height:360px;
  background:var(--surface); border:1.5px solid var(--border);
  border-radius:var(--r12) var(--r12) 0 0; box-shadow:var(--sh-lg);
  display:flex; flex-direction:column;
  transform:translateY(110%); opacity:0;
  transition:transform var(--t2) var(--ease), opacity var(--t2);
  pointer-events:none;
}
.queue-panel.open { transform:translateY(0); opacity:1; pointer-events:all; }
.queue-hdr { display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--border); font-family:var(--ff-display); font-size:13px; font-weight:800; }
.queue-close { font-size:18px; color:var(--text-3); background:none; border:none; cursor:pointer; padding:2px 6px; }
.queue-list { overflow-y:auto; flex:1; padding:6px; }
.queue-item { display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:var(--r8); cursor:pointer; transition:background var(--t1); }
.queue-item:hover { background:var(--hover); }

/* ── DEVICE MODAL ───────────────────────────────────────── */
.device-modal-overlay { position:fixed; inset:0; z-index:900; background:rgba(0,0,0,.4); backdrop-filter:blur(8px); display:flex; align-items:center; justify-content:center; }
.device-modal-overlay[hidden] { display:none; }
.device-modal-backdrop { position:absolute; inset:0; }
.device-modal { position:relative; z-index:1; background:var(--surface); border:1.5px solid var(--border); border-radius:var(--r16); padding:24px; max-width:440px; width:92%; box-shadow:var(--sh-lg); }
.device-modal-hdr { display:flex; align-items:center; justify-content:space-between; margin-bottom:6px; }
.device-modal-hdr h3 { font-family:var(--ff-display); font-size:18px; font-weight:900; color:var(--text); }
.device-modal-sub { font-size:13px; color:var(--text-3); margin-bottom:18px; }
.device-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
.device-card { background:var(--bg); border:1.5px solid var(--border); border-radius:var(--r12); padding:14px 12px; text-align:center; cursor:pointer; transition:all var(--t1); }
.device-card:hover { border-color:var(--accent-bdr); background:var(--accent-dim); transform:translateY(-1px); }
.device-card.active { border-color:var(--accent-bdr); background:var(--accent-dim); }
.device-icon { font-size:24px; margin-bottom:6px; }
.device-name { font-size:11.5px; font-weight:700; color:var(--text); margin-bottom:3px; }
.device-status { font-size:10px; color:var(--text-4); }
.device-status.active { color:var(--green); font-weight:700; }

/* ── TOAST ──────────────────────────────────────────────── */
.music-toast {
  position:fixed; bottom:calc(var(--player-h) + 16px); left:50%; z-index:1000;
  transform:translateX(-50%) translateY(20px);
  background:#111; color:#fff; font-size:13px; font-weight:600;
  padding:10px 20px; border-radius:var(--pill); opacity:0;
  transition:all .25s var(--ease); pointer-events:none; white-space:nowrap;
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.music-toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ── SKELETON LOADING ───────────────────────────────────── */
.skel-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px; }
.skel-card { height:200px; border-radius:var(--r12); background:linear-gradient(90deg,var(--hover) 25%,var(--active) 50%,var(--hover) 75%); background-size:200% 100%; animation:shimmer 1.4s infinite; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── MOBILE responsive ───────────────────────────────────── */
@media (max-width:900px) {
  .queue-panel { width:100%; border-radius:var(--r12) var(--r12) 0 0; bottom:calc(var(--player-h) + 60px); }
  .device-grid { grid-template-columns:1fr 1fr; }
  .hero-banners { height:160px; padding:0 18px; }
  .banner-title { font-size:18px; }
}
@media (max-width:480px) {
  .hero-banners { height:140px; padding:0 14px; }
  .banner-dots { display:none; }
  .device-grid { grid-template-columns:1fr 1fr 1fr; }
  .player-right .pbtn:not(.player-close-btn):not(#queueBtn) { display:none; }
}

/* ══════════════════════════════════════════════════════
   SETTINGS: layout with sidebar categories
═══════════════════════════════════════════════════════ */
.settings-layout {
  display:grid;
  grid-template-columns:220px 1fr;
  flex:1;
  overflow:hidden;
  min-height:0;
}
.settings-cats {
  border-right:1px solid var(--border);
  overflow-y:auto;
  padding:12px 0 24px;
  background:var(--bg);
}
.settings-cat-group { padding:0 10px; }
.settings-cat-label {
  font-size:9.5px; font-weight:800; text-transform:uppercase; letter-spacing:.13em;
  color:var(--text-4); padding:14px 8px 5px;
  display:flex; align-items:center; gap:5px;
}
.settings-cat-item {
  display:flex; align-items:center; gap:9px;
  width:100%; padding:9px 10px; border-radius:var(--r8);
  border:none; background:none; cursor:pointer;
  color:var(--text-2); font-size:13px; font-weight:500;
  transition:all var(--t1); text-align:left; margin-bottom:1px;
}
.settings-cat-item:hover { background:var(--hover); color:var(--text); }
.settings-cat-item.active { background:var(--accent-dim); color:var(--accent-dark); font-weight:700; }
.settings-cat-item svg { flex-shrink:0; }
.settings-cat-item span { flex:1; }
.cat-arrow { color:var(--text-4); flex-shrink:0; }
.settings-cat-item.active .cat-arrow { color:var(--accent-dark); }

/* Settings sections */
.settings-body { overflow-y:auto; padding:24px; display:flex; flex-direction:column; gap:16px; }
.settings-sec { display:none; flex-direction:column; gap:14px; }
.settings-sec.active { display:flex; }
.settings-sec-title {
  display:flex; align-items:center; gap:8px;
  font-family:var(--ff-display); font-size:18px; font-weight:900; color:var(--text);
  padding-bottom:4px; border-bottom:2px solid var(--border);
}
.settings-card-hdr { margin-bottom:16px; }
.settings-card-hdr h3 { font-family:var(--ff-display); font-size:15px; font-weight:800; color:var(--text); margin-bottom:3px; }
.settings-card-hdr span { font-size:12px; color:var(--text-3); }

/* Settings header */
.settings-hdr-profile { display:flex; align-items:center; gap:12px; }
.settings-avatar {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  background:var(--accent-dim); border:2px solid var(--accent-bdr);
  display:flex; align-items:center; justify-content:center; color:var(--accent-dark);
}
.settings-hdr-name { font-size:16px; font-weight:900; font-family:var(--ff-display); color:var(--text); }
.settings-hdr-email { font-size:12px; color:var(--text-3); }

/* Plan inline card */
.plan-inline-card {
  display:flex; align-items:center; gap:10px;
  background:var(--accent-dim); border:1.5px solid var(--accent-bdr);
  border-radius:var(--r8); padding:12px 14px; margin-top:8px;
}

/* Logout btn */
.settings-logout-btn {
  display:inline-flex; align-items:center; gap:5px;
  padding:6px 12px; border-radius:var(--r8);
  font-size:12px; font-weight:700; font-family:var(--ff-display);
  color:var(--text-3); border:1.5px solid var(--border);
  background:transparent; cursor:pointer; transition:all var(--t1);
}
.settings-logout-btn:hover { color:#e53e3e; border-color:rgba(229,62,62,.3); }

/* Danger zone */
.danger-zone {
  border:1.5px solid rgba(229,62,62,.2); border-radius:var(--r12);
  padding:18px 20px; background:rgba(229,62,62,.03);
}
.danger-zone-hdr {
  display:flex; align-items:center; gap:7px;
  font-family:var(--ff-display); font-size:14px; font-weight:800;
  color:#c53030; margin-bottom:8px;
}
.danger-zone p { font-size:12.5px; color:var(--text-3); margin-bottom:0; }
.btn-danger {
  display:inline-flex; align-items:center; gap:6px; margin-top:14px;
  background:transparent; border:1.5px solid #e53e3e; color:#e53e3e;
  border-radius:var(--r8); padding:9px 18px; font-size:13px; font-weight:700;
  cursor:pointer; transition:all var(--t1); font-family:var(--ff-display);
}
.btn-danger:hover { background:#e53e3e; color:#fff; }

/* Toggle switch */
.toggle-list { display:flex; flex-direction:column; gap:0; }
.toggle-item {
  display:flex; align-items:center; justify-content:space-between;
  padding:13px 0; border-bottom:1px solid var(--border);
}
.toggle-item:last-child { border-bottom:none; }
.toggle-label { font-size:13.5px; font-weight:600; color:var(--text); }
.toggle-desc { font-size:12px; color:var(--text-3); margin-top:2px; }
.toggle-switch { position:relative; display:inline-block; width:42px; height:24px; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-track {
  position:absolute; cursor:pointer; inset:0;
  background:var(--active); border-radius:24px; transition:.3s;
}
.toggle-track::after {
  content:''; position:absolute; left:3px; top:3px;
  width:18px; height:18px; background:#fff; border-radius:50%; transition:.3s;
}
.toggle-switch input:checked + .toggle-track { background:var(--accent); }
.toggle-switch input:checked + .toggle-track::after { transform:translateX(18px); }

/* Sidebar badge */
.sidebar-badge {
  margin-left:auto; font-size:10px;
  background:var(--accent-dim); color:var(--accent-dark);
  padding:1px 7px; border-radius:var(--pill); font-weight:700;
}

/* ── CONTENT CARDS (Podcast / Radio) ──────────────────── */
.content-card-grid { display:flex; flex-direction:column; gap:8px; padding-bottom:20px; }
.content-card {
  display:flex; align-items:center; gap:14px;
  padding:12px 14px; border-radius:var(--r8);
  border:1.5px solid var(--border); background:var(--surface);
  cursor:pointer; transition:all var(--t1);
}
.content-card:hover { border-color:var(--accent-bdr); background:var(--accent-dim); transform:translateX(2px); }
.content-card-art {
  width:52px; height:52px; border-radius:var(--r8); flex-shrink:0;
  overflow:hidden; background:var(--hover);
}
.content-card-art img { width:100%; height:100%; object-fit:cover; display:block; }
.content-card-info { flex:1; min-width:0; }
.content-card-name { font-size:13.5px; font-weight:700; color:var(--text); }
.content-card-sub { font-size:12px; color:var(--text-3); margin-top:1px; }
.content-card-desc { font-size:11.5px; color:var(--text-4); margin-top:3px; }
.content-card-badge {
  display:inline-block; font-size:10px; font-weight:700; margin-top:4px;
  background:var(--hover); color:var(--text-3); padding:2px 8px; border-radius:var(--pill);
}
.content-card-play { color:var(--text-4); flex-shrink:0; }
.content-card-live {
  display:flex; align-items:center; gap:5px;
  font-size:11px; font-weight:700; color:#e53e3e; flex-shrink:0;
}
.live-dot {
  width:7px; height:7px; border-radius:50%; background:#e53e3e;
  animation:pulse 1.5s ease-in-out infinite;
}

/* CS card with icon */
.cs-icon { color:var(--accent-dark); margin-bottom:8px; }

/* Settings panel responsive */
@media (max-width:768px) {
  
/* ── SETTINGS 2-COLUMN LAYOUT ───────────────────────────── */
.settings-layout { display:grid; grid-template-columns:210px 1fr; flex:1; overflow:hidden; min-height:0; }
.settings-cats { border-right:1px solid var(--border); overflow-y:auto; padding:10px 0 24px; background:var(--bg); }
.settings-cat-group { padding:0 10px; }
.settings-cat-label { font-size:9.5px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--text-4); padding:14px 8px 5px; display:flex; align-items:center; gap:5px; }
.settings-cat-item { display:flex; align-items:center; gap:9px; width:100%; padding:9px 10px; border-radius:var(--r8); border:none; background:none; cursor:pointer; color:var(--text-2); font-size:13px; font-weight:500; transition:all var(--t1); text-align:left; margin-bottom:1px; }
.settings-cat-item:hover { background:var(--hover); color:var(--text); }
.settings-cat-item.active { background:var(--accent-dim); color:var(--accent-dark); font-weight:700; }
.settings-cat-item span { flex:1; }
.cat-arrow { color:var(--text-4); flex-shrink:0; }
.settings-cat-item.active .cat-arrow { color:var(--accent-dark); }

.settings-sec.active { display:flex; }
.settings-sec-title { display:flex; align-items:center; gap:8px; font-family:var(--ff-display); font-size:18px; font-weight:900; color:var(--text); padding-bottom:8px; border-bottom:2px solid var(--border); margin-bottom:4px; }
.settings-card-hdr { margin-bottom:14px; }
.settings-card-hdr h3 { font-family:var(--ff-display); font-size:15px; font-weight:800; color:var(--text); margin-bottom:3px; }
.settings-card-hdr span { font-size:12px; color:var(--text-3); }
/* Header avatar */

/* Inline plan card */
.plan-inline-card { display:flex; align-items:center; gap:10px; background:var(--accent-dim); border:1.5px solid var(--accent-bdr); border-radius:var(--r8); padding:12px 14px; margin-top:8px; }
/* Logout btn */
.settings-logout-btn { display:inline-flex; align-items:center; gap:5px; padding:6px 12px; border-radius:var(--r8); font-size:12px; font-weight:700; font-family:var(--ff-display); color:var(--text-3); border:1.5px solid var(--border); background:transparent; cursor:pointer; transition:all var(--t1); }
.settings-logout-btn:hover { color:#e53e3e; border-color:rgba(229,62,62,.3); }
/* Danger zone */
.danger-zone { border:1.5px solid rgba(229,62,62,.2); border-radius:var(--r12); padding:18px 20px; background:rgba(229,62,62,.03); }
.danger-zone-hdr { display:flex; align-items:center; gap:7px; font-family:var(--ff-display); font-size:14px; font-weight:800; color:#c53030; margin-bottom:8px; }
.danger-zone p { font-size:12.5px; color:var(--text-3); }
.btn-danger { display:inline-flex; align-items:center; gap:6px; margin-top:14px; background:transparent; border:1.5px solid #e53e3e; color:#e53e3e; border-radius:var(--r8); padding:9px 18px; font-size:13px; font-weight:700; cursor:pointer; transition:all var(--t1); font-family:var(--ff-display); }
.btn-danger:hover { background:#e53e3e; color:#fff; }
/* Toggles */
.toggle-list { display:flex; flex-direction:column; }
.toggle-item { display:flex; align-items:center; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--border); }
.toggle-item:last-child { border-bottom:none; }
.toggle-label { font-size:13.5px; font-weight:600; color:var(--text); }
.toggle-desc { font-size:12px; color:var(--text-3); margin-top:2px; }
.toggle-switch { position:relative; display:inline-block; width:42px; height:24px; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-track { position:absolute; cursor:pointer; inset:0; background:var(--active); border-radius:24px; transition:.3s; }
.toggle-track::after { content:""; position:absolute; left:3px; top:3px; width:18px; height:18px; background:#fff; border-radius:50%; transition:.3s; }
.toggle-switch input:checked ~ .toggle-track { background:var(--accent); }
.toggle-switch input:checked ~ .toggle-track::after { transform:translateX(18px); }
/* Sidebar badge */
.sidebar-badge { margin-left:auto; font-size:10px; background:var(--accent-dim); color:var(--accent-dark); padding:1px 7px; border-radius:var(--pill); font-weight:700; }
/* Content cards (Podcast/Radio) */
.content-card-grid { display:flex; flex-direction:column; gap:8px; padding-bottom:20px; }
.content-card { display:flex; align-items:center; gap:14px; padding:12px 14px; border-radius:var(--r8); border:1.5px solid var(--border); background:var(--surface); cursor:pointer; transition:all var(--t1); }
.content-card:hover { border-color:var(--accent-bdr); background:var(--accent-dim); transform:translateX(2px); }
.content-card-art { width:52px; height:52px; border-radius:var(--r8); flex-shrink:0; overflow:hidden; background:var(--hover); }
.content-card-art img { width:100%; height:100%; object-fit:cover; display:block; }
.content-card-info { flex:1; min-width:0; }
.content-card-name { font-size:13.5px; font-weight:700; color:var(--text); }
.content-card-sub { font-size:12px; color:var(--text-3); margin-top:1px; }
.content-card-desc { font-size:11.5px; color:var(--text-4); margin-top:3px; }
.content-card-badge { display:inline-block; font-size:10px; font-weight:700; margin-top:4px; background:var(--hover); color:var(--text-3); padding:2px 8px; border-radius:var(--pill); }
.content-card-arrow { color:var(--text-4); flex-shrink:0; }
.radio-live { display:flex; align-items:center; gap:5px; font-size:11px; font-weight:700; color:#e53e3e; flex-shrink:0; }
.live-dot { width:7px; height:7px; border-radius:50%; background:#e53e3e; animation:pulse 1.5s ease-in-out infinite; }
/* feat overlay */
.feat-track-overlay { position:absolute; bottom:0; left:0; right:0; height:55%; background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 100%); pointer-events:none; }
/* cs-icon */
.cs-icon { color:var(--accent-dark); margin-bottom:8px; }
/* Settings responsive */
@media (max-width:768px) {
  .settings-layout { grid-template-columns:1fr; }
  .settings-cats { border-right:none; border-bottom:1px solid var(--border); max-height:200px; overflow-y:auto; }
  .settings-body { padding:16px; }
}
@media (max-width:480px) {
  .settings-cats { display:flex; flex-direction:row; overflow-x:auto; max-height:none; padding:6px; gap:3px; }
  .settings-cat-group { display:flex; flex-direction:row; gap:3px; padding:0; }
  .settings-cat-label { display:none; }
  .settings-cat-item { white-space:nowrap; padding:7px 12px; font-size:12px; }
  .cat-arrow { display:none; }
}

/* ── BANNER COVERS collage ───────────────────────────────── */
.banner-covers {
  position:absolute; right:60px; top:50%; transform:translateY(-50%);
  display:flex; align-items:center; gap:14px; z-index:2;
  pointer-events:none;
}
.bcc { border-radius:var(--r8); overflow:hidden; box-shadow:0 8px 28px rgba(0,0,0,.5); flex-shrink:0; }
.bcc img { display:block; object-fit:cover; }
.bcc-l { width:72px; height:72px; opacity:.65; transform:rotate(-5deg); }
.bcc-m { width:120px; height:120px; opacity:1; }
.bcc-r { width:72px; height:72px; opacity:.65; transform:rotate(5deg); }
@media (max-width:1100px){ .banner-covers { display:none; } }

/* ── RADIO CARD playing state ────────────────────────────── */
.radio-card.radio-playing { border-color:var(--accent-bdr); background:var(--accent-dim); }

/* ── NOVIDADES ───────────────────────────────────────────── */
.novidades-list { display:flex; flex-direction:column; gap:0; }
.novidade-item { display:flex; gap:14px; padding:14px 0; border-bottom:1px solid var(--border); align-items:flex-start; }
.novidade-item:last-child { border-bottom:none; }
.novidade-dot { width:10px; height:10px; border-radius:50%; background:var(--accent-dark); flex-shrink:0; margin-top:4px; }
.novidade-item.new .novidade-dot { background:#22c55e; box-shadow:0 0 0 3px rgba(34,197,94,.2); }
.novidade-info { flex:1; min-width:0; }
.novidade-title { font-size:13.5px; font-weight:700; color:var(--text); }
.novidade-desc { font-size:12.5px; color:var(--text-3); margin-top:3px; line-height:1.5; }
.novidade-date { font-size:11px; color:var(--text-4); margin-top:4px; }
.novidade-item.new .novidade-title::after { content:" NOVO"; font-size:9px; font-weight:800; color:#22c55e; background:rgba(34,197,94,.12); padding:1px 6px; border-radius:var(--pill); margin-left:6px; vertical-align:middle; }


/* ════════════════════════════════════════════════════════
   MOBILE MORE DRAWER
════════════════════════════════════════════════════════ */
.mob-more-drawer { position:fixed; inset:0; z-index:600; pointer-events:none; }
.mob-more-drawer:not([hidden]) { pointer-events:all; }
.mob-more-overlay { position:absolute; inset:0; background:rgba(0,0,0,.45); opacity:0; transition:opacity .3s; }
.mob-more-drawer:not([hidden]) .mob-more-overlay { opacity:1; }
.mob-more-sheet {
  position:absolute; bottom:0; left:0; right:0;
  background:var(--surface); border-radius:20px 20px 0 0;
  padding:12px 0 calc(env(safe-area-inset-bottom,0px) + 20px);
  transform:translateY(100%);
  transition:transform .35s cubic-bezier(.32,0,.67,0);
  box-shadow:0 -8px 40px rgba(0,0,0,.18);
}
.mob-more-drawer:not([hidden]) .mob-more-sheet { transform:translateY(0); transition:transform .35s cubic-bezier(.34,1.3,.64,1); }
.mob-more-handle { width:36px; height:4px; background:var(--border-2); border-radius:2px; margin:0 auto 16px; }
.mob-more-title { font-size:12px; font-weight:800; color:var(--text-4); text-transform:uppercase; letter-spacing:.1em; padding:0 20px 10px; }
.mob-more-list { display:flex; flex-direction:column; gap:2px; padding:0 10px; }
.mob-more-item { display:flex; align-items:center; gap:14px; padding:12px 10px; border-radius:var(--r12); cursor:pointer; transition:background var(--t1); }
.mob-more-item:active { background:var(--hover); }
.mob-more-icon { width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.mob-more-info { flex:1; min-width:0; }
.mob-more-name { font-size:15px; font-weight:700; color:var(--text); }
.mob-more-sub { font-size:12px; color:var(--text-3); margin-top:1px; }

/* ════════════════════════════════════════════════════════
   MOBILE FULL PLAYER
════════════════════════════════════════════════════════ */
.mob-full-player {
  position:fixed; inset:0; z-index:550;
  background:var(--bg);
  display:flex; flex-direction:column; align-items:center;
  padding:0 28px;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.32,0,.67,0);
  overflow-y:auto;
}
.mob-full-player:not([hidden]) { transform:translateY(0); transition:transform .4s cubic-bezier(.34,1.2,.64,1); }
.mob-fp-header { display:flex; align-items:center; justify-content:space-between; width:100%; padding-top:calc(env(safe-area-inset-top,0px) + 16px); padding-bottom:12px; flex-shrink:0; }
.mob-fp-close, .mob-fp-menu { background:none; border:none; color:var(--text-3); cursor:pointer; padding:8px; border-radius:50%; transition:all var(--t1); -webkit-tap-highlight-color:transparent; }
.mob-fp-close:active, .mob-fp-menu:active { background:var(--hover); }
.mob-fp-label { font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.12em; color:var(--text-3); }
.mob-fp-art { width:min(74vw, 320px); height:min(74vw, 320px); border-radius:22px; overflow:hidden; background:var(--hover); box-shadow:0 24px 64px rgba(0,0,0,.28); margin:4px 0 24px; flex-shrink:0; }
.mob-fp-art img { width:100%; height:100%; object-fit:cover; display:block; }
.mob-fp-info { width:100%; margin-bottom:6px; }
.mob-fp-title { font-size:22px; font-weight:900; font-family:var(--ff-display); color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.mob-fp-artist { font-size:14px; color:var(--text-3); margin-top:3px; }
.mob-fp-actions { display:flex; align-items:center; gap:4px; margin-bottom:14px; width:100%; justify-content:flex-end; }
.mob-fp-like { background:none; border:none; cursor:pointer; padding:8px; color:var(--text-3); -webkit-tap-highlight-color:transparent; }
.mob-fp-progress { width:100%; margin-bottom:6px; }
.mob-fp-range {
  width:100%; -webkit-appearance:none; appearance:none;
  height:4px; border-radius:2px; background:var(--active);
  background:linear-gradient(to right, var(--accent) 0%, var(--active) 0%);
  outline:none; cursor:pointer;
}
.mob-fp-range::-webkit-slider-thumb { -webkit-appearance:none; width:18px; height:18px; border-radius:50%; background:var(--accent-dark); cursor:pointer; margin-top:-7px; box-shadow:0 2px 6px rgba(0,0,0,.2); }
.mob-fp-times { display:flex; justify-content:space-between; font-size:11px; color:var(--text-4); margin-top:5px; }
.mob-fp-controls { display:flex; align-items:center; justify-content:space-between; width:100%; padding:10px 0 20px; }
.mob-fp-btn { background:none; border:none; color:var(--text-2); cursor:pointer; padding:10px; border-radius:50%; transition:all var(--t1); display:flex; align-items:center; justify-content:center; -webkit-tap-highlight-color:transparent; }
.mob-fp-btn:active { background:var(--hover); }
.mob-fp-btn.active { color:var(--accent-dark); }
.mob-fp-play { background:var(--accent) !important; color:#111 !important; width:68px; height:68px; border-radius:50% !important; box-shadow:0 8px 24px rgba(243,198,57,.35); }
.mob-fp-play:active { transform:scale(.94); }

/* ════════════════════════════════════════════════════════
   DEVICE CONNECT SECTION
════════════════════════════════════════════════════════ */
.device-list { display:flex; flex-direction:column; gap:6px; }
.device-item {
  display:flex; align-items:center; gap:14px;
  padding:14px 16px; border-radius:var(--r12);
  border:1.5px solid var(--border);
  background:var(--surface);
  cursor:pointer;
  transition:all var(--t2);
  -webkit-tap-highlight-color:transparent;
}
.device-item:hover { border-color:var(--border-2); background:var(--hover); }
.device-item.active { border-color:var(--accent-bdr); background:var(--accent-dim); }
.device-item.connecting { opacity:.6; pointer-events:none; }
.device-item.error { border-color:rgba(229,62,62,.3); background:rgba(229,62,62,.04); }
.device-icon { width:46px; height:46px; border-radius:14px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.device-info { flex:1; min-width:0; }
.device-name { font-size:14px; font-weight:700; color:var(--text); }
.device-status { font-size:12px; color:var(--text-3); margin-top:2px; transition:color .2s; }
.device-item.active .device-status { color:var(--accent-dark); font-weight:600; }
.device-item.connecting .device-status { color:var(--text-4); }
.device-item.error .device-status { color:#e53e3e; }
.device-active-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--accent-dark); flex-shrink:0;
  box-shadow:0 0 0 3px var(--accent-dim);
  animation:pulse 2s ease-in-out infinite;
}
.device-arrow { color:var(--text-4); flex-shrink:0; transition:transform .2s; }
.device-item:hover .device-arrow { transform:translateX(2px); color:var(--text-2); }

.share-audio-row { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:4px; }
.share-audio-btn {
  display:flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 14px; border-radius:var(--r8);
  border:1.5px solid var(--border); background:var(--surface);
  color:var(--text-2); font-size:13px; font-weight:700;
  cursor:pointer; transition:all var(--t1); font-family:var(--ff-display);
  -webkit-tap-highlight-color:transparent;
}
.share-audio-btn:hover { border-color:var(--accent-bdr); background:var(--accent-dim); color:var(--accent-dark); }
.share-audio-btn:active { transform:scale(.97); }
.share-audio-btn.unavailable { opacity:.45; cursor:not-allowed; }
@media (max-width:480px) {
  .share-audio-row { grid-template-columns:1fr 1fr; gap:6px; }
  .share-audio-btn { font-size:12px; padding:10px 8px; gap:5px; }
}

/* ════════════════════════════════════════════════════════
   SETTINGS MOBILE — all breakpoints
════════════════════════════════════════════════════════ */
@media (max-width:900px) {
  /* Slide up from bottom */
  .settings-overlay { align-items:flex-end; justify-content:center; }
  .settings-panel {
    max-width:100%; width:100%; height:92dvh;
    border-radius:20px 20px 0 0;
    border-left:none; border-top:1px solid var(--border);
    overflow:hidden;
    display:flex; flex-direction:column;
    animation:mfpSlideUp .35s cubic-bezier(.34,1.3,.64,1) both;
  }
  /* Layout: stacked */
  .settings-layout {
    grid-template-columns:1fr;
    flex:1; display:flex; flex-direction:column;
    overflow:hidden; min-height:0;
  }
  /* Horizontal pill scrollbar for categories */
  .settings-cats {
    display:flex !important; flex-direction:row !important;
    overflow-x:auto !important; overflow-y:hidden !important;
    max-height:none !important;
    padding:10px 14px !important;
    gap:5px !important;
    border-right:none !important;
    border-bottom:1px solid var(--border) !important;
    flex-shrink:0 !important;
    background:var(--bg) !important;
    -webkit-overflow-scrolling:touch;
  }
  .settings-cats::-webkit-scrollbar { display:none !important; }
  .settings-cat-group { display:flex !important; flex-direction:row !important; gap:5px !important; padding:0 !important; flex-shrink:0 !important; }
  .settings-cat-label { display:none !important; }
  .settings-cat-item {
    white-space:nowrap !important;
    padding:8px 16px !important; font-size:13px !important;
    border-radius:var(--pill) !important;
    border:1.5px solid var(--border) !important;
    background:var(--surface) !important;
    min-width:auto !important;
  }
  .settings-cat-item.active {
    background:var(--accent-dim) !important;
    border-color:var(--accent-bdr) !important;
    color:var(--accent-dark) !important;
  }
  .settings-cat-item span { flex:none !important; }
  .cat-arrow { display:none !important; }
  /* Scrollable content area */
  .settings-body {
    flex:1 !important; overflow-y:auto !important;
    padding:18px 16px calc(env(safe-area-inset-bottom,0px) + 80px) !important;
    -webkit-overflow-scrolling:touch;
  }
  .settings-hdr { padding:16px 18px !important; }
  .settings-hdr-actions { gap:6px !important; }
  .settings-logout-btn { padding:6px 11px !important; font-size:12px !important; }
  .settings-sec-title { font-size:16px !important; }
  /* Cards */
  .settings-card { padding:14px 14px !important; }
  .settings-form label { gap:6px !important; margin-bottom:8px !important; }
  .settings-form label input { font-size:14px !important; }
  /* Plan status row */
  .plan-status-row { grid-template-columns:1fr 1fr !important; gap:8px !important; }
  /* upgrade grid */
  .upgrade-grid, .coming-soon-grid { grid-template-columns:1fr !important; }
  /* Device list */
  .device-item { padding:12px 13px !important; }
  .device-icon { width:40px !important; height:40px !important; }
}
@media (max-width:480px) {
  .settings-panel { height:94dvh !important; }
  .settings-body { padding:14px 12px calc(env(safe-area-inset-bottom,0px) + 80px) !important; }
  .settings-form label span { font-size:11.5px !important; }
}
@keyframes mfpSlideUp {
  from { transform:translateY(100%); opacity:.6; }
  to { transform:translateY(0); opacity:1; }
}

/* ════════════════════════════════════════════════════════
   FILA DE REPRODUÇÃO (Queue Settings Panel)
════════════════════════════════════════════════════════ */
.fila-hdr { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; border-bottom:1px solid var(--border); }
.fila-hdr span { font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--text-3); }
.fila-item { display:flex; align-items:center; gap:10px; padding:9px 14px; border-bottom:1px solid var(--border); transition:background var(--t1); }
.fila-item:last-child { border-bottom:none; }
.fila-item.fila-now { background:var(--accent-dim); }
.fila-item-num { font-size:11px; color:var(--text-4); width:18px; text-align:center; flex-shrink:0; }
.fila-item-art { width:36px; height:36px; border-radius:6px; overflow:hidden; flex-shrink:0; background:var(--hover); }
.fila-item-art img { width:100%; height:100%; object-fit:cover; display:block; }
.fila-item-info { flex:1; min-width:0; }
.fila-item-title { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fila-item-artist { font-size:11px; color:var(--text-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fila-item-dur { font-size:11px; color:var(--text-4); flex-shrink:0; }
.fila-item-play { background:none; border:none; color:var(--accent-dark); cursor:pointer; padding:5px; opacity:0; transition:opacity var(--t1); font-size:11px; }
.fila-item-del { background:none; border:none; color:var(--text-4); cursor:pointer; padding:5px; opacity:0; transition:opacity var(--t1); }
.fila-item:hover .fila-item-play,
.fila-item:hover .fila-item-del { opacity:1; }
.fila-item-del:hover { color:#e53e3e; }
.fila-empty { padding:32px 16px; text-align:center; color:var(--text-4); font-size:13px; }
.fila-section-label { font-size:10px; font-weight:800; text-transform:uppercase; letter-spacing:.1em; color:var(--text-4); padding:10px 14px 4px; }
/* Mobile: touch-friendly */
@media (max-width:900px) {
  .fila-item-play, .fila-item-del { opacity:1; }
}

/* ════════════════════════════════════════════════════════
   PLAYER BAR — mobile X close button
════════════════════════════════════════════════════════ */
.player-close-mobile {
  display:none;
  background:none; border:none;
  color:var(--text-3); cursor:pointer;
  padding:6px; border-radius:50%;
  flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
.player-close-mobile:active { background:var(--hover); }
@media (max-width:900px) {
  .player-close-mobile { display:flex; align-items:center; justify-content:center; }
  /* Hide desktop close btn on mobile (we use our new one) */
  #closePlayerBtn { display:none !important; }
}

/* ── TRACK PAGER ─────────────────────────────────────────── */
.track-pager { display:flex; align-items:center; justify-content:center; gap:14px; padding:16px; font-size:13px; color:var(--text-3); border-top:1px solid var(--border); }
.track-pager-btn { background:var(--surface); border:1.5px solid var(--border); color:var(--text-2); font-size:13px; font-weight:700; padding:7px 18px; border-radius:var(--pill); cursor:pointer; transition:all var(--t1); font-family:var(--ff-display); }
.track-pager-btn:hover { border-color:var(--accent-bdr); background:var(--accent-dim); color:var(--accent-dark); }

/* ════════════════════════════════════════════════════════
   ORBIPLAY EVOLUTION ENGINE — Dynamic styles
════════════════════════════════════════════════════════ */
.evo-mood-chip { animation:slideDown .3s ease; }
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.evo-sugg-chip:hover { border-color:var(--accent-bdr) !important; background:var(--accent-dim) !important; color:var(--accent-dark) !important; }
.evo-recent-item:hover { background:var(--hover) !important; }
#evoRecentSection, #evoRecsSection { animation:fadeInUp .4s ease; }
@keyframes fadeInUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
#evoDashboard .plan-status-box { background:var(--bg); border:1.5px solid var(--border); border-radius:var(--r8); padding:10px 12px; text-align:center; }
#evoLog::-webkit-scrollbar { width:3px; }
#evoLog::-webkit-scrollbar-thumb { background:var(--border-2); border-radius:2px; }

/* ══════════════════════════════════════════════════════════════
   IPHONE SAFE AREA — Fix logo behind clock
══════════════════════════════════════════════════════════════ */
/* When installed as PWA (black-translucent status bar), 
   pad the top bar so content clears the iPhone notch/clock */
@supports (padding-top: env(safe-area-inset-top)) {
  .music-top-bar {
    padding-top: env(safe-area-inset-top, 0px);
    height: calc(60px + env(safe-area-inset-top, 0px));
  }
  .music-page-wrap {
    padding-top: 0;
  }
  /* Full player header also needs safe area */
  .mob-fp-header {
    padding-top: calc(env(safe-area-inset-top, 0px) + 16px) !important;
  }
  /* Mobile nav bottom safe area */
  .mobile-nav {
    padding-bottom: env(safe-area-inset-bottom, 0px);
    height: calc(60px + env(safe-area-inset-bottom, 0px));
  }
  /* Player bar above mobile nav */
  .player-bar {
    bottom: calc(60px + env(safe-area-inset-bottom, 0px));
  }
}

/* ══════════════════════════════════════════════════════════════
   TOPBAR ICON BUTTONS
══════════════════════════════════════════════════════════════ */
.topbar-icon-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: none; border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2);
  transition: all var(--t1);
  position: relative;
  -webkit-tap-highlight-color: transparent;
}
.topbar-icon-btn:hover { background: var(--hover); color: var(--text); }
.topbar-icon-btn:active { background: var(--active); transform: scale(.92); }

/* ══════════════════════════════════════════════════════════════
   NOTIFICATION DOT + PANEL
══════════════════════════════════════════════════════════════ */
.notif-dot {
  position: absolute;
  top: 4px; right: 4px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #e53e3e;
  border: 2px solid var(--bg);
  animation: notifPulse 2s ease-in-out infinite;
}
@keyframes notifPulse {
  0%,100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.3); opacity: .8; }
}
.mobile-nav-item .notif-dot {
  top: 2px; right: 8px;
  border-color: rgba(255,255,255,.98);
}

/* Notification Panel */
.notif-panel { position: fixed; inset: 0; z-index: 700; pointer-events: none; }
.notif-panel:not([hidden]) { pointer-events: all; }
.notif-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.35);
  opacity: 0; transition: opacity .25s;
}
.notif-panel:not([hidden]) .notif-overlay { opacity: 1; }
.notif-sheet {
  position: absolute;
  top: 0; right: 0;
  width: 340px; max-width: 95vw;
  height: 100vh;
  background: var(--surface);
  border-left: 1px solid var(--border);
  box-shadow: -8px 0 40px rgba(0,0,0,.12);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform .3s cubic-bezier(.32,0,.67,0);
  overflow: hidden;
}
.notif-panel:not([hidden]) .notif-sheet {
  transform: translateX(0);
  transition: transform .32s cubic-bezier(.34,1.3,.64,1);
}
.notif-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: calc(env(safe-area-inset-top,0px) + 16px) 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.notif-title {
  font-size: 17px; font-weight: 800;
  font-family: var(--ff-display); color: var(--text);
}
.notif-close-btn {
  background: var(--hover); border: none;
  width: 28px; height: 28px; border-radius: 50%;
  cursor: pointer; font-size: 13px; color: var(--text-3);
  display: flex; align-items: center; justify-content: center;
  transition: all var(--t1);
}
.notif-close-btn:hover { background: var(--active); color: var(--text); }
.notif-list { flex: 1; overflow-y: auto; padding: 8px 0; }
.notif-item {
  display: flex; align-items: flex-start; gap: 13px;
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  cursor: pointer; transition: background var(--t1);
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--hover); }
.notif-item.unread { background: var(--accent-dim); }
.notif-item.unread:hover { background: rgba(243,198,57,.15); }
.notif-icon {
  width: 42px; height: 42px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 20px;
}
.notif-content { flex: 1; min-width: 0; }
.notif-item-title { font-size: 13.5px; font-weight: 700; color: var(--text); margin-bottom: 2px; }
.notif-item-body { font-size: 12px; color: var(--text-3); line-height: 1.5; }
.notif-item-time { font-size: 10.5px; color: var(--text-4); margin-top: 4px; }
.notif-unread-badge {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent-dark); flex-shrink: 0; margin-top: 6px;
}
.notif-empty {
  padding: 60px 24px; text-align: center;
  color: var(--text-4); font-size: 14px;
}
.notif-empty svg { display: block; margin: 0 auto 16px; opacity: .3; }

/* Mobile: full-width bottom sheet */
@media (max-width: 600px) {
  .notif-sheet {
    top: auto; bottom: 0; left: 0; right: 0;
    width: 100%; height: 75vh;
    border-left: none; border-top: 1px solid var(--border);
    border-radius: 20px 20px 0 0;
    transform: translateY(100%);
  }
  .notif-panel:not([hidden]) .notif-sheet { transform: translateY(0); }
}

/* ══════════════════════════════════════════════════════════
   BANNER FIX — background art + overlay
══════════════════════════════════════════════════════════ */
.banner-bg-art { display:none; } /* replaced by inline style */
.banner-inner { position:relative; z-index:3; display:flex; flex-direction:column; gap:6px; max-width:460px; }
.banner-title { font-family:var(--ff-display); font-size:clamp(17px,2.2vw,24px); font-weight:900; color:#fff; line-height:1.15; margin:0; }
.banner-sub { font-size:12px; color:rgba(255,255,255,.7); margin:0; }
.banner-btn { display:inline-flex; align-items:center; gap:6px; padding:8px 18px; border-radius:var(--pill); background:rgba(255,255,255,.95); color:#111; font-family:var(--ff-display); font-size:12px; font-weight:800; border:none; cursor:pointer; margin-top:6px; transition:all var(--t1); width:fit-content; }
.banner-btn:hover { background:#fff; transform:translateY(-1px); box-shadow:0 4px 14px rgba(0,0,0,.25); }
.banner-btn.dark { background:rgba(0,0,0,.85); color:#fff; }
.banner-dots { display:flex; gap:5px; flex-direction:column; position:relative; z-index:3; }
.banner-dot { width:6px; height:6px; border-radius:3px; background:rgba(255,255,255,.4); cursor:pointer; border:none; transition:all var(--t2); padding:0; }
.banner-dot.active { background:rgba(255,255,255,.95); height:22px; border-radius:3px; }
.banner-covers { position:absolute; right:70px; top:50%; transform:translateY(-50%); display:flex; align-items:center; gap:12px; z-index:3; pointer-events:none; }
.bcc { border-radius:var(--r8); overflow:hidden; box-shadow:0 8px 30px rgba(0,0,0,.6); flex-shrink:0; }
.bcc img { display:block; object-fit:cover; }
.bcc-l { width:68px; height:68px; opacity:.7; transform:rotate(-6deg) translateY(4px); }
.bcc-m { width:110px; height:110px; opacity:1; }
.bcc-r { width:68px; height:68px; opacity:.7; transform:rotate(6deg) translateY(4px); }
@media (max-width:1100px){ .banner-covers { right:30px; } }
@media (max-width:900px){ .banner-covers { display:none; } .hero-banners { height:170px; min-height:170px; padding:0 20px; } }
@media (max-width:480px){ .hero-banners { height:150px; min-height:150px; padding:0 16px; } .banner-title { font-size:16px; } }

/* ══════════════════════════════════════════════════════════
   PODCAST DETAIL + EPISODES
══════════════════════════════════════════════════════════ */
.pod-loading { display:flex; align-items:center; justify-content:center; gap:12px; padding:40px 16px; color:var(--text-3); font-size:14px; font-weight:600; }
.pod-spinner { width:20px; height:20px; border:2.5px solid var(--border); border-top-color:var(--accent-dark); border-radius:50%; animation:podSpin .7s linear infinite; flex-shrink:0; }
@keyframes podSpin { to { transform:rotate(360deg); } }
.pod-back-btn { display:inline-flex; align-items:center; gap:6px; background:none; border:1.5px solid var(--border); color:var(--text-3); font-size:13px; font-weight:700; padding:6px 14px; border-radius:var(--pill); cursor:pointer; margin:16px 16px 8px; transition:all var(--t1); }
.pod-back-btn:hover { border-color:var(--border-2); color:var(--text); }
.pod-detail { display:flex; flex-direction:column; }
.pod-detail-header { display:flex; align-items:center; gap:14px; padding:0 16px 16px; }
.pod-detail-art { width:72px; height:72px; border-radius:10px; overflow:hidden; flex-shrink:0; }
.pod-detail-art img { width:100%; height:100%; object-fit:cover; display:block; }
.pod-detail-name { font-size:16px; font-weight:800; color:var(--text); font-family:var(--ff-display); }
.pod-episodes-list { display:flex; flex-direction:column; border-top:1px solid var(--border); }
.pod-ep-row { display:flex; align-items:center; gap:12px; padding:12px 16px; border-bottom:1px solid var(--border); transition:background var(--t1); cursor:pointer; }
.pod-ep-row:last-child { border-bottom:none; }
.pod-ep-row:hover { background:var(--hover); }
.pod-ep-row.pod-ep-playing { background:var(--accent-dim); }
.pod-ep-num { font-size:12px; color:var(--text-4); width:24px; text-align:center; flex-shrink:0; font-weight:600; }
.pod-ep-row.pod-ep-playing .pod-ep-num { color:var(--accent-dark); }
.pod-ep-info { flex:1; min-width:0; }
.pod-ep-title { font-size:13px; font-weight:700; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pod-ep-desc { font-size:11px; color:var(--text-3); margin-top:2px; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; line-height:1.4; }
.pod-ep-date { font-size:10px; color:var(--text-4); margin-top:3px; }
.pod-ep-play-btn { width:34px; height:34px; border-radius:50%; background:var(--accent); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:#111; transition:all var(--t1); }
.pod-ep-play-btn:hover { transform:scale(1.1); background:var(--accent-dark); }
.pod-ep-row.pod-ep-playing .pod-ep-play-btn { background:var(--accent-dark); }

/* ══════════════════════════════════════════════════════════
   RADIO STATES — loading, error
══════════════════════════════════════════════════════════ */
.radio-spinner { width:12px; height:12px; border:2px solid rgba(255,255,255,.3); border-top-color:currentColor; border-radius:50%; animation:podSpin .7s linear infinite; display:inline-block; flex-shrink:0; }
.radio-card.radio-loading { border-color:var(--accent-bdr); background:var(--accent-dim); opacity:.8; }
.radio-card.radio-loading .radio-live { color:var(--accent-dark); display:flex; align-items:center; gap:5px; }
.radio-card.radio-playing { border-color:var(--accent-bdr); background:var(--accent-dim); }
.radio-card.radio-error { border-color:rgba(229,62,62,.3); background:rgba(229,62,62,.04); }
.radio-card.radio-error .radio-live { color:#e53e3e; display:flex; align-items:center; gap:4px; }

/* ══════════════════════════════════════════════════════════════
   PODCAST DETAIL — redesigned hero
══════════════════════════════════════════════════════════════ */
.pod-detail { display:flex; flex-direction:column; padding-bottom:100px; }
.pod-ep-row {
  display:flex; align-items:center; gap:12px;
  padding:14px 20px; border-bottom:1px solid var(--border);
  transition:background var(--t1); cursor:default;
}
.pod-ep-row:hover { background:var(--hover); }
.pod-ep-row.pod-ep-playing { background:var(--accent-dim); }
.pod-ep-num {
  font-size:12px; color:var(--text-4); width:26px;
  text-align:center; flex-shrink:0; font-weight:700;
}
.pod-ep-row.pod-ep-playing .pod-ep-num { color:var(--accent-dark); }
.pod-ep-info { flex:1; min-width:0; }
.pod-ep-title {
  font-size:14px; font-weight:700; color:var(--text);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pod-ep-desc {
  font-size:12px; color:var(--text-3); margin-top:3px;
  overflow:hidden; display:-webkit-box;
  -webkit-line-clamp:2; -webkit-box-orient:vertical; line-height:1.5;
}
.pod-ep-date { font-size:11px; color:var(--text-4); margin-top:4px; }
.pod-ep-play-btn {
  width:36px; height:36px; border-radius:50%;
  background:var(--accent); border:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0; color:#111; transition:all var(--t1);
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.pod-ep-play-btn:hover { transform:scale(1.1); background:#e6b800; }
.pod-ep-row.pod-ep-playing .pod-ep-play-btn { background:var(--accent-dark); }
