/* Header dropdowns: icon buttons, favorites list, notifications, user menu, dev role switcher */

/* ── Header icon buttons + dropdown panels ── */
/* ---------- HEADER ICON BUTTONS + DROPDOWN PANELS ---------- */
.icon-btn{
  position:relative;
  width:38px;height:38px;
  display:grid;place-items:center;
  background:transparent;border:1px solid var(--line-strong);border-radius:50%;
  color:var(--ink);cursor:pointer;
  transition:background .15s, border-color .15s, color .15s;
  flex-shrink:0;
}
.icon-btn:hover{background:var(--surface-2);border-color:var(--ink-dim)}
.icon-btn.active{background:var(--surface-2);border-color:var(--accent);color:var(--accent)}
.icon-btn svg{width:16px;height:16px}
.icon-btn .badge{
  position:absolute;top:-3px;right:-3px;
  min-width:18px;height:18px;padding:0 5px;border-radius:999px;
  background:var(--accent-2);color:#fff;
  font-family:"JetBrains Mono",monospace;font-size:9.5px;font-weight:700;
  display:grid;place-items:center;letter-spacing:-0.02em;
  border:2px solid var(--bg);
}
/* Preserve grid layout when badge is shown via data-show-for */
body[data-role="member"] .icon-btn .badge[data-show-for~="signed-in"],
body[data-role="editor"] .icon-btn .badge[data-show-for~="signed-in"],
body[data-role="chief"] .icon-btn .badge[data-show-for~="signed-in"],
body[data-role="admin"] .icon-btn .badge[data-show-for~="signed-in"]{display:grid !important}
.icon-btn .badge.dot{
  width:11px;height:11px;min-width:11px;padding:0;
  background:var(--accent);border:2px solid var(--bg);
}

.header-dropdown{position:relative}
.dropdown-panel{
  position:absolute;top:calc(100% + 12px);right:0;z-index:90;
  width:380px;
  background:var(--surface);
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  box-shadow:0 24px 60px -12px rgba(0,0,0,.7), 0 0 0 1px rgba(212,255,62,.02);
  opacity:0;transform:translateY(-8px) scale(.97);
  pointer-events:none;
  transition:opacity .18s, transform .22s cubic-bezier(.2,.9,.3,1);
  overflow:hidden;
}
.dropdown-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

.dd-head{
  padding:14px 18px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:10px;
}
.dd-head h4{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-soft);margin:0;font-weight:600;
}
.dd-head .dd-action{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-dim);cursor:pointer;background:transparent;border:0;font-weight:500;
  transition:color .15s;
}
.dd-head .dd-action:hover{color:var(--accent)}


/* ── Favorites list ── */
/* ----- Favorites list ----- */
.fav-list{max-height:380px;overflow-y:auto;padding:6px 0}
.fav-list::-webkit-scrollbar{width:6px}
.fav-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}

.fav-item{
  display:flex;gap:12px;padding:10px 18px;align-items:center;
  transition:background .15s, opacity .2s, transform .2s;cursor:pointer;
}
.fav-item:hover{background:var(--surface-2)}
.fav-thumb{
  width:54px;height:40px;flex-shrink:0;border-radius:6px;overflow:hidden;
  border:1px solid var(--line);position:relative;
}
.fav-thumb-art{position:absolute;inset:0}
.fav-content{flex:1;min-width:0}
.fav-content h5{
  font-family:"Fraunces",serif;font-weight:500;font-size:13.5px;margin:0 0 3px;
  letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.fav-content .meta{
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;
}
.fav-content .meta b{color:var(--accent);font-weight:700}
.fav-item .remove{
  width:26px;height:26px;border-radius:7px;
  display:grid;place-items:center;color:var(--ink-dim);
  opacity:0;transition:opacity .15s, color .15s, background .15s;
  flex-shrink:0;background:transparent;border:0;cursor:pointer;
}
.fav-item:hover .remove{opacity:1}
.fav-item .remove:hover{color:var(--accent-2);background:var(--bg-2)}
.fav-item .remove svg{width:13px;height:13px}

.dd-foot{
  padding:12px 18px;border-top:1px solid var(--line);
  display:flex;justify-content:center;background:var(--bg-2);
}
.dd-foot a, .dd-foot button{
  font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-soft);font-weight:600;display:inline-flex;align-items:center;gap:6px;
  transition:color .15s, gap .15s;
  background:transparent;border:0;cursor:pointer;padding:0;
}
.dd-foot a:hover, .dd-foot button:hover{color:var(--accent);gap:10px}


/* ── Notifications ── */
/* ----- Notifications ----- */
.notif-welcome{
  padding:16px 18px;display:flex;gap:12px;align-items:flex-start;
  border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,rgba(212,255,62,.06),transparent 70%);
  position:relative;
}
.notif-welcome::before{
  content:"";position:absolute;top:12px;left:8px;width:4px;height:4px;
  background:var(--accent);border-radius:50%;
}
.notif-welcome .shield{
  width:36px;height:36px;border-radius:10px;background:var(--bg-2);border:1px solid var(--line);
  display:grid;place-items:center;flex-shrink:0;color:var(--accent);
}
.notif-welcome .shield svg{width:16px;height:16px}
.notif-welcome .content{flex:1;min-width:0}
.notif-welcome h5{
  font-family:"Fraunces",serif;font-weight:500;font-size:15px;margin:0 0 4px;letter-spacing:-0.01em;
}
.notif-welcome h5 em{font-style:italic;color:var(--accent);font-weight:400}
.notif-welcome p{
  margin:0 0 6px;font-size:12.5px;color:var(--ink-soft);line-height:1.5;
}
.notif-welcome ul{
  margin:4px 0 10px;padding-left:18px;font-size:12.5px;color:var(--ink-soft);line-height:1.7;
  list-style:none;
}
.notif-welcome ul li{position:relative}
.notif-welcome ul li::before{
  content:"";position:absolute;left:-14px;top:9px;width:4px;height:1px;background:var(--accent);
}
.notif-welcome .time{
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;display:block;margin-top:8px;
}
.notif-welcome .cta{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:10px;padding:8px 14px;border-radius:8px;
  background:var(--accent);color:#0b0b0a;
  font-family:inherit;font-size:12.5px;font-weight:600;
  border:0;cursor:pointer;
  transition:background .15s;
}
.notif-welcome .cta:hover{background:#c3f029}
.notif-welcome .cta svg{width:13px;height:13px}

.notif-list{max-height:300px;overflow-y:auto}
.notif-list::-webkit-scrollbar{width:6px}
.notif-list::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:3px}

.notif-item{
  display:flex;gap:12px;padding:12px 18px;align-items:flex-start;
  border-bottom:1px solid var(--line);transition:background .15s;cursor:pointer;
  position:relative;
}
.notif-item:last-child{border-bottom:0}
.notif-item:hover{background:var(--surface-2)}
.notif-item.unread::after{
  content:"";position:absolute;left:8px;top:18px;width:4px;height:4px;
  background:var(--accent);border-radius:50%;
}
.notif-item .ico{
  width:30px;height:30px;border-radius:8px;flex-shrink:0;
  display:grid;place-items:center;
}
.notif-item .ico.drop{background:rgba(212,255,62,.12);color:var(--accent)}
.notif-item .ico.sale{background:rgba(255,92,41,.15);color:var(--accent-2)}
.notif-item .ico.system{background:rgba(108,92,231,.15);color:#a594f7}
.notif-item .ico.reply{background:rgba(0,212,255,.12);color:#00d4ff}
.notif-item .ico svg{width:13px;height:13px}
.notif-item .body{flex:1;min-width:0}
.notif-item .body p{margin:0;font-size:13px;color:var(--ink);line-height:1.4}
.notif-item .body p b{font-weight:600;color:var(--ink)}
.notif-item .body .time{
  display:block;margin-top:4px;
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;
}

@media (max-width:640px){
  .dropdown-panel{width:calc(100vw - 40px);right:-10px}
}


/* ── User menu (signed-in state) ── */
/* ---------- USER MENU (signed-in state) ---------- */
.user-btn{
  display:inline-flex;align-items:center;gap:9px;
  padding:4px 14px 4px 4px;border-radius:999px;
  background:var(--surface);border:1px solid var(--line-strong);
  color:var(--ink);cursor:pointer;font-family:inherit;
  transition:background .15s, border-color .15s;
}
.user-btn:hover{background:var(--surface-2);border-color:var(--ink-dim)}
.user-btn.active{background:var(--surface-2);border-color:var(--accent)}
.user-avatar{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  font-family:"Fraunces",serif;font-weight:600;font-style:italic;font-size:14px;
  color:#0b0b0a;letter-spacing:-0.02em;
  border:1px solid rgba(0,0,0,.25);
}
.user-avatar.role-member{background:linear-gradient(135deg,#b9b2a1,#7a7466)}
.user-avatar.role-editor{background:linear-gradient(135deg,#00d4ff,#0099cc)}
.user-avatar.role-chief{background:linear-gradient(135deg,#a594f7,#6c5ce7)}
.user-avatar.role-admin{background:linear-gradient(135deg,#d4ff3e,#a8e018)}
.user-btn .uname{
  font-size:13px;font-weight:500;line-height:1;
  display:flex;flex-direction:column;gap:3px;align-items:flex-start;
}
.user-btn .uname .role{
  font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;font-weight:600;
}
.user-btn.active .uname .role,.user-btn:hover .uname .role{color:var(--accent)}
.user-btn .chev{width:13px;height:13px;color:var(--ink-dim);transition:transform .15s}
.user-btn.active .chev{transform:rotate(180deg);color:var(--accent)}

/* User menu dropdown panel */
.user-panel{
  position:absolute;top:calc(100% + 12px);right:0;z-index:90;
  width:320px;
  background:var(--surface);
  border:1px solid var(--line-strong);
  border-radius:var(--radius);
  box-shadow:0 24px 60px -12px rgba(0,0,0,.7), 0 0 0 1px rgba(212,255,62,.02);
  opacity:0;transform:translateY(-8px) scale(.97);
  pointer-events:none;
  transition:opacity .18s, transform .22s cubic-bezier(.2,.9,.3,1);
  overflow:hidden;
}
.user-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

/* User profile card (top) */
.user-card{
  padding:18px;
  background:linear-gradient(135deg,rgba(212,255,62,.04),transparent 80%);
  border-bottom:1px solid var(--line);
  display:flex;gap:14px;align-items:center;position:relative;
}
.user-card .avatar-big{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  display:grid;place-items:center;
  font-family:"Fraunces",serif;font-weight:600;font-style:italic;font-size:20px;
  color:#0b0b0a;letter-spacing:-0.02em;
  border:2px solid rgba(0,0,0,.3);
}
.user-card .uinfo{flex:1;min-width:0}
.user-card .uname-big{
  font-family:"Fraunces",serif;font-weight:500;font-size:17px;
  letter-spacing:-0.01em;margin:0;line-height:1.1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.user-card .email{
  font-size:11.5px;color:var(--ink-dim);margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.user-card .role-badge{
  display:inline-flex;align-items:center;gap:5px;margin-top:6px;
  padding:2px 8px;border-radius:999px;
  font-family:"JetBrains Mono",monospace;font-size:9.5px;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
}
.role-badge::before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}
.role-badge.role-member{background:rgba(185,178,161,.15);color:#b9b2a1}
.role-badge.role-editor{background:rgba(0,212,255,.12);color:#00d4ff}
.role-badge.role-chief{background:rgba(165,148,247,.15);color:#a594f7}
.role-badge.role-admin{background:rgba(212,255,62,.12);color:var(--accent)}
.user-card .view-profile{
  position:absolute;top:16px;right:16px;
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-dim);font-weight:600;
  transition:color .15s;
}
.user-card .view-profile:hover{color:var(--accent)}

/* Menu sections */
.user-sec{padding:6px 0;border-bottom:1px solid var(--line)}
.user-sec:last-child{border-bottom:0}
.user-sec .label{
  padding:10px 18px 6px;
  font-family:"JetBrains Mono",monospace;font-size:9.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-dim);font-weight:600;
}
.user-item{
  display:flex;align-items:center;gap:12px;
  padding:9px 18px;font-size:13.5px;color:var(--ink-soft);
  cursor:pointer;transition:background .15s, color .15s;
  background:transparent;border:0;width:100%;text-align:left;font-family:inherit;
  white-space:nowrap;
}
.user-item:hover{background:var(--surface-2);color:var(--ink)}
.user-item .uico{
  width:18px;height:18px;flex-shrink:0;color:var(--ink-dim);
}
.user-item:hover .uico{color:var(--accent)}
.user-item .utext{
  flex:1;display:flex;align-items:center;gap:8px;
  min-width:0;overflow:hidden;text-overflow:ellipsis;
}
.user-item .utext > span:first-child{
  flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0;
}
.user-item .count{
  font-family:"JetBrains Mono",monospace;font-size:10px;
  padding:1px 7px;border-radius:999px;flex-shrink:0;
  background:var(--bg-2);border:1px solid var(--line);color:var(--ink-dim);font-weight:600;
}
.user-item .count.hot{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}
.user-item .count.accent{background:rgba(212,255,62,.15);color:var(--accent);border-color:rgba(212,255,62,.3)}
.user-item.logout{color:#ff6b4a}
.user-item.logout:hover{background:rgba(255,92,41,.08);color:#ff8060}
.user-item.logout .uico{color:#ff6b4a}

/* Others submenu inside user panel */
.user-others-btn .chev-mini{
  width:12px;height:12px;margin-left:auto;flex-shrink:0;
  transition:transform .2s;color:var(--ink-dim);
}
.user-others-btn[aria-expanded="true"] .chev-mini{transform:rotate(180deg)}
.user-others-btn[aria-expanded="true"]{color:var(--ink);background:var(--surface-2)}

.user-others-panel{
  max-height:0;overflow:hidden;
  transition:max-height .25s ease;
  background:rgba(0,0,0,.25);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.user-others-panel.open{max-height:300px;border-top:1px solid var(--line)}
.user-others-panel:not(.open){border-top:0;border-bottom:0}

.user-item.user-sub{
  padding-left:46px;font-size:13px;
  background:transparent;
}
.user-item.user-sub:hover{background:var(--surface-2)}
.user-item.user-sub .uico{width:15px;height:15px}

/* Member hides followers in user menu too */
body[data-role="member"] .user-item.editor-only{display:none !important}

/* Administrator row — lime themed */
.user-item.user-admin{color:var(--accent)}
.user-item.user-admin .uico{color:var(--accent)}
.user-item.user-admin:hover{background:rgba(212,255,62,.06);color:var(--accent)}

/* Night mode toggle + schedule */
.night-toggle{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:9px 18px;font-size:13.5px;color:var(--ink-soft);
}
.night-toggle .left{display:flex;align-items:center;gap:12px}
.night-toggle .uico{width:18px;height:18px;color:var(--ink-dim)}
.toggle-switch{
  width:36px;height:20px;border-radius:999px;
  background:var(--line-strong);
  position:relative;cursor:pointer;flex-shrink:0;
  transition:background .2s;
  border:0;
}
.toggle-switch::after{
  content:"";position:absolute;top:2px;left:2px;
  width:16px;height:16px;border-radius:50%;background:var(--ink-soft);
  transition:transform .2s, background .2s;
}
.toggle-switch.on{background:var(--accent)}
.toggle-switch.on::after{transform:translateX(16px);background:#0b0b0a}

.night-schedule{
  padding:4px 18px 8px;display:none;
  background:var(--bg-2);border-top:1px solid var(--line);
}
.night-schedule.open{display:block}
.schedule-row{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:10px 0;font-size:12.5px;color:var(--ink-dim);
}
.schedule-row + .sch-time[style*="flex"]{border-top:1px dashed var(--line)}
.sch-time + .sch-time[style*="flex"]{border-top:1px dashed var(--line)}
.sch-time{
  display:none;
  animation:rise .2s ease both;
}
.schedule-row .scheck{
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;
}
.scheck input{display:none}
.scheck .sbox{
  width:14px;height:14px;border-radius:4px;flex-shrink:0;
  background:var(--surface);border:1px solid var(--line-strong);
  display:grid;place-items:center;transition:background .15s, border-color .15s;
}
.scheck input:checked + .sbox{background:var(--accent);border-color:var(--accent)}
.scheck .sbox svg{width:9px;height:9px;color:#0b0b0a;opacity:0;transition:opacity .15s}
.scheck input:checked + .sbox svg{opacity:1}
.time-sel{
  padding:5px 9px;border-radius:6px;
  background:var(--surface);border:1px solid var(--line);color:var(--ink);
  font:inherit;font-size:11.5px;font-family:"JetBrains Mono",monospace;
  cursor:pointer;outline:0;
  transition:border-color .15s;
}
.time-sel:hover{border-color:var(--line-strong)}
.time-sel:focus{border-color:var(--accent)}


/* ── Dev role switcher (floating bottom-right) ── */
/* ---------- DEV ROLE SWITCHER (floating bottom-right) ---------- */
.dev-switcher{
  position:fixed;bottom:20px;right:20px;z-index:95;
  font-family:"JetBrains Mono",monospace;
}
.dev-btn{
  width:48px;height:48px;border-radius:50%;
  background:var(--surface);border:1px solid var(--line-strong);
  color:var(--ink);cursor:pointer;
  display:grid;place-items:center;
  box-shadow:0 10px 30px -8px rgba(0,0,0,.6);
  transition:background .15s, border-color .15s, transform .15s;
  position:relative;
}
.dev-btn:hover{background:var(--surface-2);border-color:var(--accent);transform:translateY(-2px)}
.dev-btn svg{width:18px;height:18px}
.dev-btn .dev-tag{
  position:absolute;top:-6px;right:-6px;
  padding:2px 6px;border-radius:999px;
  background:var(--accent-2);color:#fff;
  font-family:"JetBrains Mono",monospace;font-size:8px;letter-spacing:.1em;font-weight:700;
  border:2px solid var(--bg);
}

.dev-panel{
  position:absolute;bottom:calc(100% + 10px);right:0;
  width:260px;
  background:var(--surface);border:1px solid var(--line-strong);
  border-radius:12px;overflow:hidden;
  opacity:0;transform:translateY(8px) scale(.97);pointer-events:none;
  transition:opacity .15s, transform .2s;
  box-shadow:0 20px 50px -10px rgba(0,0,0,.7);
}
.dev-panel.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.dev-head{
  padding:12px 16px;border-bottom:1px solid var(--line);
  background:linear-gradient(135deg,rgba(255,92,41,.05),transparent);
}
.dev-head h5{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent-2);margin:0 0 3px;font-weight:700;
}
.dev-head p{
  font-size:10.5px;color:var(--ink-dim);margin:0;letter-spacing:.05em;
  font-family:"Geist",sans-serif;
}
.dev-list{padding:6px}
.dev-role{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 10px;border-radius:7px;
  background:transparent;border:0;color:var(--ink-soft);
  cursor:pointer;font-family:inherit;font-size:12.5px;text-align:left;
  transition:background .15s, color .15s;
}
.dev-role:hover{background:var(--bg-2);color:var(--ink)}
.dev-role.on{background:var(--bg-2);color:var(--ink)}
.dev-role.on::after{content:"✓";color:var(--accent);margin-left:auto;font-weight:700}
.dev-role .rdot{
  width:10px;min-width:10px;max-width:10px;
  height:10px;min-height:10px;max-height:10px;
  border-radius:50%;flex-shrink:0;flex-grow:0;
  border:2px solid rgba(0,0,0,.3);box-sizing:content-box;
}
.dev-role .rdot.guest{background:#555}
.dev-role .rdot.member{background:#b9b2a1}
.dev-role .rdot.editor{background:#00d4ff}
.dev-role .rdot.chief{background:#a594f7}
.dev-role .rdot.admin{background:var(--accent)}
.dev-role .rname{font-family:"Geist",sans-serif}
.dev-role .rmono{
  font-family:"JetBrains Mono",monospace;font-size:9px;letter-spacing:.14em;
  color:var(--ink-dim);text-transform:uppercase;margin-left:auto;
}
.dev-role.on .rmono{display:none}

/* Role-based visibility toggles */
[data-show-for]{display:none !important}
body[data-role="guest"] [data-show-for~="guest"],
body[data-role="member"] [data-show-for~="member"],
body[data-role="member"] [data-show-for~="signed-in"],
body[data-role="editor"] [data-show-for~="editor"],
body[data-role="editor"] [data-show-for~="signed-in"],
body[data-role="chief"] [data-show-for~="chief"],
body[data-role="chief"] [data-show-for~="editor"],
body[data-role="chief"] [data-show-for~="signed-in"],
body[data-role="admin"] [data-show-for~="admin"],
body[data-role="admin"] [data-show-for~="chief"],
body[data-role="admin"] [data-show-for~="editor"],
body[data-role="admin"] [data-show-for~="signed-in"]{display:inherit !important}

/* Force correct display for known elements */
body[data-role="member"] .user-btn,
body[data-role="editor"] .user-btn,
body[data-role="chief"] .user-btn,
body[data-role="admin"] .user-btn{display:inline-flex !important}

body[data-role="member"] .header-actions > .btn,
body[data-role="editor"] .header-actions > .btn,
body[data-role="chief"] .header-actions > .btn,
body[data-role="admin"] .header-actions > .btn{display:none !important}

/* Force flex layout for visible user-items (buttons) — display:inherit breaks button flex
   Each body-role must only force flex for items that match its permissions. */
body[data-role="member"] .user-item[data-show-for~="member"],
body[data-role="member"] .user-item[data-show-for~="signed-in"],
body[data-role="editor"] .user-item[data-show-for~="editor"],
body[data-role="editor"] .user-item[data-show-for~="signed-in"],
body[data-role="chief"] .user-item[data-show-for~="chief"],
body[data-role="chief"] .user-item[data-show-for~="editor"],
body[data-role="chief"] .user-item[data-show-for~="signed-in"],
body[data-role="admin"] .user-item[data-show-for~="admin"],
body[data-role="admin"] .user-item[data-show-for~="chief"],
body[data-role="admin"] .user-item[data-show-for~="editor"],
body[data-role="admin"] .user-item[data-show-for~="signed-in"]{display:flex !important}

/* Force inline-flex for visible profile tabs — only matching roles */
body[data-role="editor"] .p-tab[data-show-for~="editor"],
body[data-role="editor"] .p-tab[data-show-for~="signed-in"],
body[data-role="chief"] .p-tab[data-show-for~="chief"],
body[data-role="chief"] .p-tab[data-show-for~="editor"],
body[data-role="chief"] .p-tab[data-show-for~="signed-in"],
body[data-role="admin"] .p-tab[data-show-for~="admin"],
body[data-role="admin"] .p-tab[data-show-for~="chief"],
body[data-role="admin"] .p-tab[data-show-for~="editor"],
body[data-role="admin"] .p-tab[data-show-for~="signed-in"]{display:inline-flex !important}

/* Editor/Chief/Admin: hide the 4 tabs that live inside "Others" dropdown */
body[data-role="member"] .p-tab.hide-editor-plus,
body[data-role="editor"] .p-tab.hide-editor-plus,
body[data-role="chief"]  .p-tab.hide-editor-plus,
body[data-role="admin"]  .p-tab.hide-editor-plus{display:none !important}

/* Member: hide "Followers" from Others dropdown (member has no followers tab) */
body[data-role="member"] .others-item.editor-only,
body[data-role="guest"]  .others-item.editor-only{display:none !important}

/* Force flex for p-tab-wrap (Others container) when visible */
body[data-role="member"] .p-tab-wrap[data-show-for],
body[data-role="editor"] .p-tab-wrap[data-show-for],
body[data-role="chief"]  .p-tab-wrap[data-show-for],
body[data-role="admin"]  .p-tab-wrap[data-show-for]{display:block !important}

/* Others dropdown */
.p-tab-wrap{position:relative;display:none}
.p-tab-wrap > .p-tab{display:inline-flex}
.p-tab-wrap > .p-tab .chev{width:12px;height:12px;transition:transform .15s;margin-left:-2px}
.p-tab-wrap.open > .p-tab .chev{transform:rotate(180deg)}
.p-tab-wrap.open > .p-tab{color:var(--ink)}

.others-menu{
  position:absolute;top:calc(100% + 2px);left:0;min-width:220px;z-index:1000;
  background:var(--surface);border:1px solid var(--line-strong);border-radius:10px;
  padding:6px;box-shadow:0 12px 32px -6px rgba(0,0,0,.6);
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .15s, transform .15s;
}
.p-tab-wrap.open .others-menu{opacity:1;transform:translateY(0);pointer-events:auto}
.others-item{
  display:flex;align-items:center;gap:10px;width:100%;
  padding:9px 12px;border-radius:7px;
  background:transparent;border:0;color:var(--ink-soft);cursor:pointer;
  font:inherit;font-size:13px;text-align:left;
  transition:background .15s, color .15s;
}
.others-item:hover{background:var(--surface-2);color:var(--ink)}
.others-item.active{background:rgba(212,255,62,.08);color:var(--accent)}
.others-item > span:first-of-type{flex:1}
.others-item svg{width:14px;height:14px;color:var(--ink-dim);flex-shrink:0}
.others-item:hover svg,
.others-item.active svg{color:var(--accent)}
.others-item .c{
  font-family:"JetBrains Mono",monospace;font-size:10px;padding:2px 7px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:999px;
  color:var(--ink-dim);
}
.others-item.active .c{background:rgba(212,255,62,.12);color:var(--accent);border-color:rgba(212,255,62,.3)}

/* Overview grid — no stats for member (collapse to single column) */
body[data-role="member"] .overview-grid,
body[data-role="guest"] .overview-grid{grid-template-columns:1fr}

/* Force flex for visible overview stats */
body[data-role="editor"] #overviewStats[data-show-for],
body[data-role="chief"] #overviewStats[data-show-for],
body[data-role="admin"] #overviewStats[data-show-for]{display:flex !important}

@media (max-width:640px){
  .user-panel{width:calc(100vw - 40px);right:-10px}
  .user-btn .uname{display:none}
  .dev-switcher{bottom:14px;right:14px}
}

