:root{--sp-green:#1DB954;--sp-green2:#1ed760;--bg:#000;--panel:#121212;--panel2:#181818;--panel3:#242424;--text:#fff;--muted:#b3b3b3;--line:rgba(255,255,255,.08);--player-h:96px;--top-h:72px;--side-w:330px;color-scheme:dark}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{width:100%;min-height:100%;overflow-x:hidden}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);padding-bottom:0}
a{text-decoration:none;color:inherit}
button,input{font:inherit}
button{cursor:pointer}
.sp-shell{height:100vh;display:grid;grid-template-rows:var(--top-h) 1fr var(--player-h);background:#000;overflow:hidden}
.sp-top{height:var(--top-h);display:flex;align-items:center;gap:12px;padding:8px 14px;background:#000}
.sp-logo{width:44px;height:44px;border-radius:50%;background:#fff;color:#000;display:grid;place-items:center;font-size:25px;flex:0 0 auto}
.sp-logo img{width:100%;height:100%;object-fit:contain;padding:6px;display:block}
.sp-home{width:48px;height:48px;border:0;border-radius:50%;background:#1f1f1f;color:#fff;font-size:20px;display:grid;place-items:center}
.sp-search{height:50px;max-width:560px;flex:1;display:flex;align-items:center;gap:12px;background:#242424;border:1px solid transparent;border-radius:999px;padding:0 16px;color:#b3b3b3}
.sp-search:focus-within{border-color:#555;background:#2a2a2a}
.sp-search input{width:100%;border:0;outline:0;background:transparent;color:#fff;font-size:15px}
.sp-top-links{margin-left:auto;display:flex;align-items:center;gap:22px;color:#b3b3b3;font-weight:800;font-size:14px;white-space:nowrap}
.sp-top-links a:hover{color:#fff}
.sp-vline{width:1px;height:28px;background:#777}
.sp-login{border:0;border-radius:999px;background:#fff;color:#000;font-weight:900;padding:14px 27px}
.sp-signup{color:#b3b3b3;font-weight:900}
.sp-menu{display:none;width:44px;height:44px;border:0;border-radius:50%;background:#1f1f1f;color:#fff}
.sp-workspace{display:grid;grid-template-columns:var(--side-w) minmax(0,1fr);gap:8px;padding:0 8px 8px;min-height:0}
.sp-library{background:var(--panel);border-radius:8px;min-height:0;overflow:auto;padding:18px 14px 120px}
.sp-library-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:4px 8px 18px}
.sp-library-title strong{font-size:17px}
.sp-create{border:0;border-radius:999px;background:#1f1f1f;color:#fff;padding:9px 14px;font-weight:900}
.sp-side-nav{display:grid;gap:4px;margin-bottom:18px}
.sp-side-nav a{height:52px;display:flex;align-items:center;gap:14px;padding:0 14px;border-radius:10px;color:#b3b3b3;font-weight:900}
.sp-side-nav a:hover,.sp-side-nav a.active{background:rgba(255,255,255,.1);color:#fff}
.sp-lib-box{background:#242424;border-radius:12px;padding:18px 16px;margin-bottom:12px}
.sp-lib-box h3{font-size:15px;margin-bottom:9px}
.sp-lib-box p{font-size:13px;line-height:1.45;color:#ddd;font-weight:700;margin-bottom:16px}
.sp-white-pill{display:inline-flex;background:#fff;color:#000;border-radius:999px;padding:10px 17px;font-weight:900;font-size:13px}
.sp-legal{display:flex;flex-wrap:wrap;gap:12px 16px;margin:24px 10px;color:#b3b3b3;font-size:11px}
.sp-lang{display:inline-flex;align-items:center;gap:8px;margin:8px 10px;border:1px solid #777;border-radius:999px;padding:8px 13px;font-weight:900;font-size:12px}
.sp-main{background:linear-gradient(#1a1a1a,#121212 46%);border-radius:8px;min-width:0;min-height:0;overflow:auto;position:relative}
.sp-page{padding:24px 46px 150px;background:linear-gradient(180deg,rgba(29,185,84,.16),transparent 240px)}
.sp-hero{min-height:330px;padding:38px 46px 28px;display:flex;align-items:flex-end;background:linear-gradient(90deg,rgba(0,0,0,.93),rgba(0,0,0,.65) 45%,rgba(0,0,0,.22)),var(--hero-image,linear-gradient(135deg,#242424,#111));background-size:cover;background-position:center;position:relative}
.sp-hero:after{content:"";position:absolute;inset:auto 0 0;height:150px;background:linear-gradient(transparent,#121212)}
.sp-hero-content{position:relative;z-index:1;max-width:900px}
.sp-badge,.welcome-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:900;margin-bottom:12px;color:#fff}
.sp-badge i,.welcome-label i{color:var(--sp-green)}
.sp-hero h1{font-size:clamp(46px,7vw,96px);line-height:.88;font-weight:900;margin-bottom:18px;text-shadow:0 18px 50px rgba(0,0,0,.55)}
.sp-hero p{color:#ddd;font-size:15px;line-height:1.55;font-weight:650;max-width:760px}
.sp-actions{height:84px;display:flex;align-items:center;gap:20px}
.sp-play-big{width:66px;height:66px;border:0;border-radius:50%;background:var(--sp-green);color:#000;display:grid;place-items:center;font-size:25px;box-shadow:0 18px 42px rgba(29,185,84,.28)}
.sp-section{margin-top:28px}
.sp-section-head,.section-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}
.sp-section-head h2,.section-header h2{font-size:23px;font-weight:900}
.section-header a{color:#b3b3b3;font-weight:900;font-size:13px}
.sp-card-grid,.rec-grid,.album-grid,.artist-directory,.collection-grid,.plans-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.song-card,.album-card,.artist-tile,.plan-card,.playlist-card{background:#181818;border:1px solid transparent;border-radius:10px;padding:14px;position:relative;transition:.18s;color:#fff;overflow:hidden;box-shadow:none}
.song-card:hover,.album-card:hover,.artist-tile:hover,.plan-card:hover,.playlist-card:hover{background:#282828;transform:none;border-color:transparent}
.song-cover,.album-card img,.artist-tile img,.playlist-cover{width:100%;aspect-ratio:1/1;border-radius:7px;object-fit:cover;margin-bottom:12px;background:#333;display:block;height:auto}
.song-cover{position:relative;overflow:hidden}
.song-cover img{width:100%;height:100%;object-fit:cover;display:block}
.song-title,.album-info strong,.artist-tile strong,.plan-name{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:15px;font-weight:850}
.song-artist,.song-stats,.album-info span,.artist-tile span,.plan-cycle,.features,.note{display:block;color:#b3b3b3;font-size:13px;line-height:1.4;margin-top:7px;font-weight:700}
.play-overlay{position:absolute;right:12px;bottom:12px;opacity:0;transform:translateY(8px);transition:.18s;color:#000;font-size:44px}
.song-card:hover .play-overlay{opacity:1;transform:translateY(0)}
.play-overlay i{background:var(--sp-green);border-radius:50%;box-shadow:0 10px 24px rgba(0,0,0,.45)}
.empty-state,.empty-search{padding:26px;text-align:center;color:#b3b3b3;font-weight:800;background:rgba(18,18,18,.6);border:1px solid var(--line);border-radius:14px}
.mood-row,.tabs,.method-row{display:flex;gap:10px;overflow-x:auto;padding:4px 0 14px;margin-bottom:16px}
.mood-chip,.tab,.method,.soft-btn{flex:0 0 auto;border:1px solid #555;background:#242424;color:#fff;border-radius:999px;padding:10px 16px;font-weight:900}
.mood-chip.active,.tab.active,.primary-btn{background:var(--sp-green);color:#000;border-color:transparent}
.primary-btn,.soft-btn{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}
.plan-price{font-size:34px;font-weight:900;margin:8px 0}
.features{display:grid;gap:9px;margin:14px 0 20px}
.features span{display:flex;gap:9px}
.features i,.method.ready{color:var(--sp-green)}
.actions{margin-top:auto;display:grid;gap:10px}
.alert{border-radius:12px;padding:13px 15px;margin-bottom:16px;font-weight:800;font-size:14px;border:1px solid var(--line)}
.alert.success{background:rgba(29,185,84,.12);color:#9cf3ba}
.alert.error{background:rgba(239,68,68,.12);color:#fca5a5}
.mini-player{height:var(--player-h)!important;position:static!important;display:grid!important;grid-template-columns:320px 42px minmax(220px,1fr) 42px 190px 190px 44px!important;align-items:center!important;gap:12px!important;padding:12px 18px!important;background:#000!important;border-top:1px solid #222!important;border-radius:0!important;box-shadow:none!important;transform:none!important;opacity:1!important;visibility:visible!important;z-index:3000!important;max-width:none!important;width:auto!important}
.player-art-button{width:58px!important;height:58px!important;border-radius:5px!important;overflow:hidden;grid-column:auto!important}
.mini-player-info{min-width:0;max-width:none!important}
.mini-player-title{font-size:14px!important;color:#fff!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-player-artist,.mini-player-kicker,.player-time{color:#b3b3b3!important;font-size:12px!important}
.player-main-btn{background:#fff!important;color:#000!important;box-shadow:none!important}
.player-icon-btn{background:transparent!important;border:0!important;color:#b3b3b3!important}
.player-seek,.volume-bar{accent-color:var(--sp-green)}
.bottom-nav{display:none!important}
.sp-mobile-overlay{display:none}
@media(max-width:1200px){:root{--side-w:280px}.sp-card-grid,.rec-grid,.album-grid,.artist-directory,.collection-grid,.plans-grid{grid-template-columns:repeat(3,1fr)}.sp-top-links a:nth-child(-n+3),.sp-vline{display:none}.sp-page{padding-left:34px;padding-right:34px}.mini-player{grid-template-columns:240px 38px minmax(180px,1fr) 38px 150px 120px 40px!important}}
@media(max-width:860px){.sp-shell{grid-template-rows:64px 1fr 148px;--player-h:148px}.sp-menu{display:grid}.sp-top{height:64px;padding:8px}.sp-logo,.sp-home{width:42px;height:42px}.sp-search{height:44px}.sp-top-links{display:none}.sp-workspace{display:block;padding:0}.sp-library{position:fixed;left:0;top:0;bottom:0;width:min(320px,88vw);border-radius:0;z-index:2500;transform:translateX(-105%);transition:.25s;padding-top:78px}.sp-library.open{transform:translateX(0)}.sp-mobile-overlay.active{display:block;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:2400}.sp-main{border-radius:0}.sp-hero{min-height:310px;padding:32px 22px 24px}.sp-hero h1{font-size:clamp(40px,13vw,64px)}.sp-page{padding:18px 14px 165px}.sp-card-grid,.rec-grid,.album-grid,.artist-directory,.collection-grid,.plans-grid{grid-template-columns:repeat(2,1fr);gap:12px}.mini-player{height:148px!important;grid-template-columns:58px minmax(0,1fr) 44px!important;grid-template-rows:auto auto!important;gap:8px!important;padding:10px 12px!important}.player-art-button{width:48px!important;height:48px!important}.player-seek-wrap{grid-column:1/4!important;position:static!important;min-width:0}.desktop-player-only,.player-volume,.player-social-actions,.close-player{display:none!important}.mini-player-controls{display:contents}.player-main-btn{width:42px!important;height:42px!important}.mini-player-kicker{display:none}}
@media(max-width:520px){.sp-search input{font-size:13px}.sp-logo{display:none}.sp-top{gap:8px}.sp-page{padding-left:10px;padding-right:10px}.sp-card-grid,.rec-grid,.album-grid,.artist-directory,.collection-grid,.plans-grid{grid-template-columns:1fr 1fr}.song-card,.album-card,.artist-tile,.plan-card{padding:10px}.sp-section-head h2,.section-header h2{font-size:20px}}
