@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--bg: #0e0b1a;--bg-2: #130f21;--surface: #1a1528;--card: #1e1930;--card-hi: #241d38;--border: rgba(162, 122, 255, .12);--border-hi: rgba(162, 122, 255, .28);--purple: #7b52ab;--purple-lo: #5c3a8a;--purple-hi: #a56ee8;--purple-glow: rgba(123, 82, 171, .35);--pink: #d4659b;--pink-lo: rgba(212, 101, 155, .15);--text: #ede8ff;--text-2: #9d93c0;--text-3: #5e5480;--gold: #e8c56d;--silver: #a8b5c8;--bronze: #c4875a;--r: 14px;--r-sm: 8px;--font: "Plus Jakarta Sans", sans-serif;--font-ui: "Space Grotesk", sans-serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.65;background-image:radial-gradient(ellipse 60% 40% at 20% 0%,rgba(123,82,171,.15) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 80% 100%,rgba(212,101,155,.08) 0%,transparent 70%);background-attachment:fixed}.stars-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.star{position:absolute;border-radius:50%;background:#fff;animation:twinkle var(--duration, 4s) infinite ease-in-out var(--delay, 0s)}@keyframes twinkle{0%,to{opacity:.1;transform:scale(1)}50%{opacity:.8;transform:scale(1.3)}}.app-wrapper{min-height:100vh;position:relative}.navbar{position:sticky;top:0;z-index:100;background:#0e0b1ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:66px}.navbar-brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text)}.logo-text{font-family:var(--font-ui);font-size:1.1rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,var(--purple-hi),var(--pink));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-sub{font-size:.6rem;font-weight:400;color:var(--text-3);display:block;margin-top:-2px;letter-spacing:.06em;text-transform:uppercase;-webkit-text-fill-color:var(--text-3)}.navbar-links{display:flex;gap:4px;list-style:none}.navbar-links a{text-decoration:none;color:var(--text-2);font-family:var(--font-ui);font-weight:500;font-size:.85rem;padding:.4rem .85rem;border-radius:20px;transition:color .15s,background .15s}.navbar-links a:hover{color:var(--text);background:#ffffff0f}.navbar-links a.active{color:var(--purple-hi);background:#7b52ab2e;border:1px solid rgba(123,82,171,.3)}.main-content{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:2.5rem 1.5rem 5rem}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;transition:border-color .2s;position:relative}.card:hover{border-color:var(--border-hi)}.card:before{content:"";position:absolute;top:0;left:1.25rem;right:1.25rem;height:1px;background:linear-gradient(90deg,transparent,rgba(162,122,255,.3),transparent);border-radius:1px}.page-title{font-family:var(--font-ui);font-size:1.8rem;font-weight:700;letter-spacing:-.03em;background:linear-gradient(135deg,var(--text) 40%,var(--purple-hi));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.25rem}.page-subtitle{font-size:.875rem;color:var(--text-2);margin-bottom:2rem}.podium-container{display:flex;align-items:flex-end;justify-content:center;gap:1rem;margin:1.5rem 0 2.5rem}.podium-card{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.5rem 1.1rem 2rem;border-radius:var(--r);min-width:158px;text-align:center;position:relative;overflow:hidden;cursor:pointer;transition:transform .22s,box-shadow .22s;background:var(--card-hi);border:1px solid var(--border)}.podium-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0006}.podium-card.first{border-color:#e8c56d59;background:linear-gradient(160deg,rgba(232,197,109,.06) 0%,var(--card-hi) 60%);box-shadow:0 0 30px #e8c56d0f}.podium-card.second{border-color:#a8b5c840;background:linear-gradient(160deg,rgba(168,181,200,.05) 0%,var(--card-hi) 60%)}.podium-card.third{border-color:#c4875a40;background:linear-gradient(160deg,rgba(196,135,90,.05) 0%,var(--card-hi) 60%)}.podium-card.first{order:2}.podium-card.second{order:1;min-height:auto}.podium-card.third{order:3}.podium-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r) var(--r) 0 0}.podium-card.first:after{background:linear-gradient(90deg,var(--gold),#fff7c0,var(--gold))}.podium-card.second:after{background:linear-gradient(90deg,var(--silver),#e8edf3,var(--silver))}.podium-card.third:after{background:linear-gradient(90deg,var(--bronze),#f5d4b8,var(--bronze))}.podium-crown{position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:1.4rem;animation:float 3.5s ease-in-out infinite;filter:drop-shadow(0 2px 6px rgba(232,197,109,.5))}@keyframes float{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-5px)}}.podium-avatar{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:1.5rem;font-weight:700}.podium-card.first .podium-avatar{background:#e8c56d26;color:var(--gold);border:1.5px solid rgba(232,197,109,.4)}.podium-card.second .podium-avatar{background:#a8b5c81f;color:var(--silver);border:1.5px solid rgba(168,181,200,.3)}.podium-card.third .podium-avatar{background:#c4875a1f;color:var(--bronze);border:1.5px solid rgba(196,135,90,.3)}.podium-name{font-family:var(--font-ui);font-weight:700;font-size:.95rem;letter-spacing:-.01em;color:var(--text)}.podium-estado{font-size:.68rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.podium-scrobbles{font-family:var(--font-ui);font-size:1.4rem;font-weight:700;color:var(--text);line-height:1.1}.podium-scrobbles span{font-size:.62rem;font-weight:400;color:var(--pink);display:block;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.podium-badge{position:absolute;bottom:7px;right:10px;font-size:1.3rem;opacity:.45}.ranking-table{width:100%;border-collapse:collapse}.ranking-table th{text-align:left;font-family:var(--font-ui);font-size:.68rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;padding:.6rem 1rem;border-bottom:1px solid var(--border)}.ranking-table td{padding:.7rem 1rem;border-bottom:1px solid rgba(162,122,255,.05);vertical-align:middle}.ranking-row{cursor:pointer;transition:background .15s}.ranking-row:hover{background:#7b52ab12}.rank-num{font-family:var(--font-ui);font-weight:600;font-size:.85rem;color:var(--text-3)}.rank-num.top1{color:var(--gold);font-size:1.1rem}.rank-num.top2{color:var(--silver);font-size:1rem}.rank-num.top3{color:var(--bronze);font-size:1rem}.user-info{display:flex;align-items:center;gap:.65rem}.user-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}.user-name{font-weight:600;font-size:.9rem;letter-spacing:-.01em;color:var(--text)}.user-lastfm{font-size:.72rem;color:var(--text-3)}.estado-badge{display:inline-block;padding:.15rem .6rem;border-radius:20px;font-family:var(--font-ui);font-size:.68rem;font-weight:600;background:#7b52ab29;color:var(--purple-hi);border:1px solid rgba(123,82,171,.28);text-transform:uppercase;letter-spacing:.05em}.scrobbles-val{font-family:var(--font-ui);font-weight:700;font-size:.95rem;color:var(--text)}.dias-activos{font-size:.82rem;color:var(--text-2)}.filters-bar{display:flex;gap:.875rem;flex-wrap:wrap;align-items:flex-end;margin-bottom:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.3rem}.filter-label{font-family:var(--font-ui);font-size:.67rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.filter-select{background:var(--card-hi);border:1px solid var(--border);color:var(--text);border-radius:20px;padding:.45rem .85rem;font-family:var(--font-ui);font-size:.84rem;cursor:pointer;outline:none;transition:border-color .15s}.filter-select:focus{border-color:var(--purple)}.heatmap-cell{border-radius:3px;aspect-ratio:1;transition:transform .12s;cursor:pointer}.heatmap-cell:hover{transform:scale(1.6);z-index:10}.heatmap-cell[data-level="0"]{background:#ffffff0a}.heatmap-cell[data-level="1"]{background:#d4659b40}.heatmap-cell[data-level="2"]{background:#d4659b80}.heatmap-cell[data-level="3"]{background:#a56ee8bf}.heatmap-cell[data-level="4"]{background:var(--purple-hi);box-shadow:0 0 6px var(--purple-glow)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(135px,1fr));gap:.875rem;margin-bottom:1.75rem}.stat-card{background:var(--card-hi);border:1px solid var(--border);border-radius:var(--r-sm);padding:1.1rem 1rem;transition:border-color .2s}.stat-card:hover{border-color:var(--border-hi)}.stat-icon{font-size:1.25rem;margin-bottom:.5rem}.stat-value{font-family:var(--font-ui);font-size:1.55rem;font-weight:700;letter-spacing:-.03em;color:var(--text)}.stat-label{font-size:.7rem;color:var(--text-3);margin-top:.12rem;text-transform:uppercase;letter-spacing:.05em}.btn{padding:.55rem 1.1rem;border-radius:20px;font-family:var(--font-ui);font-weight:600;font-size:.85rem;cursor:pointer;border:none;transition:all .15s;letter-spacing:-.01em}.btn-primary{background:linear-gradient(135deg,var(--purple),var(--pink));color:#fff;border:1px solid rgba(255,255,255,.1)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 20px var(--purple-glow)}.btn-secondary{background:#ffffff0d;color:var(--text-2);border:1px solid var(--border)}.btn-secondary:hover{background:#ffffff17;color:var(--text)}.btn-danger{background:#dc35451a;color:#f47373;border:1px solid rgba(220,53,69,.22)}.btn-danger:hover{background:#dc35452e}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.875rem}.form-label{font-family:var(--font-ui);font-size:.7rem;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em}.form-input,.form-select{background:var(--bg-2);border:1px solid var(--border);color:var(--text);border-radius:var(--r-sm);padding:.55rem .85rem;font-family:var(--font);font-size:.875rem;outline:none;width:100%;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus{border-color:var(--purple);box-shadow:0 0 0 3px #7b52ab26}.form-input::placeholder{color:var(--text-3)}.loading-state{text-align:center;padding:4rem 2rem;color:var(--text-2)}.loading-spinner{width:38px;height:38px;border:2px solid rgba(162,122,255,.12);border-top-color:var(--purple-hi);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.error-state{padding:2rem;text-align:center;background:#dc35450f;border:1px solid rgba(220,53,69,.15);border-radius:var(--r);color:#f47373;font-size:.9rem;line-height:1.7}.estados-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(265px,1fr));gap:1.25rem}.estado-card{transition:transform .2s,border-color .2s}.estado-card:hover{transform:translateY(-3px);border-color:var(--border-hi)}.estado-title{font-family:var(--font-ui);font-size:1.1rem;font-weight:700;margin-bottom:.875rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem}.admin-login{max-width:400px;margin:4rem auto}.admin-grid{display:grid;grid-template-columns:1fr 330px;gap:1.5rem;align-items:start}.toast{position:fixed;bottom:1.75rem;right:1.75rem;background:var(--card-hi);border:1px solid var(--border-hi);border-radius:var(--r-sm);padding:.75rem 1.125rem;font-family:var(--font-ui);font-size:.85rem;color:var(--text);z-index:999;animation:slideIn .25s ease;box-shadow:0 8px 30px #00000080}.toast.success{border-color:#4ade804d}.toast.error{border-color:#dc35454d}@keyframes slideIn{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.footer{text-align:center;padding:1.5rem;color:var(--text-3);font-size:.8rem;border-top:1px solid var(--border);position:relative;z-index:1;font-family:var(--font-ui);letter-spacing:.03em}@media (max-width: 860px){.admin-grid{grid-template-columns:1fr}.podium-container{flex-direction:column;align-items:center}.podium-card{order:unset!important;width:100%;max-width:260px}.main-content{padding:1.5rem 1rem 4rem}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:#7b52ab66;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--purple)}::selection{background:#7b52ab66;color:var(--text)}
