/* ===== Sidebar Drawer (mobile + desktop consistent) ===== */
:root{
  --sb-bg: #122338;
  --app-bg: rgba(255,255,255,.55);
  --app-border: rgba(15,23,42,.08);
  --app-icon-bg: rgba(255,255,255,.85);
  --app-icon-border: rgba(0,0,0,.10);
  --app-icon-color: #0f172a;
  --app-title: #0f172a;
  --app-subtitle: rgba(15,23,42,.72);
  --sb-bg2:#0e1c2f;
  --sb-text:#eaf2ff;
  --sb-muted: rgba(234,242,255,.75);
  --sb-border: rgba(255,255,255,.14);
  --sb-card: rgba(255,255,255,.06);
  --sb-accent: rgba(79,155,246,.25);
  --sb-accent2: rgba(79,155,246,.45);
  --sb-shadow: 0 20px 60px rgba(0,0,0,.45);
  --appTop-h: 64px;
}

/* Hide any legacy horizontal menu row if still present */
.nav, .topbar, .navRow, .legacyTopbar, .navlink { display:none !important; }

body.hasSidebar{ padding-top: var(--appTop-h); }

/* Top app bar */
.appTop{
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--appTop-h);
  display:flex;
  align-items:center;
  gap:12px;
  padding: 10px 14px;
  z-index: 1200;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: var(--app-bg);
  border-bottom: 1px solid var(--app-border);
}
.appTitle{ line-height:1.1; min-width: 0; }
.appTitle .t1{ font-weight: 800; letter-spacing: .08em; font-size: 13px; opacity:.95; color: var(--app-title); }
.appTitle .t2{ font-weight: 600; font-size: 12px; opacity:.85; color: var(--app-subtitle); }
.appRight{ margin-left:auto; display:flex; align-items:center; gap:10px; }

.iconBtn{
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid var(--app-icon-border);
  background: var(--app-icon-bg);
  color: var(--app-icon-color);
  box-shadow: 0 10px 26px rgba(0,0,0,.12);
  display:flex; align-items:center; justify-content:center;
  font-size: 18px; line-height:1;
  cursor:pointer;
}
.iconBtn:hover{ transform: translateY(-1px); }
.iconBtn:active{ transform: translateY(0); }

/* Overlay */
.sbOverlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1400;
}
body.sb-open .sbOverlay{ display:block; }
body:not(.sb-open) .sbOverlay{ display:none; }

/* Drawer */
.sbDrawer{
  position: fixed;
  inset: 0 auto 0 0;
  width: min(360px, 86vw);
  background: linear-gradient(180deg, var(--sb-bg), var(--sb-bg2));
  color: var(--sb-text);
  z-index: 1500;
  box-shadow: var(--sb-shadow);
  transform: translateX(-110%);
  transition: transform .22s ease;
  display:flex;
  flex-direction: column;
}
body.sb-open .sbDrawer{
  transform: translateX(0);
}
.sbHead{
  display:flex;
  align-items:flex-start;
  justify-content: space-between;
  gap: 10px;
  padding: 18px 16px 12px;
}
.sbHeadText .sbApp{
  font-weight: 800;
  letter-spacing: .10em;
  font-size: 12px;
  color: var(--sb-text);
}
.sbHeadText .sbSub{
  margin-top: 4px;
  font-size: 12px;
  color: var(--sb-muted);
}
.sbCloseBtn{
  width: 40px; height: 40px;
  border-radius: 12px;
  border: 1px solid var(--sb-border);
  background: rgba(255,255,255,.07);
  color: var(--sb-text);
  cursor:pointer;
  font-size: 20px;
  display:flex; align-items:center; justify-content:center;
}
.sbNav{
  padding: 8px 14px 12px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.sbItem{
  width: 100%;
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 14px 14px;
  border-radius: 14px;
  border: 1px solid var(--sb-border);
  background: rgba(255,255,255,.06);
  color: var(--sb-text);
  text-decoration:none;
  font-weight: 650;
  letter-spacing: .01em;
}
.sbItem:hover{ background: rgba(255,255,255,.09); }
.sbItem.is-active{
  background: var(--sb-accent);
  border-color: var(--sb-accent2);
  box-shadow: 0 14px 30px rgba(147, 193, 248, 0.18);
}
.sbIco{
  width: 26px;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity: .95;
}
.sbFoot{
  margin-top:auto;
  padding: 12px 14px 16px;
}
.sbDanger{
  background: rgba(255,255,255,.05);
}

/* Make page content not clipped under fixed top bar in some pages with their own wrappers */
.wrap, main.wrap, .container, .page{ position: relative; z-index: 1; }
/* Make page content not clipped under fixed top bar in some pages with their own wrappers */
.wrap, main.wrap, .container, .page{ position: relative; z-index: 1; }

/* Sidebar contrast + badge */
.sbDrawer,
.sbDrawer .sbItem,
.sbDrawer .sbHeadText .sbApp,
.sbDrawer .sbHeadText .sbSub,
.sbDrawer .sbDanger{
  color: #F8FAFC;
}

.sbDrawer .sbItem{
  opacity: 1;
}

.sbDrawer .sbItem .sbIco,
.sbDrawer .sbItem span,
.sbDrawer .sbItem svg{
  color: inherit;
  fill: currentColor;
}

.sbDrawer .sbItem:hover{
  color: #FFFFFF;
  background: rgba(255,255,255,.10);
}

.sbDrawer .sbItem.is-active,
.sbDrawer .sbItem.active{
  color: #FFFFFF;
  background: rgba(59,130,246,.28);
  border-color: rgba(59,130,246,.45);
}

.sbBadge{
  margin-left:auto;
  min-width:24px;
  height:22px;
  padding:0 8px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
  background: rgba(255,255,255,.14);
  color: #ffffff;
  border: 1px solid rgba(255,255,255,.16);
}


.themeToggleBtn .themeToggleIcon{ font-size:18px; line-height:1; }
.themeToggleSide{ margin-bottom: 10px; }
.themeToggleSide .themeToggleText{ font-weight: 700; }

body[data-theme="dark"]{
  --app-bg: rgba(20,20,22,.92);
  --app-border: rgba(255,255,255,.08);
  --app-icon-bg: #1b1c20;
  --app-icon-border: rgba(255,255,255,.10);
  --app-icon-color: #f4f4f5;
  --app-title: #fafafa;
  --app-subtitle: #9ca3af;
  --sb-bg: #141416;
  --sb-bg2: #17181c;
  --sb-text: #f4f4f5;
  --sb-muted: #a1a1aa;
  --sb-border: rgba(255,255,255,.08);
  --sb-card: rgba(255,255,255,.03);
  --sb-accent: rgba(89,191,214,.16);
  --sb-accent2: rgba(89,191,214,.30);
  --sb-shadow: 0 20px 60px rgba(0,0,0,.50);
}

body[data-theme="dark"] .appTop{
  background: rgba(18,18,18,.94);
  border-bottom-color: rgba(255,255,255,.08);
}

body[data-theme="dark"] .iconBtn,
body[data-theme="dark"] .sbCloseBtn{
  background: #1c1d21;
  border-color: rgba(255,255,255,.10);
  color: #f4f4f5;
  box-shadow: none;
}

body[data-theme="dark"] .iconBtn:hover,
body[data-theme="dark"] .sbCloseBtn:hover{
  background: #23252b;
}

body[data-theme="dark"] .sbDrawer{
  background: linear-gradient(180deg, #141416, #17181c);
}

body[data-theme="dark"] .sbItem{
  background: rgba(255,255,255,.02);
  border-color: rgba(255,255,255,.06);
}

body[data-theme="dark"] .sbItem:hover{
  background: rgba(255,255,255,.05);
}

body[data-theme="dark"] .sbItem.is-active,
body[data-theme="dark"] .sbItem.active{
  background: rgba(89,191,214,.14);
  border-color: rgba(89,191,214,.28);
  box-shadow: none;
}

body[data-theme="dark"] .sbBadge{
  background: rgba(89,191,214,.14);
  border-color: rgba(89,191,214,.26);
  color: #dcf7ff;
}
