.user-menu{position:relative}.user-menu-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.user-menu-btn:hover{border-color:var(--accent);transform:scale(1.05);color:var(--accent)}.user-menu-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;min-width:220px;padding:8px;box-shadow:0 12px 36px rgba(0,0,0,.4);z-index:1001;opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .18s ease,transform .18s ease,visibility .18s}.user-menu.is-open .user-menu-dropdown{opacity:1;visibility:visible;transform:translateY(0)}.user-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;color:var(--text-secondary);text-decoration:none;background:none;border:none;cursor:pointer;border-radius:8px;font-size:13px;font-family:inherit;text-align:left;transition:var(--transition)}.user-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu-item i{width:16px;text-align:center;color:var(--accent)}.user-menu-item.logout-btn i{color:#e74c3c}.auth-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:2000;padding:20px}.auth-modal.is-open{display:flex}.auth-modal-backdrop{position:absolute;inset:0;background:rgba(5,5,20,.75);backdrop-filter:blur(8px);animation:authFadeIn .25s ease}.auth-modal-panel{position:relative;background:var(--bg-card,#16162d);border:1px solid var(--border,rgba(255,255,255,.08));border-radius:20px;padding:36px 32px 28px;width:100%;max-width:440px;box-shadow:0 24px 80px rgba(0,0,0,.6);animation:authSlideUp .3s cubic-bezier(.2,.9,.3,1.1);max-height:92vh;overflow-y:auto}@keyframes authFadeIn{from{opacity:0}to{opacity:1}}@keyframes authSlideUp{from{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:15px;transition:var(--transition)}.auth-modal-close:hover{background:var(--bg-hover);color:#fff}.auth-tabs{display:flex;gap:4px;margin-bottom:22px;background:rgba(255,255,255,.04);padding:4px;border-radius:10px}.auth-tab{flex:1;background:transparent;border:none;padding:8px 10px;border-radius:8px;color:var(--text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition)}.auth-tab:hover{color:var(--text-primary)}.auth-tab.is-active{background:var(--accent-gradient,linear-gradient(135deg,#e74c8b,#a855f7));color:#fff;box-shadow:0 4px 14px rgba(231,76,139,.3)}.auth-form{display:none}.auth-form.is-active{display:block}.auth-title{font-size:20px;margin:0 0 18px;color:var(--text-primary);font-weight:700}.auth-field{display:block;margin-bottom:14px}.auth-field>span{display:block;font-size:12px;color:var(--text-muted);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.03em}.auth-field input,.auth-field select{width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-primary);font-size:14px;font-family:inherit;transition:var(--transition);box-sizing:border-box}.auth-field input:focus,.auth-field select:focus{outline:none;border-color:var(--accent,#e74c8b);background:rgba(255,255,255,.06)}.auth-field input[type="date"]{color-scheme:dark}.auth-field select[data-custom-select]{position:absolute!important;opacity:0!important;pointer-events:none!important;height:0!important;width:0!important;border:0!important;padding:0!important}.cs-wrap{position:relative}.cs-btn{width:100%;padding:11px 38px 11px 14px;border-radius:10px;border:1px solid var(--border);background:rgba(255,255,255,.03);color:var(--text-primary);font-size:14px;font-family:inherit;text-align:left;cursor:pointer;transition:var(--transition);box-sizing:border-box;position:relative;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cs-btn::after{content:"";position:absolute;right:14px;top:50%;width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid #999;transform:translateY(-50%);transition:transform .15s ease}.cs-wrap.is-open .cs-btn{border-color:var(--accent,#e74c8b);background:rgba(255,255,255,.06)}.cs-wrap.is-open .cs-btn::after{transform:translateY(-50%) rotate(180deg)}.cs-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#1c1c34;border:1px solid rgba(231,76,139,.3);border-radius:10px;padding:6px;z-index:2100;max-height:240px;overflow-y:auto;box-shadow:0 16px 40px rgba(0,0,0,.6);display:none}.cs-wrap.is-open .cs-menu{display:block}.cs-wrap.cs-drop-up .cs-menu{top:auto;bottom:calc(100% + 4px)}.cs-opt{display:block;width:100%;padding:9px 12px;border:none;background:transparent;color:#e8e8f0;font-size:13px;font-family:inherit;text-align:left;border-radius:6px;cursor:pointer;transition:background .12s,color .12s}.cs-opt:hover{background:rgba(231,76,139,.18);color:#fff}.cs-opt.is-selected{background:linear-gradient(135deg,#e74c8b,#a855f7);color:#fff;font-weight:600}.cs-menu::-webkit-scrollbar{width:8px}.cs-menu::-webkit-scrollbar-track{background:transparent}.cs-menu::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:4px}.cs-menu::-webkit-scrollbar-thumb:hover{background:rgba(231,76,139,.4)}.auth-hint{display:block;font-size:11px;color:var(--text-muted);margin-top:4px;text-transform:none;letter-spacing:0}.auth-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.auth-turnstile{margin:10px 0 4px;display:flex;justify-content:center}.auth-submit{width:100%;padding:13px;border-radius:10px;border:none;background:var(--accent-gradient,linear-gradient(135deg,#e74c8b,#a855f7));color:#fff;font-size:14px;font-weight:700;cursor:pointer;font-family:inherit;margin-top:8px;transition:transform .15s ease,box-shadow .15s ease}.auth-submit:hover{transform:translateY(-1px);box-shadow:0 8px 24px rgba(231,76,139,.35)}.auth-submit:disabled{opacity:.55;cursor:wait;transform:none}.auth-error,.auth-ok{margin:10px 0 0;padding:9px 12px;border-radius:8px;font-size:13px;line-height:1.4}.auth-error{background:rgba(231,76,60,.12);color:#ff7a6b;border:1px solid rgba(231,76,60,.3)}.auth-ok{background:rgba(46,204,113,.12);color:#5ee59c;border:1px solid rgba(46,204,113,.3)}.auth-links{margin:14px 0 0;font-size:12px;color:var(--text-muted);text-align:center}.auth-links a{color:var(--accent,#e74c8b);text-decoration:none}.auth-links a:hover{text-decoration:underline}.fav-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:6px;font-size:16px;border-radius:50%;transition:var(--transition);line-height:1}.fav-btn:hover{color:#e74c8b;transform:scale(1.15)}.fav-btn.is-fav{color:#e74c8b}.fav-btn.is-fav:hover{color:#ff6b9d}.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.playlist-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:16px;transition:var(--transition);cursor:pointer;display:block;text-decoration:none;color:inherit}.playlist-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 12px 32px rgba(231,76,139,.15)}.playlist-card-cover{width:100%;aspect-ratio:1/1;border-radius:10px;background:linear-gradient(135deg,#2a2a48,#16162d);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:40px;color:rgba(255,255,255,.2);overflow:hidden}.playlist-card-cover img{width:100%;height:100%;object-fit:cover}.playlist-card-name{font-weight:700;font-size:15px;color:var(--text-primary);margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.playlist-card-meta{font-size:12px;color:var(--text-muted)}.playlist-create-card{border-style:dashed;border-color:var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:240px;color:var(--text-muted);font-weight:600;font-size:14px}.playlist-create-card i{font-size:32px;margin-bottom:8px}.playlist-create-card:hover{color:var(--accent)}.add-to-playlist-popover{position:absolute;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:8px;min-width:240px;max-height:320px;overflow-y:auto;z-index:1500;box-shadow:0 16px 40px rgba(0,0,0,.5)}.add-to-playlist-popover .popover-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;padding:6px 10px}.add-to-playlist-popover .popover-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--text-primary);font-size:13px;background:none;border:none;width:100%;text-align:left;font-family:inherit;transition:background .12s}.add-to-playlist-popover .popover-item:hover{background:var(--bg-hover)}.add-to-playlist-popover .popover-item i{color:var(--accent);width:14px}.add-to-playlist-popover .popover-divider{height:1px;background:var(--border);margin:4px 0}.auth-input-group{position:relative;display:flex;align-items:center}.auth-input-group>input{flex:1;padding-right:44px!important}.auth-pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:transparent;border:none;color:var(--text-muted);width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:color .15s,background .15s}.auth-pw-toggle:hover{color:var(--accent);background:rgba(255,255,255,.06)}.auth-pw-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.auth-check{display:flex;align-items:center;gap:10px;margin:6px 0 10px;font-size:13.5px;color:var(--text-muted);cursor:pointer;user-select:none}.auth-check input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid var(--border);border-radius:5px;background:transparent;cursor:pointer;position:relative;flex-shrink:0;transition:border-color .15s,background .15s}.auth-check input[type="checkbox"]:hover{border-color:var(--accent)}.auth-check input[type="checkbox"]:checked{background:linear-gradient(135deg,#e74c8b,#a855f7);border-color:transparent}.auth-check input[type="checkbox"]:checked::after{content:"";position:absolute;left:5px;top:1px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.auth-check span{line-height:1.3}.fav-btn.pl-btn{color:var(--text-muted)}.fav-btn.pl-btn:hover{color:var(--accent);background:rgba(231,76,139,.1)}.artist-hero-info .artist-links,.artist-hero-content .artist-links,.artist-links{display:grid!important;grid-template-columns:92px 92px 92px!important;gap:6px!important;align-items:center!important;width:288px!important;max-width:100%!important;justify-content:start!important}.artist-hero-info .artist-links .btn-artist-link,.artist-hero-content .artist-links .btn-artist-link,.artist-links>.btn-artist-link{display:flex!important;width:92px!important;box-sizing:border-box!important;white-space:nowrap!important;padding:7px 4px!important;font-size:10.5px!important;gap:4px!important;justify-content:center!important;align-items:center!important;min-width:0!important;border-radius:18px!important;overflow:hidden!important;line-height:1!important}.btn-artist-link.btn-follow{background:var(--accent-gradient);color:#fff;border:0;cursor:pointer;font-family:inherit;font-weight:600;line-height:1;transition:var(--transition)}.btn-artist-shuffle{display:flex!important;align-items:center;justify-content:center;gap:8px;width:288px!important;max-width:100%;margin:10px 0 0 0!important;padding:10px 20px!important;border:0;border-radius:24px!important;font-size:13px!important;font-weight:600;color:#fff;cursor:pointer;background:var(--accent-gradient)!important;box-shadow:0 3px 20px rgba(231,76,139,0.28)!important;transition:transform 0.2s ease,box-shadow 0.2s ease;letter-spacing:0.2px}.btn-artist-shuffle:hover{transform:translateY(-2px);box-shadow:0 6px 28px rgba(231,76,139,0.45)!important;filter:none!important}.btn-artist-link.btn-follow:hover{transform:translateY(-1px);filter:brightness(1.08)}.btn-artist-link.btn-follow.is-following{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--text-primary)}.btn-artist-link.btn-follow.is-following:hover{background:rgba(255,107,107,.1);border-color:#ff6b6b;color:#ff6b6b}.btn-artist-link.btn-follow.is-following:hover .follow-text::after{content:' · Dejar de seguir';display:none}.playlist-pop{position:absolute;width:260px;background:#16162d;border:1px solid var(--border);border-radius:12px;box-shadow:0 18px 48px rgba(0,0,0,.55);z-index:2500;padding:10px;font-size:14px}.playlist-pop-head{font-weight:700;font-size:13px;color:var(--text-muted);padding:4px 6px 8px;border-bottom:1px solid var(--border);margin-bottom:6px}.playlist-pop-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.playlist-pop-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:0;color:var(--text-primary);cursor:pointer;border-radius:8px;text-align:left;width:100%;font-family:inherit;font-size:13px}.playlist-pop-item:hover{background:rgba(231,76,139,.12);color:var(--accent)}.playlist-pop-item i{color:var(--accent);width:16px;text-align:center}.playlist-pop-item span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.playlist-pop-item small{color:var(--text-muted);font-size:11px}.playlist-pop-new{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}.playlist-pop-new input{flex:1;padding:7px 10px;background:rgba(255,255,255,.03);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;font-size:13px}.playlist-pop-new button{background:var(--accent-gradient);color:#fff;border:0;width:34px;border-radius:8px;cursor:pointer}@media (max-width:768px){.auth-modal-panel{padding:28px 22px 22px}.auth-field-row{grid-template-columns:1fr}.user-menu-dropdown{right:-8px}}.ui-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:3000;padding:20px}.ui-modal.is-open{display:flex;animation:uiFadeIn .2s ease}.ui-modal.is-closing{animation:uiFadeOut .18s ease forwards}.ui-modal-backdrop{position:absolute;inset:0;background:rgba(5,5,20,.75);backdrop-filter:blur(8px)}.ui-modal-panel{position:relative;background:var(--bg-card,#16162d);border:1px solid var(--border,rgba(255,255,255,.08));border-radius:20px;padding:28px 28px 22px;width:100%;max-width:400px;box-shadow:0 24px 80px rgba(0,0,0,.6);animation:uiSlideUp .28s cubic-bezier(.2,.9,.3,1.1);text-align:center}@keyframes uiFadeIn{from{opacity:0}to{opacity:1}}@keyframes uiFadeOut{from{opacity:1}to{opacity:0}}@keyframes uiSlideUp{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.ui-modal-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:22px}.ui-modal-icon--danger{background:rgba(231,76,60,.14);color:#ff6b6b}.ui-modal-icon--info{background:rgba(124,58,237,.14);color:#a78bfa}.ui-modal-icon--success{background:rgba(34,197,94,.14);color:#4ade80}.ui-modal-title{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--text-primary,#fff)}.ui-modal-message{margin:0 0 22px;font-size:14px;line-height:1.5;color:var(--text-muted,#b0b0c4)}.ui-modal-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.ui-modal-btn{padding:10px 22px;border-radius:10px;border:1px solid transparent;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition,all .2s);min-width:108px}.ui-modal-btn--primary{background:var(--accent-gradient,linear-gradient(135deg,#e74c8b,#a855f7));color:#fff;box-shadow:0 4px 14px rgba(231,76,139,.3)}.ui-modal-btn--primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(231,76,139,.45)}.ui-modal-btn--danger{background:linear-gradient(135deg,#ef4444,#e11d48);color:#fff;box-shadow:0 4px 14px rgba(239,68,68,.3)}.ui-modal-btn--danger:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(239,68,68,.45)}.ui-modal-btn--ghost{background:rgba(255,255,255,.05);color:var(--text-primary,#fff);border-color:var(--border,rgba(255,255,255,.1))}.ui-modal-btn--ghost:hover{background:rgba(255,255,255,.1)}.ui-modal-btn:focus-visible{outline:2px solid var(--accent,#e74c8b);outline-offset:2px}
/* === Modal Completar Perfil (post-Google o usuarios con datos vacios) === */
.cp-modal-bg{position:fixed;inset:0;z-index:3500;display:none;align-items:flex-start;justify-content:center;padding:20px;background:rgba(5,5,20,.78);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.cp-modal-bg.is-open{display:flex;animation:authFadeIn .25s ease}
.cp-modal{position:relative;width:100%;max-width:460px;margin:auto;background:linear-gradient(135deg, rgba(22,22,45,0.96), rgba(15,15,30,0.96));border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px 28px 24px;box-shadow:0 24px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(231,76,139,.10) inset;animation:authSlideUp .3s cubic-bezier(.2,.9,.3,1.1)}
.cp-modal-title{margin:0 0 6px;font-size:22px;font-weight:800;color:#fff;letter-spacing:-0.01em;background:linear-gradient(135deg,#e74c8b,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.cp-modal-sub{margin:0 0 22px;font-size:13.5px;color:rgba(255,255,255,.6)}
.cp-form{display:flex;flex-direction:column;gap:14px}
.cp-field{display:block}
.cp-field>span{display:block;font-size:12px;color:rgba(255,255,255,.55);margin-bottom:6px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.cp-field input{width:100%;padding:11px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04);color:#fff;font-size:14px;font-family:inherit;box-sizing:border-box;transition:border-color .15s, background .15s}
.cp-field input:focus{outline:none;border-color:#e74c8b;background:rgba(255,255,255,.07)}
.cp-field input[type="date"]{color-scheme:dark}
.cp-hint{display:block;font-size:11px;color:rgba(255,255,255,.45);margin-top:4px}
.cp-error{margin:8px 0 0;padding:10px 12px;border-radius:8px;font-size:13px;background:rgba(231,76,60,.12);color:#ff7a6b;border:1px solid rgba(231,76,60,.3)}
.cp-submit{margin-top:8px;padding:13px;border-radius:10px;border:0;background:linear-gradient(135deg,#e74c8b,#a855f7);color:#fff;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;box-shadow:0 6px 20px rgba(231,76,139,.32);transition:transform .15s, box-shadow .15s, filter .15s}
.cp-submit:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(231,76,139,.45);filter:brightness(1.06)}
.cp-submit:disabled{opacity:.6;cursor:wait}
.cp-field.is-prefilled{display:none}

/* === Botón "Continuar con Google" === */
/* Botón "Continuar con Google" — glassy dark, neon en contexto web */
.auth-google{
  display:flex;align-items:center;justify-content:center;gap:12px;width:100%;
  height:48px;padding:0 20px;box-sizing:border-box;
  border-radius:12px;border:1px solid rgba(255,255,255,.10);
  background:linear-gradient(135deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.015) 100%);
  color:#fff;font-size:14px;font-weight:700;font-family:inherit;letter-spacing:.01em;
  cursor:pointer;margin:0 0 18px;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  position:relative;overflow:hidden;
  transition:transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.auth-google:hover{
  transform:translateY(-1px);
  background:linear-gradient(135deg, rgba(231,76,139,0.12) 0%, rgba(168,85,247,0.07) 100%);
  border-color:rgba(231,76,139,.32);
  box-shadow:0 8px 22px rgba(231,76,139,.18), 0 0 0 1px rgba(231,76,139,.12) inset;
}
.auth-google:active{transform:translateY(0)}
.auth-google svg{
  flex-shrink:0;width:18px;height:18px;
  background:#fff;border-radius:50%;padding:3px;box-sizing:content-box;
  box-shadow:0 2px 6px rgba(0,0,0,.35);
}
.auth-google[disabled]{opacity:.55;cursor:wait}

/* Separador "o con email" — line + chip glassy en el medio */
.auth-divider{
  display:flex;align-items:center;gap:14px;margin:0 0 18px;
  color:rgba(255,255,255,.42);font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:.14em;
}
.auth-divider::before,.auth-divider::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(90deg, transparent 0%, rgba(231,76,139,.22) 50%, transparent 100%);
}
.auth-divider span{
  padding:4px 12px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
}

/* Body lock — cuando el modal cp está forzado, ocultar todo lo demás */
html.cp-locked, body.cp-locked { overflow:hidden !important; height:100vh !important; }
body.cp-locked > *:not(#cpModalBg) { visibility:hidden !important; pointer-events:none !important; }
body.cp-locked #cpModalBg { visibility:visible !important; pointer-events:auto !important; }

/* Botón "Cerrar sesión" dentro del modal cp (única salida) */
.cp-logout {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; margin-top:14px; padding:11px 14px;
  background:transparent; border:1px solid rgba(255,255,255,.10);
  color:rgba(255,255,255,.55); font-size:13px; font-weight:600; font-family:inherit;
  border-radius:10px; cursor:pointer;
  transition:background .15s, border-color .15s, color .15s;
}
.cp-logout:hover {
  background:rgba(255,107,107,.08);
  border-color:rgba(255,107,107,.30);
  color:#ff8c8c;
}
.cp-logout i { font-size:12px; }
