:root{--bg:#070707;--panel:#121212;--soft:#1c1c1f;--text:#fff;--muted:#a7a7a7;--green:#1ed760;--red:#ff394b;--yellow:#ffd166;--cyan:#30d5ff;--orange:#ff9f1c;--white:#fff;--radius:18px}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#151515,#000);color:var(--text)}a{color:inherit;text-decoration:none}button,input,select{font-family:inherit}.mobile-only{max-width:430px;margin:0 auto;min-height:100vh;background:#000;position:relative;padding-bottom:98px}.topbar{position:sticky;top:0;z-index:5;background:rgba(0,0,0,.75);backdrop-filter:blur(14px);display:flex;align-items:center;gap:12px;padding:14px 16px}.back{font-size:28px}.brand{font-weight:900;letter-spacing:-.6px}.hero{padding:0 18px 14px}.cover-big{width:72%;aspect-ratio:1/1;margin:8px auto 16px;border-radius:2px;display:block;object-fit:cover;box-shadow:0 16px 45px #000}.folder-title{font-size:34px;line-height:1;font-weight:950;margin:0 0 10px}.muted{color:var(--muted);font-size:13px}.spotify-badge{display:flex;align-items:center;gap:7px;font-size:13px;margin:12px 0}.dotlogo{width:20px;height:20px;background:var(--green);border-radius:50%;display:inline-grid;place-items:center;color:#000;font-weight:900}.actions{display:flex;align-items:center;gap:17px;margin-top:12px}.circle{width:34px;height:34px;border:1px solid #606060;border-radius:50%;display:grid;place-items:center;color:#ccc;background:transparent}.play-main{margin-left:auto;width:58px;height:58px;border:0;border-radius:50%;background:var(--green);color:#000;font-size:25px;font-weight:900}.track{display:grid;grid-template-columns:52px 1fr 30px;gap:10px;align-items:center;padding:7px 14px}.track img{width:48px;height:48px;object-fit:cover}.track b{font-size:14px}.track small{display:block;color:#aaa;margin-top:3px}.track.active b{color:var(--green)}.kebab{color:#aaa;font-size:22px;text-align:center}.player{position:fixed;left:50%;bottom:58px;transform:translateX(-50%);width:min(414px,96vw);background:#52606a;border-radius:7px;display:grid;grid-template-columns:44px 1fr auto auto;gap:8px;align-items:center;padding:8px;z-index:20}.player img{width:42px;height:42px;object-fit:cover}.player-title{font-size:13px;font-weight:800}.player-sub{font-size:12px;color:#eee}.player button{background:transparent;border:0;color:#fff;font-size:24px}.bottomnav{position:fixed;left:50%;bottom:0;transform:translateX(-50%);height:58px;width:min(430px,100vw);background:#050505;display:flex;justify-content:space-around;align-items:center;z-index:21;border-top:1px solid #171717}.bottomnav div{text-align:center;font-size:10px;color:#ddd}.bottomnav span{display:block;font-size:22px}.rows{padding:8px 0 90px}.genre-row{margin:0 0 18px}.genre-row h2{font-size:18px;margin:0 0 10px;padding:0 14px}.slide{display:flex;gap:12px;overflow-x:auto;padding:0 14px;scrollbar-width:none}.slide::-webkit-scrollbar{display:none}.card{min-width:132px}.card img{width:132px;height:132px;border-radius:6px;object-fit:cover}.card b{display:block;margin-top:7px;font-size:13px}.card small{color:#aaa}.formbox{padding:22px}.formbox h1{font-size:34px}.input{width:100%;padding:15px 14px;border-radius:12px;border:1px solid #333;background:#121212;color:#fff;margin:8px 0}.btn{border:0;border-radius:999px;padding:14px 18px;background:var(--green);font-weight:900;color:#000;cursor:pointer}.btn.secondary{background:#252525;color:#fff}.plan{border:1px solid #333;border-radius:16px;padding:14px;margin:10px 0;background:#121212}.plan input{margin-right:8px}.download{color:#000;background:var(--green);padding:8px 12px;border-radius:999px;font-weight:800;font-size:12px;display:inline-block;margin-top:5px}.expired{padding:18px;background:#321;color:#ffd7a2;border-radius:16px;margin:14px}
.admin-body{background:#eef3f7;color:#111;min-height:100vh}.admin-wrap{display:grid;grid-template-columns:250px 1fr;min-height:100vh}.side{background:#101218;color:#fff;padding:24px}.side h1{color:var(--green);margin:0 0 22px}.side a{display:block;padding:12px;border-radius:12px;margin:7px 0;background:#1b1f2a}.admin-main{padding:24px}.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat{border-radius:18px;padding:18px;color:#111;font-weight:900}.bgw{background:#fff}.bgr{background:#ff5964}.bgg{background:#35e27c}.bgy{background:#ffd166}.bgc{background:#4cc9f0}.bgo{background:#ff9f1c}.panel{background:#fff;border-radius:20px;padding:18px;margin:18px 0;box-shadow:0 10px 30px #d9e0e8}.admin-form{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.admin-form input,.admin-form select{padding:12px;border:1px solid #d6dbe1;border-radius:12px}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid #e5e7eb;text-align:left}.tag{border-radius:999px;padding:5px 10px;font-weight:800;font-size:12px}.green{background:#d6ffe5;color:#057431}.orange{background:#ffe8c2;color:#9c5700}.progress{height:8px;background:#e5e7eb;border-radius:99px;overflow:hidden}.bar{height:100%;background:var(--green);width:0}.danger{background:var(--red);color:#fff}.mini-cover{width:48px;height:48px;object-fit:cover;border-radius:8px}@media(max-width:800px){.admin-wrap{display:block}.side{position:static}.grid,.admin-form{grid-template-columns:1fr}.dashboard-note:before{content:'Dashboard optimizado para computadora';display:block;background:#fff3cd;padding:10px;border-radius:10px;margin-bottom:12px}}
/* AppMusic actualización v2: reproductor con anterior/siguiente y ecualizador canvas */
.player.v2{overflow:hidden;position:fixed;grid-template-columns:44px 1fr 34px 42px 34px;background:linear-gradient(135deg,rgba(82,96,106,.96),rgba(25,25,25,.96));box-shadow:0 12px 34px rgba(0,0,0,.55);border:1px solid rgba(255,255,255,.08)}
.player.v2>*{position:relative;z-index:2}.player.v2 #eqCanvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.72;filter:drop-shadow(0 0 8px rgba(30,215,96,.45))}.player.v2:before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.50),rgba(0,0,0,.12),rgba(0,0,0,.45));z-index:1}.player-info{min-width:0}.player-title,.player-sub{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player.v2 button.transport{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.09);font-size:18px;line-height:1}.player.v2 #playIcon{width:42px;height:42px;background:var(--green);color:#000;font-weight:950;font-size:23px}.track.active{background:linear-gradient(90deg,rgba(30,215,96,.12),transparent);border-radius:10px}.track.active img{box-shadow:0 0 0 2px rgba(30,215,96,.45)}

/* Modern CRUD vibrant redesign */
body{background:radial-gradient(circle at top,#1a1a40 0%,#090909 45%,#000 100%)}
.mobile-only{background:linear-gradient(180deg,#0f1023,#050505);box-shadow:0 0 40px rgba(0,0,0,.5)}
.topbar{background:rgba(10,10,20,.85);border-bottom:1px solid rgba(255,255,255,.08)}
.brand{font-size:24px;background:linear-gradient(90deg,#1ed760,#30d5ff,#ff9f1c);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.formbox{margin:24px 16px;padding:28px;border-radius:28px;background:rgba(15,15,25,.95);border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 60px rgba(0,0,0,.55)}
.formbox h1{font-size:42px;line-height:1.05;margin-bottom:24px;background:linear-gradient(90deg,#fff,#1ed760);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.input{background:#eef2ff;color:#111;border:2px solid transparent;font-size:16px;font-weight:700;transition:.25s}
.input:focus{outline:none;border-color:#30d5ff;box-shadow:0 0 0 4px rgba(48,213,255,.18)}
.plan{position:relative;background:linear-gradient(145deg,#181a2f,#0c0d18);border:1px solid rgba(255,255,255,.1);padding:18px 16px;transition:.25s;overflow:hidden}
.plan:hover{transform:translateY(-2px);border-color:#1ed760;box-shadow:0 12px 28px rgba(30,215,96,.18)}
.plan input{accent-color:#1ed760;transform:scale(1.2)}
.plan b{font-size:28px;color:#fff}
.plan .muted,.plan span{font-size:14px;color:#b9c1d9}
.btn{width:100%;margin-top:18px;padding:18px;font-size:18px;background:linear-gradient(90deg,#1ed760,#30d5ff);color:#001b0a;box-shadow:0 10px 24px rgba(30,215,96,.35);transition:.25s}
.btn:hover{transform:translateY(-2px) scale(1.01)}
.back{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.08)}
@media(max-width:480px){.formbox h1{font-size:34px}.formbox{margin:16px 10px;padding:22px}}
