/* ═══════════════════════════════════════════════════════════════════
   JukeBox — Venue DJ UI
   Aesthetic: Dark club, neon-drenched, immersive
   Palette: Deep black + neon pink (#ff4ea3) + electric blue (#00d4ff)
            + accent pink (#ff4ea3) with glow effects
   Font: Syne (display) + DM Sans (body)
═══════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* ── Deep dark base ── */
  --bg:    #06080f;
  --bg2:   #0b0e18;
  --bg3:   #111521;
  --bg4:   #181d2e;
  --bg5:   #1e2438;
  --bdr:   rgba(255,255,255,.07);
  --bdr2:  rgba(255,255,255,.12);

  /* ── Text hierarchy ── */
  --t1:#f0f4ff;
  --t2:#8892b0;
  --t3:#4a5578;

  /* ── Neon trio ── */
  --ng:   #ff4ea3;
  --teal: #1fe4c6;   /* accent teal for buttons */   /* accent pink  — primary/active    */
  --np:   #ff4ea3;   /* neon pink   — hot/danger        */
  --nb:   #00d4ff;   /* electric blue — info/secondary   */
  --amber:#ff4ea3;   /* alias for legacy refs           */
  --teal: #00d4ff;
  --rose: #ff4ea3;
  --violet:#b94fff;

  /* ── Glow alphas ── */
  --glow-g: rgba(255,78,163,.18);
  --glow-p: rgba(255,78,163,.18);
  --glow-b: rgba(0,212,255,.18);

  /* ── Layout ── */
  --sw:248px;
  --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;
}
/* Ambient pink glow — bottom-left + top-right */
.app-main::before,
.app-main::after{
  content:'';position:fixed;pointer-events:none;z-index:0;
  border-radius:50%;
}
.app-main::before{
  width:600px;height:600px;
  bottom:-200px;left:-200px;
  background:radial-gradient(circle,rgba(255,78,163,.08) 0%,rgba(255,78,163,.03) 40%,transparent 70%);
}
.app-main::after{
  width:500px;height:500px;
  top:-180px;right:-180px;
  background:radial-gradient(circle,rgba(255,78,163,.07) 0%,rgba(255,78,163,.02) 40%,transparent 70%);
}
.app-main{position:relative}
.app-main>*{position:relative;z-index:1}

/* ── Global animated noise/grain overlay ── */
body::after{
  content:'';
  position:fixed;inset:0;
  pointer-events:none;z-index:9000;
  opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:128px 128px;
}

a{color:var(--nb);text-decoration:none}
a:hover{color:var(--ng);text-decoration:none}
img{display:block;max-width:100%}
input,select,button,textarea{font-family:inherit}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--bg5);border-radius:99px}
::-webkit-scrollbar-thumb:hover{background:var(--bdr2)}

/* ══════════════════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════════════════ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:11px 20px;border-radius:var(--r);
  font-size:13px;font-weight:600;cursor:pointer;border:none;
  transition:all .2s cubic-bezier(.4,0,.2,1);
  text-decoration:none;white-space:nowrap;letter-spacing:.01em;
  position:relative;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;opacity:0;
  background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);
  transition:opacity .2s;
}
.btn:hover::before{opacity:1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}

.btn-primary{
  background:#1fe4c6;color:#000;font-weight:700;
  box-shadow:0 0 16px rgba(31,228,198,.3),0 4px 12px rgba(31,228,198,.2);
}
.btn-primary:hover{
  background:#26ffdb;
  box-shadow:0 0 28px rgba(31,228,198,.5),0 6px 20px rgba(31,228,198,.3);
}
.btn-outline{
  background:transparent;color:var(--t1);
  border:1px solid var(--bdr2);
}
.btn-outline:hover{background:var(--bg4);border-color:var(--bdr2)}
.btn-secondary{background:var(--bg4);color:var(--t1);border:1px solid var(--bdr)}
.btn-secondary:hover{background:var(--bg5)}
.btn-danger{
  background:rgba(255,78,163,.1);color:var(--np);
  border:1px solid rgba(255,78,163,.25);
}
.btn-danger:hover{background:rgba(255,78,163,.2);box-shadow:0 0 12px var(--glow-p)}
.btn-pink{
  background:var(--np);color:#fff;font-weight:700;
  box-shadow:0 0 16px var(--glow-p),0 4px 12px rgba(255,78,163,.2);
}
.btn-pink:hover{background:#ff4585;box-shadow:0 0 28px rgba(255,78,163,.5)}
.btn-blue{
  background:var(--nb);color:#000;font-weight:700;
  box-shadow:0 0 16px var(--glow-b),0 4px 12px rgba(0,212,255,.2);
}
.btn-blue:hover{background:#1adeff;box-shadow:0 0 28px rgba(0,212,255,.5)}

.btn-full{width:100%}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-xs{padding:4px 9px;font-size:11px}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:none!important}
.hidden{display:none!important}

/* ══════════════════════════════════════════════════════
   BADGES
══════════════════════════════════════════════════════ */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 9px;border-radius:99px;
  font-size:11px;font-weight:700;letter-spacing:.02em;
}
.badge-gray{background:var(--bg4);color:var(--t2);border:1px solid var(--bdr)}
.badge-green{
  background:rgba(31,228,198,.1);color:#1fe4c6;
  border:1px solid rgba(255,78,163,.2);
  box-shadow:0 0 8px rgba(255,78,163,.1);
}
.badge-pink{
  background:rgba(255,78,163,.1);color:var(--np);
  border:1px solid rgba(255,78,163,.2);
}
.badge-blue{
  background:rgba(0,212,255,.1);color:var(--nb);
  border:1px solid rgba(0,212,255,.2);
}
.badge-amber{background:rgba(31,228,198,.1);color:#1fe4c6;border:1px solid rgba(255,78,163,.2)}
.badge-teal{background:rgba(0,212,255,.1);color:var(--nb);border:1px solid rgba(0,212,255,.2)}
.badge-red{background:rgba(255,78,163,.1);color:var(--np);border:1px solid rgba(255,78,163,.2)}
.muted{color:var(--t3)}

/* ══════════════════════════════════════════════════════
   ALERTS
══════════════════════════════════════════════════════ */
.alert{padding:12px 16px;border-radius:var(--r);font-size:13px}
.alert-success{background:rgba(255,78,163,.08);border:1px solid rgba(255,78,163,.2);color:var(--ng)}
.alert-error{background:rgba(255,78,163,.08);border:1px solid rgba(255,78,163,.2);color:var(--np)}
.mx{margin:16px 32px 0}

/* ══════════════════════════════════════════════════════
   FORMS
══════════════════════════════════════════════════════ */
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.fg label{font-size:12px;font-weight:700;color:var(--t2);text-transform:uppercase;letter-spacing:.06em}
.fg input,.fg select,.fg textarea{
  background:var(--bg3);
  border:1px solid var(--bdr);
  color:var(--t1);
  padding:11px 15px;border-radius:var(--r);
  font-size:14px;outline:none;
  transition:all .2s;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:rgba(0,212,255,.5);
  box-shadow:0 0 0 3px rgba(0,212,255,.08),0 0 12px rgba(0,212,255,.06);
  background:var(--bg4);
}
.fg input::placeholder{color:var(--t3)}
.hint{font-size:12px;color:var(--t3);line-height:1.5}
.fcheck{display:flex;align-items:center;gap:8px;margin-bottom:18px}
.fcheck input{accent-color:var(--ng);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 PAGES
══════════════════════════════════════════════════════ */
.auth-page{background:var(--bg)}
.auth-wrap{display:flex;min-height:100vh}
.auth-left{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:48px;position:relative;overflow:hidden;
  background:var(--bg);
}
/* Animated neon orbs */
.auth-left::before{
  content:'';position:absolute;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,78,163,.12) 0%,transparent 70%);
  top:-100px;left:-100px;
  animation:orbFloat 8s ease-in-out infinite;
}
.auth-left::after{
  content:'';position:absolute;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,78,163,.1) 0%,transparent 70%);
  bottom:-80px;right:-80px;
  animation:orbFloat 10s ease-in-out infinite reverse;
}
@keyframes orbFloat{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(30px,-20px) scale(1.05)}
  66%{transform:translate(-20px,30px) scale(.95)}
}
.client-left::before{
  background:radial-gradient(circle,rgba(0,212,255,.1) 0%,transparent 70%);
}

.auth-hero{position:relative;z-index:1;text-align:center}
.hero-glyph{
  font-size:64px;line-height:1;margin-bottom:20px;
  filter:drop-shadow(0 0 20px rgba(255,78,163,.5));
}
.hero-title{
  font-family:'Syne',sans-serif;
  font-size:52px;font-weight:800;
  letter-spacing:-2px;line-height:1;
  text-shadow:0 0 40px rgba(255,78,163,.2);
}
.hero-title span{
  color:transparent;
  background:linear-gradient(90deg,var(--ng),var(--nb));
  -webkit-background-clip:text;background-clip:text;
}
.hero-sub{
  margin-top:16px;color:var(--t2);font-size:15px;
  max-width:320px;line-height:1.7;margin-inline:auto;
}
/* Floating music notes decoration */
.auth-deco{
  position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden;
}
.auth-deco span{
  position:absolute;font-size:20px;opacity:.06;
  animation:noteDrift linear infinite;
}
@keyframes noteDrift{
  0%{transform:translateY(100vh) rotate(0deg);opacity:0}
  10%{opacity:.08}
  90%{opacity:.04}
  100%{transform:translateY(-100px) rotate(360deg);opacity:0}
}

.auth-right{
  width:460px;display:flex;align-items:center;justify-content:center;
  padding:48px 40px;
  background:var(--bg2);
  border-left:1px solid var(--bdr);
  position:relative;
}
.auth-right::before{
  content:'';position:absolute;top:0;left:0;
  width:2px;height:100%;
  background:linear-gradient(to bottom,transparent,var(--ng),var(--np),var(--nb),transparent);
  opacity:.4;
}
.auth-card{width:100%}
.auth-card h2{
  font-family:'Syne',sans-serif;font-size:28px;font-weight:800;
  background:linear-gradient(90deg,var(--t1),var(--t2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.auth-hint{color:var(--t3);font-size:13px;margin:8px 0 28px}
.auth-sep{text-align:center;color:var(--t3);font-size:12px;margin:18px 0;position:relative}
.auth-sep::before,.auth-sep::after{
  content:'';position:absolute;top:50%;width:42%;height:1px;
  background:linear-gradient(to right,transparent,var(--bdr2));
}
.auth-sep::before{left:0}
.auth-sep::after{right:0;background:linear-gradient(to left,transparent,var(--bdr2))}

/* ══════════════════════════════════════════════════════
   APP LAYOUT — SIDEBAR
══════════════════════════════════════════════════════ */
.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;
  position:relative;
}
/* Neon accent line on sidebar right edge */
.sidebar::after{
  content:'';position:absolute;top:0;right:-1px;
  width:1px;height:100%;
  background:linear-gradient(to bottom,
    transparent 0%,
    rgba(255,78,163,.3) 30%,
    rgba(0,212,255,.2) 60%,
    rgba(255,78,163,.3) 85%,
    transparent 100%);
}

.sidebar-brand{
  display:flex;align-items:center;gap:12px;
  padding:24px 18px 20px;
  border-bottom:1px solid var(--bdr);
}
.brand-icon{
  width:36px;height:36px;
  background:linear-gradient(135deg,var(--ng),var(--nb));
  color:#000;border-radius:8px;
  display:grid;place-items:center;
  font-size:18px;font-weight:bold;
  box-shadow:0 0 14px rgba(255,78,163,.35),0 0 28px rgba(0,212,255,.15);
}
.brand-name{
  font-family:'Syne',sans-serif;
  font-size:18px;font-weight:800;letter-spacing:-.5px;
  background:linear-gradient(90deg,var(--t1) 50%,var(--t2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.sidebar-nav{
  flex:1;padding:12px 10px;
  display:flex;flex-direction:column;gap:3px;overflow-y:auto;
}
.nav-section-label{
  font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.1em;color:var(--t3);
  padding:14px 10px 4px;margin-top:4px;
}
.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;border-radius:10px;
  color:var(--t2);font-size:13px;font-weight:500;
  transition:all .18s cubic-bezier(.4,0,.2,1);
  position:relative;
}
.nav-item:hover{
  background:var(--bg3);color:var(--t1);
  text-decoration:none;
}
.nav-item.active{
  background:linear-gradient(90deg,rgba(255,78,163,.08),rgba(255,78,163,.02));
  color:var(--ng);
  border-left:2px solid var(--ng);
  box-shadow:inset 2px 0 12px rgba(255,78,163,.06);
}
.nav-item.active::after{
  content:'';position:absolute;right:10px;top:50%;transform:translateY(-50%);
  width:5px;height:5px;border-radius:50%;
  background:var(--ng);
  box-shadow:0 0 6px var(--ng);
}
.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:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--np),var(--nb));
  color:#fff;display:grid;place-items:center;
  font-weight:800;font-size:12px;flex-shrink:0;
  box-shadow:0 0 10px rgba(255,78,163,.3);
}
.user-meta{flex:1;display:flex;flex-direction:column;min-width:0}
.user-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.05em}
.logout-btn{
  background:none;border:none;cursor:pointer;
  color:var(--t3);font-size:18px;padding:5px;
  transition:all .15s;border-radius:6px;
}
.logout-btn:hover{color:var(--np);background:rgba(255,78,163,.1)}

/* ══════════════════════════════════════════════════════
   APP MAIN + HEADER
══════════════════════════════════════════════════════ */
.app-main{flex:1;overflow-y:auto;display:flex;flex-direction:column}

.app-header{
  padding:28px 32px 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;flex-wrap:wrap;gap:12px;
}
.page-title{
  font-family:'Syne',sans-serif;
  font-size:26px;font-weight:800;letter-spacing:-.5px;
  background:linear-gradient(90deg,#ff4ea3,var(--t1) 50%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.back-link{font-size:12px;color:var(--t3);display:block;margin-bottom:4px}
.back-link:hover{color:var(--nb)}
.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 CARDS
══════════════════════════════════════════════════════ */
.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:20px;
  display:flex;align-items:center;gap:16px;
  position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s;
}
.stat-card:hover{transform:translateY(-2px)}
.stat-card::before{
  content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s;
  background:linear-gradient(135deg,rgba(255,255,255,.02),transparent);
}
.stat-card:hover::before{opacity:1}

.stat-icon{
  width:46px;height:46px;border-radius:12px;
  display:grid;place-items:center;
  font-size:18px;color:#000;flex-shrink:0;
}
.si-amber{
  background:linear-gradient(135deg,var(--ng),#28e60e);
  box-shadow:0 0 16px rgba(255,78,163,.4),0 4px 8px rgba(255,78,163,.2);
}
.si-teal{
  background:linear-gradient(135deg,var(--nb),#00a8cc);
  box-shadow:0 0 16px rgba(0,212,255,.4),0 4px 8px rgba(0,212,255,.2);
}
.si-rose{
  background:linear-gradient(135deg,var(--np),#cc1a5a);
  box-shadow:0 0 16px rgba(255,78,163,.4),0 4px 8px rgba(255,78,163,.2);
}
.si-violet{
  background:linear-gradient(135deg,var(--violet),#8a2be2);
  box-shadow:0 0 16px rgba(185,79,255,.4);
}
.stat-body{display:flex;flex-direction:column}
.stat-val{
  font-family:'Syne',sans-serif;
  font-size:28px;font-weight:800;line-height:1;
}
.stat-lbl{font-size:12px;color:var(--t3);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}

/* ══════════════════════════════════════════════════════
   CONTENT CARDS
══════════════════════════════════════════════════════ */
.card{
  background:var(--bg2);
  border:1px solid var(--bdr);
  border-radius:var(--rl);
  position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--bdr2),transparent);
}

.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 20px 14px;
  border-bottom:1px solid var(--bdr);
  flex-wrap:wrap;gap:8px;
}
.card-hdr h2{
  font-family:'Syne',sans-serif;
  font-size:14px;font-weight:700;letter-spacing:.02em;
  text-transform:uppercase;
  color:#ff4ea3;
}
.card-link{
  font-size:12px;color:var(--nb);font-weight:600;
  text-transform:uppercase;letter-spacing:.04em;
}
.card-link:hover{color:var(--ng);text-decoration:none}

.empty{padding:30px 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:48px;color:var(--t3);margin-bottom:16px;opacity:.5}
.empty-hero h2{
  font-family:'Syne',sans-serif;font-size:20px;font-weight:700;
}
.empty-hero p{color:var(--t3);font-size:13px;margin:8px 0 20px}

/* ══════════════════════════════════════════════════════
   LIST ROWS
══════════════════════════════════════════════════════ */
.list-body{padding:8px}
.list-row{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;border-radius:10px;
  transition:background .15s;
}
.list-row:hover{background:var(--bg3)}

.ava{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--np),var(--nb));
  color:#fff;display:grid;place-items:center;
  font-weight:800;font-size:12px;flex-shrink:0;
  box-shadow:0 0 8px rgba(255,78,163,.2);
}
.ava-lg{width:46px;height:46px;font-size:18px;border-radius:12px}
.thumb{
  width:40px;height:40px;border-radius:8px;overflow:hidden;
  flex-shrink:0;background:var(--bg3);
  display:grid;place-items:center;color:var(--t3);
  border:1px solid var(--bdr);
}
.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:600;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:12px 16px;text-align:left;
  font-size:10px;font-weight:800;color:var(--t3);
  text-transform:uppercase;letter-spacing:.08em;
}
.tbl td{
  padding:14px 16px;
  border-bottom:1px solid var(--bdr);
  color:var(--t1);
}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:rgba(255,255,255,.02)}
.te{display:flex;align-items:center;gap:10px}
.tart{width:32px;height:32px;border-radius:6px;object-fit:cover;flex-shrink:0}

/* ══════════════════════════════════════════════════════
   MODALS
══════════════════════════════════════════════════════ */
.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(6,8,15,.85);
  backdrop-filter:blur(8px);
}
.modal-box{
  position:relative;z-index:1;
  background:var(--bg2);
  border:1px solid var(--bdr2);
  border-radius:var(--rxl);
  width:100%;max-width:500px;
  box-shadow:0 0 0 1px rgba(255,255,255,.04),0 24px 64px rgba(0,0,0,.7),0 0 80px rgba(0,212,255,.05);
}
.modal-box::before{
  content:'';position:absolute;top:0;left:20%;right:20%;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(0,212,255,.4),var(--ng),rgba(255,78,163,.4),transparent);
  border-radius:99px;
}
.modal-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 24px;border-bottom:1px solid var(--bdr);
}
.modal-hdr h2{
  font-family:'Syne',sans-serif;font-size:17px;font-weight:800;
  background:linear-gradient(90deg,var(--t1),var(--nb));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.modal-close{
  background:rgba(255,255,255,.06);
  border:1px solid var(--bdr);color:var(--t2);
  font-size:15px;cursor:pointer;
  padding:6px 9px;border-radius:8px;
  transition:all .15s;
}
.modal-close:hover{background:rgba(255,78,163,.12);color:var(--np);border-color:rgba(255,78,163,.3)}
.modal-body{padding:22px 24px}
.modal-ftr{
  display:flex;justify-content:flex-end;gap:10px;
  padding:16px 24px;border-top:1px solid var(--bdr);
  background:rgba(0,0,0,.2);border-radius:0 0 var(--rxl) var(--rxl);
}

/* ══════════════════════════════════════════════════════
   STATUS BARS + PLAYER
══════════════════════════════════════════════════════ */
.mk-status-bar{
  display:flex;align-items:center;gap:10px;
  padding:12px 18px;border-radius:12px;
  font-size:13px;font-weight:500;
  border:1px solid var(--bdr);
  background:var(--bg3);
  transition:all .3s;
}
.mk-status-bar.mk-ok{
  background:rgba(255,78,163,.06);
  border-color:rgba(255,78,163,.2);
  color:var(--ng);
  box-shadow:0 0 20px rgba(255,78,163,.06);
}
.mk-status-bar.mk-error{
  background:rgba(255,78,163,.06);
  border-color:rgba(255,78,163,.2);
  color:var(--np);
}
.mk-status-bar.mk-loading{
  background:rgba(0,212,255,.06);
  border-color:rgba(0,212,255,.2);
  color:var(--nb);
}
.mk-status-bar.mk-idle{color:var(--t2)}

/* ══════════════════════════════════════════════════════
   DASHBOARD — PLAYER SECTION
══════════════════════════════════════════════════════ */
.client-grid{
  display:grid;
  grid-template-columns:1fr 380px;
  gap:18px;
  padding:18px 32px 32px;
}

/* Player card — showstopper glow */
.player-card{
  background:linear-gradient(135deg,var(--bg2) 0%,var(--bg3) 100%);
  border:1px solid rgba(0,212,255,.15);
  border-radius:20px;
  position:relative;overflow:hidden;
  box-shadow:0 0 40px rgba(0,212,255,.05),0 0 80px rgba(255,78,163,.03);
}
.player-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--np),var(--nb),var(--ng));
  animation:playerGlow 3s ease-in-out infinite;
}
@keyframes playerGlow{
  0%,100%{opacity:.6}
  50%{opacity:1;filter:brightness(1.3)}
}

/* Now Playing bar */
.now-playing-bar{
  display:flex;align-items:center;gap:14px;
  padding:16px 20px;
  background:rgba(0,0,0,.3);
  border-radius:12px;
  border:1px solid var(--bdr);
  backdrop-filter:blur(8px);
}
.np-art{
  width:52px;height:52px;border-radius:10px;
  object-fit:cover;flex-shrink:0;
  box-shadow:0 0 20px rgba(0,0,0,.5);
}
.np-info{flex:1;min-width:0}
.np-title{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-artist{font-size:12px;color:var(--t2);margin-top:2px}

/* Player controls */
.player-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* Progress bar */
.progress-bar{
  height:3px;background:var(--bg4);border-radius:99px;overflow:hidden;margin:8px 0;
}
.progress-fill{
  height:100%;border-radius:99px;
  background:linear-gradient(90deg,var(--nb),var(--ng));
  transition:width .5s linear;
  box-shadow:0 0 6px rgba(255,78,163,.5);
}

/* ══════════════════════════════════════════════════════
   QUEUE / TRACK ITEMS
══════════════════════════════════════════════════════ */
.track-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 14px;border-radius:10px;
  transition:all .15s;border:1px solid transparent;
  position:relative;
}
.track-item:hover{background:var(--bg3);border-color:var(--bdr)}
.track-item.track-request{
  background:rgba(255,78,163,.04);
  border-left:2px solid rgba(255,78,163,.4);
}
.track-item.track-played{opacity:.35}
.track-item.track-current{
  background:rgba(255,78,163,.05);
  border-color:rgba(255,78,163,.2);
  box-shadow:0 0 12px rgba(255,78,163,.04);
}
.tn{
  font-size:11px;color:var(--t3);
  width:20px;text-align:right;flex-shrink:0;
}
.tt{font-size:13px;font-weight:600;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ta{font-size:11px;color:var(--t2)}

/* Equalizer animation for playing track */
.eq-bars{
  display:flex;align-items:flex-end;gap:2px;height:14px;flex-shrink:0;
}
.eq-bars span{
  width:3px;border-radius:2px;
  background:var(--ng);
  animation:eqBounce .6s ease-in-out infinite alternate;
  box-shadow:0 0 4px rgba(255,78,163,.6);
}
.eq-bars span:nth-child(2){animation-delay:.2s;height:60%}
.eq-bars span:nth-child(3){animation-delay:.1s;height:80%}
@keyframes eqBounce{
  from{height:20%}to{height:100%}
}

/* ══════════════════════════════════════════════════════
   REQUEST / SHOUTOUT CARDS
══════════════════════════════════════════════════════ */
.req-item,.shout-item{
  padding:12px 14px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--bdr);
  margin-bottom:8px;
  transition:border-color .2s;
}
.req-item:hover{border-color:rgba(0,212,255,.2)}
.shout-item:hover{border-color:rgba(255,78,163,.2)}

.req-header,.shout-header{
  display:flex;align-items:center;gap:10px;margin-bottom:8px;
}
.req-from-ico,.shout-from-ico{
  font-size:20px;flex-shrink:0;
  filter:drop-shadow(0 0 6px rgba(255,78,163,.4));
}
.req-from,.shout-from{font-size:13px;font-weight:700}
.req-meta,.shout-meta{display:flex;flex-direction:column}
.req-time,.shout-time{font-size:11px;color:var(--t3)}
.req-title{font-size:14px;font-weight:700;margin-bottom:2px}
.req-artist{font-size:12px;color:var(--t2)}
.shout-msg{
  font-size:13px;line-height:1.5;
  background:rgba(255,255,255,.03);
  border-radius:8px;padding:8px 10px;
  border:1px solid var(--bdr);
  margin-bottom:10px;
}
.req-btns,.shout-btns{display:flex;gap:8px;flex-wrap:wrap}

/* ══════════════════════════════════════════════════════
   PLAYLIST GRID (MY PLAYLISTS)
══════════════════════════════════════════════════════ */
.playlist-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
  gap:14px;padding:18px 32px;
}
.pl-card{
  background:var(--bg2);border:2px solid var(--bdr);
  border-radius:16px;overflow:hidden;cursor:pointer;
  transition:all .2s cubic-bezier(.4,0,.2,1);
  position:relative;
}
.pl-card:hover{
  transform:translateY(-4px);
  border-color:rgba(0,212,255,.25);
  box-shadow:0 8px 30px rgba(0,0,0,.4),0 0 20px rgba(0,212,255,.08);
}
.pl-card.selected{
  border-color:var(--ng);
  box-shadow:0 0 0 3px rgba(255,78,163,.12),0 0 24px rgba(255,78,163,.1);
}
.pl-card.selected::after{
  content:'✓';position:absolute;top:8px;right:8px;
  width:22px;height:22px;border-radius:50%;
  background:var(--ng);color:#000;
  font-size:12px;font-weight:900;
  display:grid;place-items:center;
  box-shadow:0 0 8px rgba(255,78,163,.5);
}
.pl-art{
  width:100%;aspect-ratio:1;object-fit:cover;
  background:linear-gradient(135deg,var(--bg3),var(--bg4));
  display:flex;align-items:center;justify-content:center;
  font-size:36px;color:var(--t3);
}
.pl-art img{width:100%;height:100%;object-fit:cover}
.pl-info{padding:12px}
.pl-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pl-meta{font-size:11px;color:var(--t3);margin-top:3px}

/* ══════════════════════════════════════════════════════
   SEARCH RESULTS (SONG SEARCH)
══════════════════════════════════════════════════════ */
.search-result-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:10px;
  transition:all .15s;cursor:pointer;
  border:1px solid transparent;
}
.search-result-item:hover{
  background:var(--bg4);
  border-color:rgba(255,78,163,.2);
}
.search-art{
  width:40px;height:40px;border-radius:8px;
  object-fit:cover;flex-shrink:0;
  background:var(--bg3);
  border:1px solid var(--bdr);
}
.search-info{flex:1;min-width:0}
.search-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-artist{font-size:11px;color:var(--t2)}

/* ══════════════════════════════════════════════════════
   WALLPAPERS GRID
══════════════════════════════════════════════════════ */
.wp-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:14px;padding:18px 32px;
}
.wp-item{
  border-radius:14px;overflow:hidden;cursor:pointer;
  border:2px solid var(--bdr);
  transition:all .2s;aspect-ratio:9/16;
  position:relative;
}
.wp-item:hover{transform:scale(1.03);border-color:var(--nb);box-shadow:0 0 20px rgba(0,212,255,.15)}
.wp-item.active-wp{
  border-color:var(--ng);
  box-shadow:0 0 0 3px rgba(255,78,163,.15),0 0 20px rgba(255,78,163,.1);
}

/* ══════════════════════════════════════════════════════
   ACTION BAR (PLAYLISTS BOTTOM BAR)
══════════════════════════════════════════════════════ */
.action-bar{
  position:sticky;bottom:0;
  background:linear-gradient(0deg,var(--bg2) 80%,transparent);
  padding:16px 32px 24px;
  display:flex;align-items:center;gap:12px;
  flex-wrap:wrap;
  backdrop-filter:blur(8px);
  border-top:1px solid var(--bdr);
}

/* ══════════════════════════════════════════════════════
   QR CODE CARD
══════════════════════════════════════════════════════ */
.qr-card{
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:12px;padding:20px;
}
.qr-wrap{
  background:#fff;border-radius:14px;padding:12px;
  box-shadow:0 0 30px rgba(255,255,255,.08);
}
.qr-url{
  font-size:11px;color:var(--t3);
  font-family:'DM Sans',monospace;
  word-break:break-all;
}

/* ══════════════════════════════════════════════════════
   TEAM MEMBER CARDS
══════════════════════════════════════════════════════ */
.team-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:14px;padding:18px 32px;
}
.team-card{
  background:var(--bg3);border:1px solid var(--bdr);
  border-radius:16px;padding:18px;
  display:flex;align-items:center;gap:14px;
  transition:all .2s;
}
.team-card:hover{
  border-color:rgba(185,79,255,.25);
  box-shadow:0 0 20px rgba(185,79,255,.06);
}

/* ══════════════════════════════════════════════════════
   TOAST NOTIFICATIONS
══════════════════════════════════════════════════════ */
@keyframes toastIn{
  from{opacity:0;transform:translateX(-50%) translateY(16px) scale(.95)}
  to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
}
@keyframes toastOut{
  to{opacity:0;transform:translateX(-50%) translateY(8px) scale(.95)}
}

/* ══════════════════════════════════════════════════════
   FORMS (standalone pages)
══════════════════════════════════════════════════════ */
.form-page{padding:24px 32px 48px;max-width:720px;margin:0 auto}
.form-card{
  background:var(--bg2);border:1px solid var(--bdr);
  border-radius:20px;padding:28px;
  box-shadow:0 0 40px rgba(0,0,0,.3);
}
.form-card h2{
  font-family:'Syne',sans-serif;font-size:20px;font-weight:800;
  margin-bottom:22px;
  background:linear-gradient(90deg,var(--t1),var(--t2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.assign-page{padding:24px 32px}

/* ══════════════════════════════════════════════════════
   SECTION LABELS ON PLAYLIST PAGE
══════════════════════════════════════════════════════ */
.section-label{
  font-family:'Syne',sans-serif;
  font-size:11px;font-weight:800;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--t3);
  padding:18px 32px 6px;
  display:flex;align-items:center;gap:10px;
}
.section-label::after{
  content:'';flex:1;height:1px;
  background:linear-gradient(to right,var(--bdr),transparent);
}

/* ══════════════════════════════════════════════════════
   OFFER / FLYER UPLOAD
══════════════════════════════════════════════════════ */
.offer-preview{
  width:100%;border-radius:14px;overflow:hidden;
  border:1px solid var(--bdr);
  background:var(--bg3);
  position:relative;
}
.offer-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(0,0,0,.8) 0%,transparent 50%);
}

/* ══════════════════════════════════════════════════════
   IMPORT PREVIEW
══════════════════════════════════════════════════════ */
.imp-preview{
  display:flex;align-items:center;gap:14px;
  padding:14px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--bdr);
}

/* ══════════════════════════════════════════════════════
   SUPERADMIN HOST CARDS
══════════════════════════════════════════════════════ */
.host-card{
  background:var(--bg2);border:1px solid var(--bdr);
  border-radius:16px;padding:20px;
  transition:all .2s;position:relative;overflow:hidden;
}
.host-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--np),var(--nb));
  opacity:.5;
}
.host-card:hover{
  border-color:rgba(0,212,255,.2);
  box-shadow:0 4px 30px rgba(0,0,0,.3),0 0 20px rgba(0,212,255,.04);
}

/* ══════════════════════════════════════════════════════
   PILL BUTTONS (venue type, language etc)
══════════════════════════════════════════════════════ */
.pill-group{display:flex;flex-wrap:wrap;gap:8px}
.pill{
  padding:7px 14px;border-radius:99px;
  font-size:12px;font-weight:600;cursor:pointer;
  border:1px solid var(--bdr);background:var(--bg3);color:var(--t2);
  transition:all .15s;
}
.pill:hover{border-color:var(--bdr2);color:var(--t1)}
.pill.active{
  background:rgba(255,78,163,.1);
  border-color:rgba(255,78,163,.4);
  color:var(--ng);
  box-shadow:0 0 8px rgba(255,78,163,.1);
}

/* ══════════════════════════════════════════════════════
   SUPERADMIN PLAYLIST IMPORT
══════════════════════════════════════════════════════ */
.pl-import-result{
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:12px;
  background:var(--bg3);border:1px solid var(--bdr);
  margin-bottom:8px;
  transition:border-color .2s;
  cursor:pointer;
}
.pl-import-result:hover{border-color:rgba(255,78,163,.25)}
.pl-import-result.selected{
  border-color:var(--ng);
  background:rgba(255,78,163,.05);
}

/* ══════════════════════════════════════════════════════
   NAV SECTION LABELS
══════════════════════════════════════════════════════ */
.nav-section-label{
  font-size:10px;font-weight:800;text-transform:uppercase;
  letter-spacing:.1em;color:var(--t3);
  padding:14px 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}
  .team-grid{padding:16px 16px}
  .wp-grid{padding:16px}
}

/* ══════════════════════════════════════════════════════
   MOBILE HAMBURGER + DRAWER
══════════════════════════════════════════════════════ */
.mob-topbar{display:none}
.hamburger{display:none}
.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,.7);pointer-events:all}
.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;
  box-shadow:4px 0 40px rgba(0,0,0,.6);
}
.mob-drawer.open{transform:translateX(0)}
.mob-drawer-brand{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 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:rgba(255,255,255,.06);border:1px solid var(--bdr);
  color:var(--t3);cursor:pointer;
  font-size:18px;padding:6px 9px;border-radius:8px;line-height:1;transition:all .15s;
}
.mob-drawer-close:hover{color:var(--np);border-color:rgba(255,78,163,.3);background:rgba(255,78,163,.1)}
.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:14px}
.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}
.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){
  .sidebar{display:none}
  .mob-topbar{
    display:flex;align-items:center;justify-content:space-between;
    padding:0 16px;height:56px;
    background:var(--bg2);
    border-bottom:1px solid var(--bdr);
    position:sticky;top:0;z-index:50;flex-shrink:0;
    box-shadow:0 2px 20px rgba(0,0,0,.4);
  }
  .mob-topbar-brand{display:flex;align-items:center;gap:10px}
  .mob-topbar-brand .brand-icon{width:32px;height:32px;font-size:15px}
  .mob-topbar-brand .brand-name{font-size:17px}
  .hamburger{
    display:flex;flex-direction:column;justify-content:center;
    gap:5px;background:rgba(255,255,255,.06);
    border:1px solid var(--bdr);cursor:pointer;
    padding:9px;border-radius:9px;
    transition:all .15s;
    -webkit-tap-highlight-color:transparent;
  }
  .hamburger:hover{background:rgba(255,78,163,.08);border-color:rgba(255,78,163,.3)}
  .hamburger span{
    display:block;width:20px;height:2px;border-radius:2px;
    background:var(--ng);transition:all .3s;transform-origin:center;
    box-shadow:0 0 4px rgba(255,78,163,.5);
  }
  .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)}
  .app-layout{display:flex;flex-direction:column;height:100vh}
  .app-main{flex:1;overflow-y:auto;height:auto}
  .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:12px;overflow-x:auto}
  .tbl{min-width:500px}
  .tbl th,.tbl td{padding:10px}
  .auth-wrap{flex-direction:column}
  .auth-left{display:none}
  .auth-right{width:100%;padding:32px 24px}
  .page-title{font-size:21px}
  .app-header{padding:14px 14px 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}
  .team-grid{padding:12px;grid-template-columns:1fr}
  .wp-grid{padding:12px;grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
  .modal{padding:12px}
  .modal-box{border-radius:16px}
  .modal-body{padding:16px 18px}
  .modal-hdr{padding:16px 18px}
  .modal-ftr{padding:12px 18px}
  .action-bar{padding:12px 14px 20px}
  .section-label{padding:14px 14px 4px}
}

/* ══════════════════════════════════════════════════════
   ANIMATIONS & UTILITIES
══════════════════════════════════════════════════════ */
@keyframes plSpin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes shimmer{
  0%{background-position:-200% center}
  100%{background-position:200% center}
}

.spin{animation:plSpin .8s linear infinite}
.pulse{animation:pulse 1.5s ease-in-out infinite}

/* Neon text glow utilities */
.glow-green{text-shadow:0 0 10px rgba(255,78,163,.6),0 0 20px rgba(255,78,163,.3)}
.glow-pink{text-shadow:0 0 10px rgba(255,78,163,.6),0 0 20px rgba(255,78,163,.3)}
.glow-blue{text-shadow:0 0 10px rgba(0,212,255,.6),0 0 20px rgba(0,212,255,.3)}

/* Selection color */
::selection{background:rgba(255,78,163,.2);color:var(--t1)}

/* ══════════════════════════════════════════════════════
   TOGGLE SWITCH
══════════════════════════════════════════════════════ */
.toggle-row{display:flex;align-items:center;gap:10px}
.toggle-btn{
  position:relative;width:46px;height:26px;
  border-radius:99px;border:none;cursor:pointer;
  transition:background .25s,box-shadow .25s;
  flex-shrink:0;background:var(--bg4);
  box-shadow:inset 0 0 0 1px var(--bdr2);
}
.tog-on{
  background:#1fe4c6;
  box-shadow:inset 0 0 0 1px rgba(255,78,163,.5),0 0 10px rgba(255,78,163,.2);
}
.tog-off{background:var(--bg4);box-shadow:inset 0 0 0 1px var(--bdr2)}
.tog-knob{
  position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;
  background:#fff;transition:transform .25s cubic-bezier(.4,0,.2,1),background .25s;
  box-shadow:0 1px 4px rgba(0,0,0,.4);
}
.tog-on .tog-knob{
  transform:translateX(20px);
  background:var(--ng);
  box-shadow:0 0 6px rgba(255,78,163,.6);
}

/* ══════════════════════════════════════════════════════
   SEARCH BAR
══════════════════════════════════════════════════════ */
.search-bar{
  display:flex;align-items:center;
  background:var(--bg3);
  border:1px solid var(--bdr);
  border-radius:10px;
  padding:0 12px;
  gap:8px;
  transition:border-color .2s,box-shadow .2s;
}
.search-bar:focus-within{
  border-color:rgba(0,212,255,.4);
  box-shadow:0 0 0 3px rgba(0,212,255,.07);
}
.search-bar input{
  flex:1;background:none;border:none;outline:none;
  color:var(--t1);font-size:13px;padding:10px 0;
}
.search-bar input::placeholder{color:var(--t3)}

/* ══════════════════════════════════════════════════════
   QR CARD COMPACT
══════════════════════════════════════════════════════ */
.qr-row{display:flex;align-items:center;gap:16px;padding:16px 20px}
.qr-img{width:90px;height:90px;border-radius:8px}

/* ══════════════════════════════════════════════════════
   RIGHT COLUMN STICKY
══════════════════════════════════════════════════════ */
.client-right{
  display:flex;flex-direction:column;gap:14px;
  position:sticky;top:0;max-height:100vh;overflow-y:auto;
}

/* ══════════════════════════════════════════════════════
   TEAM MEMBERS PAGE
══════════════════════════════════════════════════════ */
.team-item{
  display:flex;align-items:flex-start;gap:16px;
  background:var(--bg2);
  border:1px solid var(--bdr);
  border-radius:16px;
  padding:18px 20px;
  transition:border-color .2s,box-shadow .2s;
  position:relative;overflow:hidden;
}
.team-item::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--np),var(--nb));
  opacity:.4;border-radius:16px 16px 0 0;
}
.team-item:hover{
  border-color:rgba(185,79,255,.25);
  box-shadow:0 4px 20px rgba(0,0,0,.3);
}
.team-ava{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg,var(--np),var(--nb));
  color:#fff;display:grid;place-items:center;
  font-family:'Syne',sans-serif;
  font-weight:800;font-size:18px;flex-shrink:0;
  box-shadow:0 0 14px rgba(255,78,163,.25);
}
.team-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}
.team-name{
  font-size:15px;font-weight:700;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.team-email{font-size:12px}
.team-perms{
  display:flex;flex-wrap:wrap;gap:6px;
  margin-top:8px;
}

/* Permission badges — ON = neon, OFF = dim */
.perm-badge{
  font-size:10px;font-weight:700;
  padding:3px 9px;border-radius:99px;
  letter-spacing:.02em;
  transition:all .15s;
}
.perm-on{
  background:rgba(255,78,163,.1);
  color:var(--ng);
  border:1px solid rgba(255,78,163,.3);
  box-shadow:0 0 6px rgba(255,78,163,.1);
}
.perm-off{
  background:rgba(255,255,255,.03);
  color:var(--t3);
  border:1px solid var(--bdr);
  text-decoration:line-through;
  opacity:.5;
}

/* Permission checkboxes in modal */
.perm-check{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;border-radius:10px;
  border:1px solid var(--bdr);
  background:var(--bg3);
  cursor:pointer;
  transition:all .15s;
  font-size:13px;color:var(--t2);
}
.perm-check:hover{
  background:var(--bg4);
  border-color:var(--bdr2);
  color:var(--t1);
}
.perm-check input[type="checkbox"]{
  accent-color:var(--ng);
  width:16px;height:16px;flex-shrink:0;cursor:pointer;
}
.perm-check:has(input:checked){
  background:rgba(255,78,163,.05);
  border-color:rgba(255,78,163,.3);
  color:var(--ng);
}

/* Team action buttons column */
.team-actions{
  display:flex;flex-direction:column;gap:6px;flex-shrink:0;
}
