*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── Dark base (SpinItUp feel) ── */
  --bg:#080d08;--bg2:#0d130d;--bg3:#131a13;--bg4:#1a241a;
  --bdr:#1e2e1e;--bdr2:#2a3e2a;
  --t1:#eef5ee;--t2:#8faa8f;--t3:#506050;
  /* ── Neon accent palette from SpinItUp logo ── */
  --amber:#39ff14;      /* neon green  — primary accent  */
  --teal:#00e5ff;       /* cyan        — secondary       */
  --rose:#ff2d78;       /* hot pink    — danger/alerts   */
  --violet:#b94fff;     /* purple      — tertiary        */
  --green:#39ff14;      /* same as amber for badge-green */
  --sw:240px;--r:8px;--rl:14px;--rxl:20px;
}
html,body{height:100%}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--t1);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:var(--amber);text-decoration:none}a:hover{text-decoration:underline}
img{display:block;max-width:100%}input,select,button,textarea{font-family:inherit}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:99px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:var(--r);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none;white-space:nowrap}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--amber);color:#000}.btn-primary:hover{background:#28e60e}
.btn-outline{background:transparent;color:var(--t1);border:1px solid var(--bdr)}.btn-outline:hover{background:var(--bg3)}
.btn-secondary{background:var(--bg4);color:var(--t1)}.btn-secondary:hover{background:var(--bdr2)}
.btn-danger{background:rgba(244,63,94,.12);color:var(--rose);border:1px solid rgba(244,63,94,.25)}.btn-danger:hover{background:rgba(244,63,94,.22)}
.btn-full{width:100%}.btn-sm{padding:6px 12px;font-size:12px}.btn-xs{padding:4px 8px;font-size:11px}
.btn:disabled{opacity:.5;cursor:not-allowed}.hidden{display:none!important}
.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:99px;font-size:11px;font-weight:600}
.badge-gray{background:var(--bg4);color:var(--t2)}.badge-green{background:rgba(34,197,94,.14);color:var(--green)}
.badge-amber{background:rgba(245,158,11,.14);color:var(--amber)}.badge-teal{background:rgba(20,184,166,.14);color:var(--teal)}
.badge-red{background:rgba(244,63,94,.14);color:var(--rose)}.muted{color:var(--t3)}
.alert{padding:12px 16px;border-radius:var(--r);font-size:13px}
.alert-success{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);color:var(--green)}
.alert-error{background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.25);color:var(--rose)}.mx{margin:16px 32px 0}
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:13px;font-weight:500;color:var(--t2)}
.fg input,.fg select{background:var(--bg3);border:1px solid var(--bdr);color:var(--t1);padding:10px 14px;border-radius:var(--r);font-size:14px;outline:none;transition:border-color .15s}
.fg input:focus,.fg select:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(57,255,20,.12)}.fg input::placeholder{color:var(--t3)}
.hint{font-size:12px;color:var(--t3)}.fcheck{display:flex;align-items:center;gap:8px;margin-bottom:18px}
.fcheck input{accent-color:var(--amber);width:16px;height:16px}.fcheck label{font-size:13px;color:var(--t2);cursor:pointer}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}
/* Auth */
.auth-page{background:var(--bg)}.auth-wrap{display:flex;min-height:100vh}
.auth-left{flex:1;background:linear-gradient(145deg,#1a1206,#0f0f11 60%,#0d1a18);display:flex;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}
.auth-left::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 30% 50%,rgba(57,255,20,.08) 0%,transparent 70%)}
.client-left::before{background:radial-gradient(ellipse 60% 60% at 30% 50%,rgba(0,229,255,.07) 0%,transparent 70%)}
.auth-hero{position:relative;z-index:1}
.hero-glyph{font-size:56px;line-height:1;margin-bottom:16px}
.hero-title{font-family:'Syne',sans-serif;font-size:48px;font-weight:800;letter-spacing:-2px;line-height:1}
.hero-title span{color:var(--amber)}.hero-sub{margin-top:14px;color:var(--t2);font-size:14px;max-width:300px;line-height:1.6}
.auth-right{width:460px;display:flex;align-items:center;justify-content:center;padding:48px 40px;background:var(--bg2);border-left:1px solid var(--bdr)}
.auth-card{width:100%}.auth-card h2{font-family:'Syne',sans-serif;font-size:26px;font-weight:700}
.auth-hint{color:var(--t3);font-size:13px;margin:6px 0 24px}
.auth-sep{text-align:center;color:var(--t3);font-size:12px;margin:16px 0;position:relative}
.auth-sep::before,.auth-sep::after{content:'';position:absolute;top:50%;width:44%;height:1px;background:var(--bdr)}
.auth-sep::before{left:0}.auth-sep::after{right:0}
/* App layout */
.app-page{background:var(--bg)}.app-layout{display:flex;height:100vh;overflow:hidden}
.sidebar{width:var(--sw);background:var(--bg2);border-right:1px solid var(--bdr);display:flex;flex-direction:column;flex-shrink:0}
.sidebar-brand{display:flex;align-items:center;gap:12px;padding:22px 20px 18px;border-bottom:1px solid var(--bdr)}
.brand-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--amber),var(--teal));color:#000;border-radius:6px;display:grid;place-items:center;font-size:17px;font-weight:bold}
.brand-name{font-family:'Syne',sans-serif;font-size:17px;font-weight:700}
.sidebar-nav{flex:1;padding:10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);color:var(--t2);font-size:14px;font-weight:500;transition:all .15s}
.nav-item:hover{background:var(--bg3);color:var(--t1);text-decoration:none}.nav-item.active{background:rgba(57,255,20,.08);color:var(--amber);border-left:2px solid var(--amber)}
.ni{font-size:15px;width:20px;text-align:center}
.sidebar-footer{padding:14px;border-top:1px solid var(--bdr);display:flex;align-items:center;gap:10px}
.user-ava{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--amber),var(--teal));color:#000;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-meta{flex:1;display:flex;flex-direction:column;min-width:0}
.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:11px;color:var(--t3)}
.logout-btn{background:none;border:none;cursor:pointer;color:var(--t3);font-size:18px;padding:4px;transition:color .15s}.logout-btn:hover{color:var(--rose)}
.app-main{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.app-header{padding:26px 32px 0;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.page-title{font-family:'Syne',sans-serif;font-size:24px;font-weight:700}
.header-right{display:flex;align-items:center;gap:12px}
.back-link{font-size:12px;color:var(--t3);display:block;margin-bottom:4px}.back-link:hover{color:var(--amber)}
.filter-sel{background:var(--bg3);border:1px solid var(--bdr);color:var(--t1);padding:8px 12px;border-radius:var(--r);font-size:13px;cursor:pointer}
/* Stats */
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:22px 32px 0}
.stat-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);padding:18px;display:flex;align-items:center;gap:14px}
.stat-icon{width:42px;height:42px;border-radius:var(--r);display:grid;place-items:center;font-size:17px;color:#000;flex-shrink:0}
.si-amber{background:var(--amber);box-shadow:0 0 10px rgba(57,255,20,.3)}.si-teal{background:var(--teal);box-shadow:0 0 10px rgba(0,229,255,.3)}.si-rose{background:var(--rose)}.si-violet{background:var(--violet)}
.stat-body{display:flex;flex-direction:column}
.stat-val{font-family:'Syne',sans-serif;font-size:26px;font-weight:700;line-height:1}.stat-lbl{font-size:12px;color:var(--t3);margin-top:4px}
/* Cards */
.card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl)}
.content-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:18px 32px 32px}
.card-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 14px;border-bottom:1px solid var(--bdr);flex-wrap:wrap;gap:8px}
.card-hdr h2{font-family:'Syne',sans-serif;font-size:15px;font-weight:600}
.card-link{font-size:13px;color:var(--amber);text-shadow:0 0 8px rgba(57,255,20,.3)}.empty{padding:28px 18px;text-align:center;color:var(--t3);font-size:13px}
.empty-hero{display:flex;flex-direction:column;align-items:center;padding:70px 32px;text-align:center}
.eh-icon{font-size:44px;color:var(--t3);margin-bottom:14px}
.empty-hero h2{font-family:'Syne',sans-serif;font-size:20px;font-weight:600}.empty-hero p{color:var(--t3);font-size:13px;margin:8px 0 18px}
/* List rows */
.list-body{padding:8px}
.list-row{display:flex;align-items:center;gap:12px;padding:10px;border-radius:var(--r);transition:background .15s}.list-row:hover{background:var(--bg3)}
.ava{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--amber),var(--teal));color:#000;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0}
.ava-lg{width:44px;height:44px;font-size:18px;border-radius:var(--r)}
.thumb{width:38px;height:38px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg3);display:grid;place-items:center;color:var(--t3)}
.thumb img{width:100%;height:100%;object-fit:cover}
.list-info{flex:1;display:flex;flex-direction:column;min-width:0}
.list-info span{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-info small{font-size:11px;color:var(--t3)}
/* Table */
.table-wrap{margin:22px 32px 32px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);overflow:hidden}
.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead{background:var(--bg3)}
.tbl th{padding:11px 14px;text-align:left;font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--bdr)}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--bg3)}
.te{display:flex;align-items:center;gap:10px}.tart{width:30px;height:30px;border-radius:4px;object-fit:cover;flex-shrink:0}
/* Modal */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px}
.modal-bd{position:absolute;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px)}
.modal-box{position:relative;z-index:1;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rxl);width:100%;max-width:500px;box-shadow:0 8px 40px rgba(0,0,0,.6)}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--bdr)}
.modal-hdr h2{font-family:'Syne',sans-serif;font-size:17px;font-weight:600}
.modal-close{background:none;border:none;color:var(--t3);font-size:17px;cursor:pointer;padding:4px}.modal-close:hover{color:var(--t1)}
.modal-body{padding:22px}.modal-ftr{padding:14px 22px;border-top:1px solid var(--bdr);display:flex;gap:10px;justify-content:flex-end}
.imp-preview{display:flex;align-items:center;gap:14px;background:var(--bg3);border-radius:var(--r);padding:14px;margin-top:14px}
/* Form page */
.form-page{padding:22px 32px 32px}
.form-card{max-width:460px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);padding:26px}
.form-desc{font-size:13px;color:var(--t3);margin-bottom:22px}
/* Playlist grid */
.playlist-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px;padding:22px 32px 32px}
.pl-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);overflow:hidden;transition:border-color .2s,transform .2s}.pl-card:hover{border-color:var(--bdr2);transform:translateY(-2px)}
.pl-art{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg3)}.pl-art img{width:100%;height:100%;object-fit:cover}
.art-ph{width:100%;height:100%;display:grid;place-items:center;font-size:32px;color:var(--t3)}
.pl-count{position:absolute;bottom:8px;left:8px;background:rgba(0,0,0,.6);color:#fff;padding:2px 8px;border-radius:99px;font-size:11px}
.pl-body{padding:14px}.pl-body h3{font-family:'Syne',sans-serif;font-size:14px;font-weight:600}
.pl-desc{font-size:12px;color:var(--t3);margin-top:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pl-actions{padding:0 14px 14px;display:flex;gap:8px}
/* Assign */
.assign-page{padding:22px 32px 32px;display:flex;flex-direction:column;gap:18px}
.assign-preview{padding:22px;display:flex;gap:20px;align-items:center}
.ap-art{width:90px;height:90px;border-radius:var(--r);overflow:hidden;flex-shrink:0;background:var(--bg3)}.ap-art img{width:100%;height:100%;object-fit:cover}
.assign-preview h2{font-family:'Syne',sans-serif;font-size:20px;font-weight:700}
.track-scroll{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:4px}
.track-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px}.track-row:hover{background:var(--bg3)}
.tn{width:20px;text-align:right;font-size:11px;color:var(--t3);flex-shrink:0}
.tt{font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ta{font-size:11px;color:var(--t3);display:block}
.check-list{display:flex;flex-direction:column;gap:8px}
.check-item{display:flex;align-items:center;gap:12px;background:var(--bg3);border:1px solid var(--bdr);border-radius:var(--r);padding:12px;cursor:pointer;transition:border-color .15s}
.check-item:hover{border-color:var(--amber)}.check-item input{accent-color:var(--amber);width:17px;height:17px;flex-shrink:0}
.check-info{flex:1;display:flex;flex-direction:column;min-width:0}
.check-info span{font-size:14px;font-weight:500}.check-info small{font-size:12px;color:var(--t3)}
/* Client Dashboard */
.toggle-row{display:flex;align-items:center;gap:10px}
.toggle-btn{position:relative;width:44px;height:24px;border-radius:99px;border:none;cursor:pointer;transition:background .2s;padding:0}
.tog-off{background:var(--bg4)}.tog-on{background:var(--amber);box-shadow:0 0 8px rgba(57,255,20,.4)}
.tog-knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;display:block}
.tog-on .tog-knob{transform:translateX(20px)}
.client-grid{display:grid;grid-template-columns:1fr 340px;gap:18px;padding:22px 32px 32px}
.client-left,.client-right{display:flex;flex-direction:column;gap:18px;min-width:0}
/* Now Playing */
.now-playing-card{background:linear-gradient(135deg,#091209,var(--bg2));border:1px solid rgba(57,255,20,.15);border-radius:var(--rl);padding:18px}
.np-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.np-tag{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:4px 10px;border-radius:99px}
.tag-pl{background:rgba(20,184,166,.14);color:var(--teal)}.tag-req{background:rgba(245,158,11,.14);color:var(--amber)}
.mk-status{font-size:12px;color:var(--t3)}.mk-ready{color:var(--green)!important}.mk-error{color:var(--rose)!important}
.np-body{display:flex;gap:16px;align-items:flex-start}
.np-art{width:76px;height:76px;border-radius:var(--r);overflow:hidden;background:var(--bg3);flex-shrink:0}
.np-art img{width:100%;height:100%;object-fit:cover}.np-ph{width:100%;height:100%;display:grid;place-items:center;font-size:26px;color:var(--t3)}
.np-info{flex:1;min-width:0}
.np-info h2{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-info p{font-size:13px;color:var(--t2);margin-top:4px}
.np-note{font-size:11px!important;color:var(--t3)!important;margin-top:2px!important}
.np-ctrl{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.ctrl-btn{background:var(--bg4);border:1px solid var(--bdr);color:var(--t1);padding:7px 12px;border-radius:var(--r);font-size:13px;cursor:pointer;transition:all .15s}.ctrl-btn:hover{background:var(--bg3)}
.ctrl-play{background:var(--amber);color:#000;border-color:transparent}.ctrl-play:hover{background:#28e60e}
.ctrl-next{background:var(--bg3);border-color:var(--bdr2)}
/* Playlist tracks */
.playlist-tracks{max-height:380px;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}
.track-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r);transition:background .15s;position:relative}
.track-item:hover{background:var(--bg3)}.track-item:hover .track-remove{opacity:1}
.track-active{background:rgba(245,158,11,.1)!important;border-left:3px solid var(--amber)}
.track-played{opacity:.35}.track-request{border-left:3px solid rgba(245,158,11,.35)}
.track-text{flex:1;min-width:0}
.tart-ph{width:32px;height:32px;border-radius:4px;background:var(--bg4);display:grid;place-items:center;font-size:14px;color:var(--t3);flex-shrink:0}
.req-badge{font-size:9px;background:rgba(245,158,11,.2);color:var(--amber);padding:1px 5px;border-radius:99px;margin-left:6px;vertical-align:middle}
.playing-now{font-size:11px;color:var(--amber);white-space:nowrap;flex-shrink:0}
.track-remove{background:none;border:none;color:var(--t3);cursor:pointer;font-size:13px;padding:4px;opacity:0;transition:opacity .15s;flex-shrink:0}.track-remove:hover{color:var(--rose)}
/* QR */
.qr-card{padding:18px}.qr-row{display:flex;gap:14px;align-items:center}
.qr-wrap{background:#fff;padding:8px;border-radius:var(--r);flex-shrink:0}.qr-img{width:90px;height:90px;display:block}
.qr-card h3{font-size:14px;font-weight:600;margin-bottom:6px}.qr-card p{font-size:12px;color:var(--t3);margin-bottom:10px;line-height:1.5}
/* Requests */
.req-item{display:flex;align-items:center;gap:10px;padding:10px;border-radius:var(--r);border:1px solid var(--bdr);background:var(--bg3);transition:opacity .3s,transform .3s}
.req-art{width:38px;height:38px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg4);display:grid;place-items:center;color:var(--t3)}
.req-art img{width:100%;height:100%;object-fit:cover}
.req-info{flex:1;display:flex;flex-direction:column;min-width:0}
.req-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.req-artist{font-size:11px;color:var(--t3)}.req-by{font-size:11px;color:var(--amber)}
.req-timer{font-size:11px;margin-top:2px}
.req-btns{display:flex;gap:6px;flex-shrink:0}
.req-acc,.req-rej{width:30px;height:30px;border-radius:6px;border:none;cursor:pointer;font-size:14px;font-weight:600;transition:all .15s}
.req-acc{background:rgba(34,197,94,.14);color:var(--green)}.req-acc:hover{background:rgba(34,197,94,.28)}
.req-rej{background:rgba(244,63,94,.14);color:var(--rose)}.req-rej:hover{background:rgba(244,63,94,.28)}
/* Customer Page */
.customer-page{background:#0a0a0c;min-height:100vh}
.cust-wrap{max-width:480px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}
.cust-header{padding:18px 18px 0;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.venue-row{display:flex;align-items:center;gap:12px}
.venue-name{font-family:'Syne',sans-serif;font-size:18px;font-weight:700}
.np-pill{display:flex;align-items:center;gap:6px;background:var(--bg2);border:1px solid var(--bdr);border-radius:99px;padding:5px 12px;font-size:12px;max-width:200px;overflow:hidden;white-space:nowrap}
.np-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.status-banner{margin:14px 18px 0;padding:10px 14px;border-radius:var(--r);font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px}
.sb-open{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.22);color:var(--green)}
.sb-closed{background:var(--bg2);border:1px solid var(--bdr);color:var(--t3)}
.cust-body{flex:1;padding:14px 18px 32px}
.cust-closed{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}
.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);padding:12px 14px;margin-bottom:12px;transition:border-color .15s}
.search-bar:focus-within{border-color:var(--amber);box-shadow:0 0 0 3px rgba(57,255,20,.10)}.search-bar input{flex:1;background:none;border:none;outline:none;color:var(--t1);font-size:15px}
.search-bar input::placeholder{color:var(--t3)}.search-bar button{background:none;border:none;color:var(--t3);cursor:pointer;font-size:15px}
.results-lbl{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);padding:10px 14px 6px}
#searchResults{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);overflow:hidden}
.res-item{display:flex;align-items:center;gap:12px;padding:11px 14px;cursor:pointer;transition:background .15s}.res-item:hover{background:var(--bg3)}
.res-art{width:42px;height:42px;border-radius:6px;object-fit:cover;flex-shrink:0}
.res-art-ph{width:42px;height:42px;background:var(--bg4);border-radius:6px;display:grid;place-items:center;font-size:16px;color:var(--t3);flex-shrink:0}
.res-info{flex:1;min-width:0;display:flex;flex-direction:column}
.res-info span{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.res-info small{font-size:12px;color:var(--t3)}
.res-loading{padding:20px;text-align:center;color:var(--t3);font-size:13px}
.step-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:var(--rl);padding:18px}
.sel-prev{display:flex;align-items:center;gap:12px}.sel-art{width:52px;height:52px;border-radius:var(--r);object-fit:cover}
.sel-art-ph{width:52px;height:52px;background:var(--bg3);border-radius:var(--r);display:grid;place-items:center;font-size:20px;color:var(--t3)}
.success-ico{width:56px;height:56px;border-radius:50%;background:rgba(57,255,20,.12);color:var(--green);box-shadow:0 0 16px rgba(57,255,20,.2);display:grid;place-items:center;font-size:22px;margin:0 auto}
.status-pill{display:inline-flex;padding:7px 18px;border-radius:99px;font-size:13px;font-weight:500}
.sp-pending{background:rgba(245,158,11,.14);color:var(--amber)}
.sp-accepted{background:rgba(34,197,94,.14);color:var(--green)}
.sp-rejected{background:rgba(244,63,94,.14);color:var(--rose)}

/* ── Apple Music Player Card ──────────────────────────── */
.player-card{background:linear-gradient(135deg,#091209,var(--bg2));border:1px solid var(--bdr);border-radius:var(--rl);padding:22px}
.player-card-header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.player-icon{width:48px;height:48px;border-radius:var(--r);background:linear-gradient(135deg,var(--amber),var(--teal));color:#000;display:grid;place-items:center;font-size:22px;flex-shrink:0}
.player-card-header h2{font-family:'Syne',sans-serif;font-size:17px;font-weight:700}
.mk-status-bar{padding:10px 14px;border-radius:var(--r);font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.mk-idle {background:var(--bg3);border:1px solid var(--bdr);color:var(--t2)}
.mk-loading{background:rgba(57,255,20,.08);border:1px solid rgba(57,255,20,.25);color:var(--amber)}
.mk-ok   {background:rgba(57,255,20,.08);border:1px solid rgba(57,255,20,.3);color:var(--green)}
.mk-error{background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.3);color:var(--rose)}
.player-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-play-big{font-size:15px;font-weight:600;padding:12px 24px}
.progress-bar-wrap{height:6px;background:var(--bg3);border-radius:99px;overflow:hidden}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--amber),var(--teal));border-radius:99px;transition:width .4s ease}
/* track-playing / track-played */
.track-item.track-playing{background:rgba(245,158,11,.09);border-left:3px solid var(--amber)}
.track-item.track-playing .tn{color:var(--amber)}
.track-item.track-played{opacity:.45;pointer-events:none}
.track-item.track-played .tn{text-decoration:line-through}

/* ── Shoutout cards (client dashboard) ───────────────────────────── */
.shout-item{background:var(--bg2);border:1px solid var(--bdr);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:10px;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.shout-header{display:flex;align-items:center;gap:10px}
.shout-from-ico{font-size:22px;flex-shrink:0}
.shout-meta{flex:1;min-width:0;display:flex;flex-direction:column}
.shout-from{font-size:14px;font-weight:700;color:var(--t1)}
.shout-time{color:var(--t3)}
.shout-msg{font-size:13px;color:var(--t2);line-height:1.55;padding:8px 12px;background:var(--bg3);border-radius:8px;white-space:pre-wrap;word-break:break-word}
.shout-img-wrap{border-radius:10px;overflow:hidden;max-height:180px}
.shout-img{width:100%;max-height:180px;object-fit:cover;border-radius:10px;display:block}
.shout-btns{display:flex;gap:8px}
.shout-display-btn{background:rgba(57,255,20,.12)!important;color:var(--green)!important;border:1px solid rgba(57,255,20,.3)!important}
.shout-display-btn:hover{background:rgba(34,197,94,.25)!important}

/* ── Wallpaper thumbnails ──────────────────────────────────────── */
.wp-thumb{border-radius:10px;overflow:hidden;border:2px solid var(--bdr);background:var(--bg2);transition:border-color .2s;cursor:pointer}
.wp-thumb.wp-active{border-color:var(--green);box-shadow:0 0 0 1px var(--green),0 0 12px rgba(57,255,20,.3)}
.wp-img{width:100%;height:70px;object-fit:cover;display:block}
.wp-label{font-size:11px;padding:4px 6px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wp-actions{display:flex;gap:4px;padding:4px 6px 6px;flex-wrap:wrap}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:6px;border:1px solid var(--bdr);background:var(--bg3);color:var(--t2);cursor:pointer;white-space:nowrap}
.btn-xs:hover{background:var(--bg2)}
.btn-xs.btn-danger{background:rgba(244,63,94,.12);color:var(--rose);border-color:rgba(244,63,94,.2)}
.btn-xs.btn-primary{background:rgba(99,102,241,.15);color:#818cf8;border-color:rgba(99,102,241,.2)}

/* ── Team member cards ────────────────────────────────────────── */
.team-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;transition:opacity .2s}
.team-inactive{opacity:.45}
.team-ava{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--violet),var(--teal));display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;flex-shrink:0}
.team-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}
.team-name{font-size:14px;font-weight:600}
.team-email{font-size:12px}
.team-perms{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}
.perm-badge{font-size:10px;padding:2px 7px;border-radius:8px;font-weight:600}
.perm-on{background:rgba(57,255,20,.10);color:var(--amber);border:1px solid rgba(57,255,20,.25)}
.perm-off{background:var(--bg3);color:var(--t3);border:1px solid var(--bdr)}
.team-actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}
.perm-check{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;padding:6px 10px;background:var(--bg2);border-radius:8px;border:1px solid var(--bdr)}
.perm-check input{width:16px;height:16px;accent-color:var(--amber);flex-shrink:0}

/* ── Nav section labels ────────────────────────────────────────── */
.nav-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);padding:12px 12px 4px;margin-top:4px}

/* ── Responsive — tablet ─────────────────────────────────────── */
@media (max-width:960px){
  :root{--sw:200px}
  .client-grid{grid-template-columns:1fr;padding:16px}
  .stats-grid{grid-template-columns:1fr 1fr;padding:16px 16px 0}
  .content-grid{grid-template-columns:1fr;padding:12px 16px 24px}
  .table-wrap{margin:16px 16px 24px}
  .form-page{padding:16px}
  .playlist-grid{padding:16px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
  .assign-page{padding:16px}
  .app-header{padding:18px 16px 0}
}

/* ── Hamburger button (hidden on desktop) ───────────────────────── */
.mob-topbar{display:none}
.hamburger{display:none}

/* ── Mobile drawer overlay ──────────────────────────────────────── */
.drawer-overlay{
  display:none;position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,0);transition:background .3s;pointer-events:none;
}
.drawer-overlay.open{display:block;background:rgba(0,0,0,.55);pointer-events:all}

/* ── Mobile drawer panel ────────────────────────────────────────── */
.mob-drawer{
  position:fixed;top:0;left:0;bottom:0;z-index:201;
  width:280px;
  background:var(--bg2);border-right:1px solid var(--bdr);
  display:flex;flex-direction:column;
  transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  will-change:transform;
}
.mob-drawer.open{transform:translateX(0)}

.mob-drawer-brand{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 18px 16px;border-bottom:1px solid var(--bdr);flex-shrink:0;
}
.mob-drawer-brand .brand-row{display:flex;align-items:center;gap:12px}
.mob-drawer-close{
  background:none;border:none;color:var(--t3);cursor:pointer;
  font-size:22px;padding:4px;line-height:1;transition:color .15s;
}
.mob-drawer-close:hover{color:var(--t1)}

.mob-drawer-nav{flex:1;padding:10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.mob-drawer-nav .nav-item{padding:12px 14px;font-size:15px}
.mob-drawer-nav .nav-section-label{padding:14px 14px 4px;font-size:11px}

.mob-drawer-footer{
  padding:14px 18px;border-top:1px solid var(--bdr);
  display:flex;align-items:center;gap:12px;flex-shrink:0;
}
.mob-drawer-footer .user-ava{width:36px;height:36px;font-size:14px;flex-shrink:0}
.mob-drawer-footer .user-meta{flex:1;min-width:0}
.mob-drawer-footer .user-name{font-size:14px}
.mob-drawer-footer .user-role{font-size:12px}
.mob-drawer-footer .logout-btn{font-size:20px;padding:6px}

/* ── Mobile layout ─────────────────────────────────────────────── */
@media (max-width:700px){
  /* Hide the desktop sidebar */
  .sidebar{display:none}

  /* Show top bar */
  .mob-topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:0 16px;height:54px;
    background:var(--bg2);border-bottom:1px solid var(--bdr);
    position:sticky;top:0;z-index:50;flex-shrink:0;
  }
  .mob-topbar-brand{display:flex;align-items:center;gap:10px}
  .mob-topbar-brand .brand-icon{width:30px;height:30px;font-size:14px}
  .mob-topbar-brand .brand-name{font-size:16px}

  /* Hamburger button */
  .hamburger{
    display:flex;flex-direction:column;justify-content:center;
    gap:5px;background:none;border:none;cursor:pointer;
    padding:8px;border-radius:var(--r);transition:background .15s;
    -webkit-tap-highlight-color:transparent;
  }
  .hamburger:hover{background:var(--bg3)}
  .hamburger span{
    display:block;width:22px;height:2px;border-radius:2px;
    background:var(--amber);transition:all .3s;transform-origin:center;
  }
  /* Animate to X when open */
  .hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
  .hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  /* Main area fills remaining screen */
  .app-layout{display:flex;flex-direction:column;height:100vh}
  .app-main{flex:1;overflow-y:auto;height:auto}

  /* Content tweaks */
  .stats-grid{grid-template-columns:1fr 1fr;padding:12px 12px 0;gap:10px}
  .stat-card{padding:14px}.stat-val{font-size:22px}
  .client-grid{padding:12px;gap:12px}
  .table-wrap{margin:12px;border-radius:10px;overflow-x:auto}
  .tbl{min-width:500px}
  .tbl th,.tbl td{padding:10px 10px}
  .auth-wrap{flex-direction:column}
  .auth-left{display:none}
  .auth-right{width:100%;padding:32px 24px}
  .page-title{font-size:20px}
  .app-header{padding:14px 12px 0;flex-wrap:wrap;gap:8px}
  .form-page{padding:12px}.form-card{max-width:100%}
  .playlist-grid{padding:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .assign-page{padding:12px}
}
