:root{--bg:#0a0a0a;--s1:#141414;--s2:#1e1e1e;--s3:#2a2a2a;--red:#e50914;--rh:#ff1a25;--txt:#fff;--dim:#aaa;--mut:#666;--brd:#333;--ok:#4caf50;--sb:240px}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--txt);min-height:100vh}
.hidden{display:none!important}
a{color:inherit;text-decoration:none}
/* LOGIN */
.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a0000)}
.login-card{background:var(--s1);border:1px solid var(--brd);border-radius:16px;padding:40px;width:400px;text-align:center}
.brand{font-size:42px;font-weight:800;color:var(--red);text-shadow:0 0 30px rgba(229,9,20,.5)}
.login-card .sub{color:var(--dim);margin-bottom:24px;font-size:14px}
.login-card input,.inp{width:100%;padding:12px;margin-bottom:12px;background:var(--s2);border:1px solid var(--brd);border-radius:8px;color:var(--txt);font-size:14px;outline:none}
.login-card input:focus,.inp:focus{border-color:var(--red)}
.btn-red{width:100%;padding:12px;background:var(--red);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer}
.btn-red:hover{background:var(--rh)}
.btn-red:disabled{opacity:.5;cursor:not-allowed}
.err{color:var(--red);font-size:13px;min-height:18px;margin:8px 0}
.or{display:flex;align-items:center;gap:10px;margin:16px 0}.or::before,.or::after{content:'';flex:1;height:1px;background:var(--brd)}.or span{font-size:12px;color:var(--mut)}
.social-row{display:flex;gap:10px;margin-bottom:10px}
.social-btn{flex:1;padding:10px;background:var(--s2);border:1px solid var(--brd);border-radius:8px;color:var(--txt);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}
.social-btn:hover{border-color:var(--dim);background:var(--s3)}
.social-btn:disabled{opacity:.5;cursor:not-allowed}
.social-btn:disabled:hover{border-color:var(--brd);background:var(--s2)}
.social-btn svg{flex-shrink:0}
.login-card{max-height:90vh;overflow-y:auto}
.login-card select.inp{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%23aaa' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.role-btn.active{border-color:var(--red)!important;background:rgba(229,9,20,.15)!important;color:var(--red)!important;font-weight:600}
.w100{width:100%}
.center-text{text-align:center;font-size:22px;letter-spacing:6px;font-weight:700}
/* APP SHELL */
.app{display:flex;min-height:100vh}
/* SIDEBAR */
.sidebar{width:var(--sb);background:var(--s1);border-right:1px solid var(--brd);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:100}
.sb-brand{padding:20px 16px 12px;border-bottom:1px solid var(--brd);display:flex;align-items:center;justify-content:space-between}
.sb-brand h2{font-size:22px;font-weight:800;color:var(--red)}
.mode-pill{background:var(--red);color:#fff;border:none;padding:3px 10px;border-radius:10px;font-size:10px;font-weight:600;cursor:pointer;text-transform:uppercase}
.sb-nav{flex:1;overflow-y:auto;padding:8px 0}
.sb-nav a{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--dim);font-size:13px;border-left:3px solid transparent;transition:.2s}
.sb-nav a:hover{background:var(--s2);color:var(--txt)}
.sb-nav a.active{background:rgba(229,9,20,.1);color:var(--red);border-left-color:var(--red)}
.sb-nav a .icon{font-size:16px;width:22px;text-align:center}
.sb-footer{padding:12px 16px;border-top:1px solid var(--brd);display:flex;align-items:center;gap:10px}
.sb-avatar,.sb-avatar-fb{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}
.sb-avatar-fb{background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:16px}
.sb-user{flex:1;min-width:0;display:flex;flex-direction:column}.sb-user span{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* MAIN */
.main{flex:1;margin-left:var(--sb);display:flex;flex-direction:column;min-height:100vh;padding-bottom:130px}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;border-bottom:1px solid var(--brd);position:sticky;top:0;background:var(--bg);z-index:50}
.topbar h2{font-size:18px;font-weight:600}
.tb-left{display:flex;align-items:center;gap:12px}
.tb-right{display:flex;align-items:center;gap:12px}
.back-btn{font-size:22px;padding:4px 8px;border-radius:8px;transition:all .2s}
.back-btn:hover{background:var(--s2);color:var(--red)}
.tb-avatar,.tb-avatar-fb{width:32px;height:32px;border-radius:50%;object-fit:cover;cursor:pointer;border:2px solid var(--red)}
.tb-avatar-fb{background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:16px}
.ic-btn{background:none;border:none;color:var(--txt);font-size:18px;cursor:pointer;padding:4px;position:relative}
.ic-btn:hover{color:var(--red)}
.n-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:#fff;font-size:9px;padding:1px 5px;border-radius:8px;font-weight:700}
.credit-pill{background:var(--s2);border:1px solid var(--brd);padding:4px 12px;border-radius:16px;font-size:12px;cursor:pointer}
.credit-pill:hover{border-color:var(--red)}
.page-area{flex:1;padding:20px 24px;overflow-y:auto}
.dim{color:var(--dim)}.mut{color:var(--mut)}
/* MINI PLAYER */
.mplayer{position:fixed;bottom:60px;left:var(--sb);right:0;background:var(--s1);border-top:1px solid var(--brd);display:flex;align-items:center;gap:10px;padding:8px 16px;z-index:90}
.mp-art{width:44px;height:44px;border-radius:6px;object-fit:cover;background:var(--s3);flex-shrink:0}
.mp-info{flex:1;min-width:0}.mp-info div{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mp-playbtn{font-size:22px}
.mp-seek{width:100px;accent-color:var(--red)}
/* BOTTOM NAV */
.bnav{position:fixed;bottom:0;left:var(--sb);right:0;background:var(--s1);border-top:1px solid var(--brd);display:flex;z-index:95;padding:4px 0}
.bn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;font-size:18px;color:var(--dim);transition:.2s}
.bn span{font-size:10px}
.bn.active,.bn:hover{color:var(--red)}
/* FULL PLAYER */
.fplayer{position:fixed;inset:0;background:var(--bg);z-index:200;display:flex;flex-direction:column;align-items:center;padding:20px;overflow-y:auto}
.fp-top{display:flex;width:100%;justify-content:space-between;align-items:center;margin-bottom:20px}
.fp-art{width:280px;height:280px;border-radius:16px;object-fit:cover;background:var(--s2);margin-bottom:20px}
.fp-title{font-size:22px;font-weight:700;margin-bottom:4px;text-align:center}
.fp-artist{font-size:14px;margin-bottom:20px;text-align:center}
.fp-seek{display:flex;align-items:center;gap:10px;width:100%;max-width:400px;margin-bottom:16px}
.fp-seekbar{flex:1;accent-color:var(--red)}
.fp-ctrls{display:flex;align-items:center;gap:20px}
.fp-ctrls .ic-btn{font-size:22px}
.fp-playmain{font-size:36px;background:var(--red);border-radius:50%;width:56px;height:56px;display:flex;align-items:center;justify-content:center}
.fp-queue{width:100%;max-width:400px;margin-top:20px;border-top:1px solid var(--brd);padding-top:16px}
.fp-queue h3{margin-bottom:12px;font-size:16px}
.fp-q-item{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer}.fp-q-item:hover{background:var(--s2)}
.fp-q-art{width:36px;height:36px;border-radius:4px;object-fit:cover;background:var(--s3)}
.fp-q-info{flex:1;min-width:0}.fp-q-info div{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* NOTIFICATION PANEL */
.npanel{position:fixed;top:0;right:0;width:360px;height:100vh;background:var(--s1);border-left:1px solid var(--brd);z-index:150;display:flex;flex-direction:column;overflow-y:auto}
.np-head{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--brd)}
.n-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--brd);cursor:pointer;font-size:13px}.n-item:hover{background:var(--s2)}
.n-item.unread{border-left:3px solid var(--red)}
/* TOASTS */
.toasts{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:8px;font-size:13px;animation:slideIn .3s,fadeOut .3s 3.5s forwards;max-width:340px}
.toast.ok{background:var(--ok);color:#fff}.toast.err{background:var(--red);color:#fff}.toast.info{background:var(--s2);border:1px solid var(--brd)}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes fadeOut{from{opacity:1}to{opacity:0}}
/* PAGE STYLES */
.card{background:var(--s1);border:1px solid var(--brd);border-radius:12px;overflow:hidden}
.card:hover{border-color:var(--dim)}
/* FEED */
.feed-card{margin-bottom:16px}
.feed-header{display:flex;align-items:center;gap:10px;padding:12px}
.avatar-container,.feed-avatar-container{position:relative;cursor:pointer}
.feed-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--s3);border:2px solid var(--brd)}
.feed-avatar-fallback{width:40px;height:40px;border-radius:50%;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid var(--brd)}
.feed-user-info{flex:1}
.feed-user{font-weight:600;font-size:14px;cursor:pointer}.feed-user:hover{color:var(--red)}
.feed-time{font-size:11px;color:var(--mut)}
/* Media containers */
.media-container{position:relative;background:#000;min-height:200px;display:flex;align-items:center;justify-content:center}
.feed-media{width:100%;max-height:600px;object-fit:contain;background:#000}
.feed-media-vid{width:100%;max-height:600px;background:#000}
.img-error{color:var(--dim);font-size:12px;padding:40px}
/* Music card */
.music-card-player{display:flex;align-items:center;gap:12px;padding:12px;background:var(--s2);cursor:pointer}
.music-card-player:hover{background:var(--s3)}
.music-art-container{position:relative;width:60px;height:60px;flex-shrink:0}
.music-art{width:60px;height:60px;border-radius:8px;object-fit:cover;background:var(--s3)}
.music-art-fallback{width:60px;height:60px;border-radius:8px;background:linear-gradient(135deg,var(--red),#ff6b6b);display:flex;align-items:center;justify-content:center;font-size:28px}
.music-info{flex:1;min-width:0}
.music-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-artist{font-size:12px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.music-play{font-size:24px;color:var(--red)}
.music-price{font-size:12px;color:var(--ok);background:var(--s1);padding:4px 8px;border-radius:12px}
/* Feed actions */
.feed-actions{display:flex;gap:8px;padding:12px;flex-wrap:wrap}
.action-btn{background:none;border:1px solid var(--brd);color:var(--txt);cursor:pointer;font-size:13px;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;transition:all .2s}
.action-btn:hover{border-color:var(--red);color:var(--red)}
.like-btn[data-liked="true"]{border-color:var(--red);color:var(--red)}
.feed-caption{padding:0 12px 12px;font-size:13px;line-height:1.5}
/* Comment Modal */
.comment-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:flex-end;justify-content:center}
.comment-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.7)}
.comment-modal-content{position:relative;width:100%;max-width:500px;max-height:80vh;background:var(--s1);border-radius:16px 16px 0 0;display:flex;flex-direction:column;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.comment-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--brd)}
.comment-modal-header h3{margin:0;font-size:16px}
.comment-close-btn{background:none;border:none;color:var(--txt);font-size:20px;cursor:pointer}
.comment-list{flex:1;overflow-y:auto;padding:8px 0;min-height:200px;max-height:50vh}
.comment-item{display:flex;gap:10px;padding:12px 16px}
.comment-item:hover{background:var(--s2)}
.comment-avatar-container{flex-shrink:0}
.comment-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--s3)}
.comment-avatar-fallback{width:32px;height:32px;border-radius:50%;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:14px}
.comment-body{flex:1;min-width:0}
.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.comment-username{font-weight:600;font-size:13px;cursor:pointer}.comment-username:hover{color:var(--red)}
.comment-time{font-size:11px;color:var(--mut)}
.comment-delete{background:none;border:none;cursor:pointer;font-size:12px;opacity:0.5;margin-left:auto}.comment-delete:hover{opacity:1}
.comment-text{font-size:14px;line-height:1.4;word-break:break-word}
.comment-input-area{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--brd);background:var(--s2)}
.comment-input{flex:1;padding:10px 14px;background:var(--s1);border:1px solid var(--brd);border-radius:20px;color:var(--txt);font-size:14px;outline:none}
.comment-input:focus{border-color:var(--red)}
.comment-send-btn{padding:10px 20px;background:var(--red);color:#fff;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer}
.comment-send-btn:hover{background:var(--rh)}
/* Ad placeholder */
.ad-placeholder{min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--dim);gap:8px}
.ad-placeholder span{font-size:32px}
/* GRID */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}
.grid-card{cursor:pointer}.grid-card .g-img{width:100%;aspect-ratio:1;object-fit:cover;background:var(--s3)}
.grid-card .g-info{padding:10px}.grid-card .g-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.grid-card .g-sub{font-size:11px;color:var(--dim)}.grid-card .g-price{font-size:13px;color:var(--ok);font-weight:600;margin-top:4px}
/* GENRE CARDS */
.genre-card .genre-card-inner{padding:24px 16px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}
.genre-card .genre-icon{font-size:28px;margin-bottom:4px}
.genre-card .genre-name{font-size:15px;font-weight:600;color:#fff}
.genre-card .genre-count{font-size:12px;transition:color .2s}
.genre-card:hover{border-color:#E50914;transform:translateY(-2px);transition:all .2s}
.genre-card:hover .genre-icon{transform:scale(1.15);transition:transform .2s}
/* TABS */
.tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--s1);border-radius:8px;padding:4px;border:1px solid var(--brd)}
.tab{flex:1;padding:8px;background:none;border:none;color:var(--dim);cursor:pointer;border-radius:6px;font-size:13px;text-align:center}
.tab:hover{background:var(--s2)}.tab.active{background:var(--red);color:#fff}
/* SEARCH */
.search-bar{display:flex;gap:8px;margin-bottom:20px}
.search-bar input{flex:1;padding:10px 16px;background:var(--s2);border:1px solid var(--brd);border-radius:8px;color:var(--txt);font-size:14px;outline:none}
.search-bar input:focus{border-color:var(--red)}
/* MESSAGES */
.msg-list{display:flex;flex-direction:column}
.msg-item{display:flex;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--brd);cursor:pointer}.msg-item:hover{background:var(--s2)}
.msg-avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;background:var(--s3);flex-shrink:0}
.msg-info{flex:1;min-width:0}.msg-name{font-weight:600;font-size:14px}.msg-last{font-size:12px;color:var(--dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msg-time{font-size:10px;color:var(--mut)}
.chat-area{display:flex;flex-direction:column;height:calc(100vh - 200px)}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:8px}
.chat-bubble{max-width:70%;padding:10px 14px;border-radius:16px;font-size:13px;line-height:1.4}
.chat-mine{background:var(--red);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-theirs{background:var(--s2);align-self:flex-start;border-bottom-left-radius:4px}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--brd)}
.chat-input input{flex:1;padding:10px;background:var(--s2);border:1px solid var(--brd);border-radius:20px;color:var(--txt);outline:none}
.chat-input button{padding:10px 20px;background:var(--red);border:none;color:#fff;border-radius:20px;cursor:pointer}
/* CONTRIBUTOR MANAGER */
.contrib-manager{background:var(--s2);border:1px solid var(--brd);border-radius:8px;padding:12px}
.contrib-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600;font-size:14px}
.contrib-list{margin-bottom:12px}
.contrib-item{display:flex;align-items:center;gap:10px;padding:8px;background:var(--s1);border-radius:8px;margin-bottom:6px}
.contrib-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}
.contrib-avatar img{width:100%;height:100%;object-fit:cover}
.contrib-avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:16px}
.contrib-info{flex:1;min-width:0}
.contrib-name{font-size:13px;font-weight:600;display:flex;align-items:center;gap:4px}
.contrib-verified{color:var(--ok);font-size:11px}
.contrib-detail{font-size:11px;color:var(--dim)}
.contrib-split{display:flex;align-items:center;gap:2px;font-size:12px}
.contrib-split input{width:50px;padding:4px 6px;background:var(--s2);border:1px solid var(--brd);border-radius:4px;color:var(--txt);text-align:center}
.contrib-remove{background:none;border:none;color:var(--dim);cursor:pointer;font-size:14px;padding:4px 8px}.contrib-remove:hover{color:var(--red)}
.contrib-add{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.contrib-search-container{position:relative;flex:1;min-width:150px}
.contrib-search-container input{width:100%;padding:8px 12px;background:var(--s1);border:1px solid var(--brd);border-radius:6px;color:var(--txt);font-size:13px}
.contrib-search-results{position:absolute;top:100%;left:0;right:0;background:var(--s1);border:1px solid var(--brd);border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,0.3);z-index:100;max-height:200px;overflow-y:auto;display:none}
.contrib-search-results.active{display:block}
.search-result{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background .2s}
.search-result:hover{background:var(--s2)}
.result-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;background:var(--s3);display:flex;align-items:center;justify-content:center}
.result-avatar img{width:100%;height:100%;object-fit:cover}
.result-icon{font-size:20px;width:32px;text-align:center}
.result-info{flex:1}
.result-name{font-size:13px;font-weight:600}
.result-detail{font-size:11px;color:var(--dim)}
.search-loading,.search-no-results{padding:16px;text-align:center;color:var(--dim);font-size:12px}
.email-result{background:var(--s2);border-radius:6px;margin:6px}
/* PROFILE */
.prof-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}
.prof-pic{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid var(--red);background:var(--s3)}
.prof-pic-fb{width:80px;height:80px;border-radius:50%;background:var(--s3);display:flex;align-items:center;justify-content:center;font-size:40px;border:3px solid var(--red)}
.prof-pic-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;background:var(--red);border:2px solid var(--bg);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer}
.prof-pic-edit:hover{background:var(--rh)}
.prof-name{font-size:22px;font-weight:700}.prof-handle{font-size:13px;color:var(--dim)}
.prof-stats{display:flex;gap:24px;margin-top:8px}.prof-stat{text-align:center}.prof-stat b{display:block;font-size:18px;color:var(--red)}.prof-stat span{font-size:11px;color:var(--dim)}
.prof-bio{font-size:13px;color:var(--dim);margin-top:8px;line-height:1.5}
.prof-actions{display:flex;gap:8px;margin-top:12px}
.btn-follow{padding:8px 24px;background:var(--red);color:#fff;border:none;border-radius:20px;font-size:13px;cursor:pointer}
.btn-follow.following{background:var(--s2);border:1px solid var(--brd);color:var(--dim)}
.btn-msg{padding:8px 24px;background:var(--s2);border:1px solid var(--brd);color:var(--txt);border-radius:20px;font-size:13px;cursor:pointer}
/* WALLET */
.wallet-bal{background:linear-gradient(135deg,var(--red),#ff4444);border-radius:16px;padding:32px;text-align:center;margin-bottom:24px}
.wallet-bal h3{font-size:14px;opacity:.8;margin-bottom:8px}.wallet-bal .big{font-size:48px;font-weight:800}
.wallet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:24px}
.wallet-opt{background:var(--s1);border:1px solid var(--brd);border-radius:12px;padding:16px;text-align:center;cursor:pointer}.wallet-opt:hover{border-color:var(--red)}
.wallet-opt .w-amt{font-size:20px;font-weight:700;color:var(--red)}.wallet-opt .w-price{font-size:12px;color:var(--dim);margin-top:4px}
/* LIVE */
.live-card{border:2px solid var(--red);position:relative}.live-badge{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700}
.live-viewers{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px}
.live-video{width:100%;aspect-ratio:16/9;background:#000;border-radius:8px}
.live-chat{height:300px;overflow-y:auto;background:var(--s2);border-radius:8px;padding:12px;margin-top:12px}
.live-chat-msg{padding:4px 0;font-size:13px}.live-chat-msg b{color:var(--red)}
/* CREATOR FORMS */
.form-card{background:var(--s1);border:1px solid var(--brd);border-radius:12px;padding:24px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.form-group label{font-size:12px;color:var(--dim)}
.form-group input,.form-group select,.form-group textarea{padding:10px;background:var(--s2);border:1px solid var(--brd);border-radius:8px;color:var(--txt);font-size:13px;outline:none;font-family:inherit}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red)}
.btn-primary{padding:10px 24px;background:var(--red);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer}
.btn-primary:hover{background:var(--rh)}.btn-primary:disabled{opacity:.5}
.btn-secondary{padding:8px 16px;background:none;color:var(--red);border:1px solid var(--red);border-radius:8px;font-size:12px;cursor:pointer}
.progress{height:20px;background:var(--s2);border-radius:10px;overflow:hidden;position:relative}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--red),#ff4444);border-radius:10px;transition:width .3s}
.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;font-weight:700}
/* SECTION */
.section-title{font-size:18px;font-weight:600;margin-bottom:16px}
/* ALBUM CARDS */
.album-card{cursor:pointer;position:relative;transition:transform .2s}
.album-card:hover{transform:translateY(-4px)}
.album-badge{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;z-index:1}
.album-art-fallback{display:flex;align-items:center;justify-content:center;font-size:64px;background:linear-gradient(135deg,var(--s2),var(--s3))}
.g-meta{font-size:11px;color:var(--dim);margin:4px 0}
/* ALBUM DETAIL */
.album-detail-header{display:flex;gap:24px;margin-bottom:24px;flex-wrap:wrap}
.album-detail-art{width:200px;height:200px;border-radius:12px;overflow:hidden;flex-shrink:0;background:var(--s2)}
.album-detail-art img{width:100%;height:100%;object-fit:cover}
.album-art-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:80px;background:linear-gradient(135deg,var(--s2),var(--s3))}
.album-detail-info{flex:1;min-width:200px}
.album-type-badge{display:inline-block;background:var(--red);color:#fff;padding:4px 12px;border-radius:4px;font-size:11px;font-weight:600;margin-bottom:8px}
.album-detail-info h1{font-size:28px;margin:0 0 8px}
.album-artist{font-size:16px;color:var(--txt);margin:0 0 4px}
.album-meta{font-size:13px;color:var(--dim);margin:0 0 12px}
.album-price{font-size:24px;font-weight:700;color:var(--ok);margin-bottom:12px}
.album-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.album-desc{font-size:13px;color:var(--dim);line-height:1.5;margin-top:12px}
/* ALBUM TRACKLIST */
.album-tracklist{background:var(--s1);border:1px solid var(--brd);border-radius:12px;padding:16px}
.album-tracklist h3{margin:0 0 12px;font-size:16px}
.album-track-item{display:flex;align-items:center;gap:12px;padding:10px 8px;border-radius:8px;transition:background .2s}
.album-track-item:hover{background:var(--s2)}
.track-num{width:24px;text-align:center;font-size:14px;color:var(--dim);font-weight:600}
.track-info{flex:1;min-width:0}
.track-title{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.track-artist{font-size:11px;color:var(--dim)}
.track-price{font-size:12px;color:var(--ok);margin-right:8px}
.track-actions{display:flex;gap:4px}
.track-actions button{background:var(--s3);border:none;color:var(--txt);width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:12px;transition:all .2s}
.track-actions button:hover{background:var(--red);color:#fff}
/* ADS */
.ad-card{border:1px dashed var(--brd)!important}
.ad-container{text-align:center;margin:12px 0;min-height:50px;background:var(--s2);border-radius:8px}
#sticky-banner-ad{background:var(--bg);border-top:1px solid var(--brd)}
#interstitial-ad .adsbygoogle{background:var(--s3)}

/* ENHANCED SOCIAL SHARING */
.share-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.9);
    z-index: 300;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: fadeInBg 0.2s ease;
}

@keyframes fadeInBg {
    from { opacity: 0; }
    to { opacity: 1; }
}

.share-modal {
    background: var(--s1);
    border: 1px solid var(--brd);
    border-radius: 20px;
    width: 100%;
    max-width: 420px;
    animation: slideUpModal 0.3s ease;
    overflow: hidden;
}

@keyframes slideUpModal {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.share-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--brd);
}

.share-modal-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}

.share-modal-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    color: var(--dim);
    padding: 4px;
    line-height: 1;
}

.share-modal-close:hover {
    color: var(--txt);
}

.share-preview {
    display: flex;
    gap: 16px;
    padding: 20px;
    background: var(--s2);
}

.share-preview-art {
    width: 80px;
    height: 80px;
    border-radius: 12px;
    object-fit: cover;
    background: var(--s3);
    flex-shrink: 0;
}

.share-preview-art-fallback {
    width: 80px;
    height: 80px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--red), #ff6b6b);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
}

.share-preview-info {
    flex: 1;
    min-width: 0;
}

.share-preview-title {
    font-weight: 700;
    font-size: 16px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}

.share-preview-artist {
    color: var(--dim);
    font-size: 14px;
    margin-bottom: 8px;
}

.share-duration-hint {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(229, 9, 20, 0.15);
    color: var(--red);
    font-size: 11px;
    padding: 4px 10px;
    border-radius: 12px;
}

/* Clip Selector for Stories */
.share-clip-section {
    padding: 16px 20px;
    border-bottom: 1px solid var(--brd);
}

.share-clip-label {
    font-size: 12px;
    color: var(--dim);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.share-clip-slider {
    width: 100%;
    height: 40px;
    background: var(--s2);
    border-radius: 8px;
    position: relative;
    margin-bottom: 8px;
}

.share-clip-waveform {
    height: 100%;
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 8px;
}

.share-clip-bar {
    flex: 1;
    background: var(--brd);
    min-width: 2px;
    border-radius: 1px;
    transition: background 0.2s;
}

.share-clip-bar.active {
    background: var(--red);
}

.share-clip-range {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    color: var(--dim);
}

/* Social Platform Grid */
.share-platforms {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    padding: 20px;
}

.share-platform-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 8px;
    border: none;
    border-radius: 16px;
    cursor: pointer;
    transition: all 0.2s;
}

.share-platform-btn:hover {
    transform: translateY(-2px);
}

.share-platform-btn:active {
    transform: scale(0.95);
}

.share-platform-btn.instagram {
    background: linear-gradient(45deg, #833AB4, #FD1D1D, #F77737);
}

.share-platform-btn.facebook {
    background: #1877F2;
}

.share-platform-btn.twitter {
    background: #000;
}

.share-platform-btn.whatsapp {
    background: #25D366;
}

.share-platform-btn.tiktok {
    background: linear-gradient(135deg, #00f2ea, #ff0050);
}

.share-platform-btn.snapchat {
    background: #FFFC00;
}

.share-platform-btn.youtube {
    background: #FF0000;
}

.share-platform-btn.spotify {
    background: #1DB954;
}

.share-platform-icon {
    font-size: 28px;
    margin-bottom: 6px;
}

.share-platform-name {
    font-size: 10px;
    font-weight: 600;
    color: white;
    text-transform: uppercase;
}

.share-platform-btn.snapchat .share-platform-name {
    color: #000;
}

/* Copy Link Section */
.share-link-section {
    padding: 0 20px 20px;
}

.share-link-row {
    display: flex;
    gap: 8px;
}

.share-link-input {
    flex: 1;
    background: var(--s2);
    border: 1px solid var(--brd);
    border-radius: 12px;
    padding: 12px 16px;
    color: var(--txt);
    font-size: 13px;
    outline: none;
}

.share-link-input:focus {
    border-color: var(--red);
}

.share-copy-btn {
    background: var(--red);
    color: white;
    border: none;
    border-radius: 12px;
    padding: 12px 20px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all 0.2s;
}

.share-copy-btn:hover {
    background: var(--rh);
}

.share-copy-btn.copied {
    background: var(--ok);
}

.share-more-btn {
    width: 100%;
    background: none;
    border: 1px solid var(--brd);
    border-radius: 12px;
    padding: 12px;
    color: var(--dim);
    font-size: 13px;
    cursor: pointer;
    margin-top: 12px;
    transition: all 0.2s;
}

.share-more-btn:hover {
    border-color: var(--red);
    color: var(--red);
}

/* ENHANCED QUEUE MANAGEMENT */
.queue-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 400px;
    max-width: 100%;
    height: 100vh;
    background: var(--s1);
    border-left: 1px solid var(--brd);
    z-index: 250;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform 0.3s ease;
}

.queue-panel.open {
    transform: translateX(0);
}

.queue-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--brd);
}

.queue-header h3 {
    margin: 0;
    font-size: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}

.queue-count {
    background: var(--red);
    color: white;
    font-size: 11px;
    padding: 2px 8px;
    border-radius: 10px;
}

.queue-actions {
    display: flex;
    gap: 8px;
}

.queue-action-btn {
    background: var(--s2);
    border: 1px solid var(--brd);
    color: var(--txt);
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
}

.queue-action-btn:hover {
    border-color: var(--red);
    color: var(--red);
}

.queue-action-btn.danger:hover {
    border-color: #ff4444;
    color: #ff4444;
}

.queue-close {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--dim);
    cursor: pointer;
    padding: 4px;
}

.queue-close:hover {
    color: var(--txt);
}

.queue-now-playing {
    padding: 16px 20px;
    background: linear-gradient(135deg, rgba(229, 9, 20, 0.15), transparent);
    border-bottom: 1px solid var(--brd);
}

.queue-now-label {
    font-size: 10px;
    color: var(--red);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-bottom: 12px;
}

.queue-current-track {
    display: flex;
    gap: 12px;
    align-items: center;
}

.queue-current-art {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    object-fit: cover;
    background: var(--s3);
}

.queue-current-info {
    flex: 1;
    min-width: 0;
}

.queue-current-title {
    font-weight: 600;
    font-size: 15px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.queue-current-artist {
    font-size: 13px;
    color: var(--dim);
}

.queue-list-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    background: var(--s2);
    font-size: 12px;
    color: var(--dim);
}

.queue-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

.queue-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 20px;
    cursor: pointer;
    transition: background 0.2s;
}

.queue-item:hover {
    background: var(--s2);
}

.queue-item.playing {
    background: rgba(229, 9, 20, 0.1);
}

.queue-item-drag {
    color: var(--dim);
    cursor: grab;
    padding: 4px;
}

.queue-item-drag:active {
    cursor: grabbing;
}

.queue-item-num {
    width: 24px;
    text-align: center;
    font-size: 13px;
    color: var(--dim);
}

.queue-item-art {
    width: 44px;
    height: 44px;
    border-radius: 6px;
    object-fit: cover;
    background: var(--s3);
}

.queue-item-info {
    flex: 1;
    min-width: 0;
}

.queue-item-title {
    font-size: 14px;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.queue-item-artist {
    font-size: 12px;
    color: var(--dim);
}

.queue-item-duration {
    font-size: 12px;
    color: var(--dim);
}

.queue-item-remove {
    background: none;
    border: none;
    color: var(--dim);
    font-size: 16px;
    cursor: pointer;
    padding: 4px 8px;
    opacity: 0;
    transition: opacity 0.2s;
}

.queue-item:hover .queue-item-remove {
    opacity: 1;
}

.queue-item-remove:hover {
    color: #ff4444;
}

/* Empty queue */
.queue-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    color: var(--dim);
    padding: 40px 20px;
    text-align: center;
}

.queue-empty-icon {
    font-size: 48px;
    margin-bottom: 16px;
    opacity: 0.5;
}

.queue-empty-text {
    font-size: 14px;
}

/* ENHANCED MINI PLAYER */
.mplayer {
    position: fixed;
    bottom: 60px;
    left: var(--sb);
    right: 0;
    background: var(--s1);
    border-top: 1px solid var(--brd);
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    z-index: 90;
}

.mp-art {
    width: 44px;
    height: 44px;
    border-radius: 6px;
    object-fit: cover;
    background: var(--s3);
    flex-shrink: 0;
}

.mp-info {
    flex: 1;
    min-width: 0;
}

.mp-info div {
    font-size: 13px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mp-playbtn {
    font-size: 22px;
}

.mp-seek {
    width: 100px;
    accent-color: var(--red);
}

.mp-share-btn, .mp-queue-btn {
    background: none;
    border: none;
    color: var(--dim);
    font-size: 18px;
    cursor: pointer;
    padding: 6px;
    transition: color 0.2s;
}

.mp-share-btn:hover, .mp-queue-btn:hover {
    color: var(--red);
}

/* NOTIFICATION PLAYER STYLE (mobile-like) */
.notif-player {
    position: fixed;
    top: 20px;
    right: 20px;
    width: 340px;
    background: var(--s1);
    border: 1px solid var(--brd);
    border-radius: 16px;
    z-index: 1000;
    display: none;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    animation: slideInNotif 0.3s ease;
}

@keyframes slideInNotif {
    from { transform: translateX(100%); opacity: 0; }
    to { transform: translateX(0); opacity: 1; }
}

.notif-player.show {
    display: block;
}

.notif-player-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px;
}

.notif-player-art {
    width: 56px;
    height: 56px;
    border-radius: 8px;
    object-fit: cover;
    background: var(--s3);
}

.notif-player-info {
    flex: 1;
    min-width: 0;
}

.notif-player-title {
    font-weight: 600;
    font-size: 14px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.notif-player-artist {
    font-size: 12px;
    color: var(--dim);
}

.notif-player-close {
    background: none;
    border: none;
    color: var(--dim);
    font-size: 18px;
    cursor: pointer;
}

.notif-player-controls {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 16px;
    padding: 0 16px 16px;
}

.notif-ctrl-btn {
    background: none;
    border: none;
    color: var(--txt);
    font-size: 20px;
    cursor: pointer;
    padding: 8px;
    transition: color 0.2s;
}

.notif-ctrl-btn:hover {
    color: var(--red);
}

.notif-ctrl-btn.play {
    background: var(--red);
    color: white;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    font-size: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.notif-ctrl-btn.play:hover {
    background: var(--rh);
    color: white;
}

.notif-ctrl-btn.shuffle.active, .notif-ctrl-btn.repeat.active {
    color: var(--red);
}

/* RESPONSIVE */
@media(max-width:768px){
    .sidebar{display:none}.main{margin-left:0}
    .mplayer{left:0}.bnav{left:0}
    .form-row{grid-template-columns:1fr}
    .npanel{width:100%}
    #sticky-banner-ad{left:0}
    .album-detail-header{flex-direction:column;align-items:center;text-align:center}
    .album-detail-art{width:160px;height:160px}
    .album-actions{justify-content:center}

    .share-platforms {
        grid-template-columns: repeat(3, 1fr);
    }

    .queue-panel {
        width: 100%;
    }

    .notif-player {
        width: calc(100% - 40px);
        left: 20px;
        right: 20px;
    }
}

@media(max-width:480px){
    .share-platforms {
        grid-template-columns: repeat(2, 1fr);
    }

    .share-preview {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }
}
