/* =========================================================
   NEON GAMING THEME — Sidebar (Global)
   Berlaku di semua halaman yang include includes/sidebar.php
   ========================================================= */

:root{
  --sb-purple:#a855f7;
  --sb-pink:#ec4899;
  --sb-gold:#fbbf24;
  --sb-bg:#0f0720;
  --sb-bg2:#180b2e;
}

/* ====== OVERLAY — full screen cover ====== */
.as-sidebar-overlay{
  /* main.css punya inset: 70px 0 0 0 (tidak full screen).
     Override ke inset: 0 supaya cover seluruh layar termasuk area atas */
  position: fixed !important;
  inset: 0 !important;
  z-index: 9000 !important;       /* di bawah sidebar (10040) tapi di atas konten */
  background: rgba(0,0,0,.72) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  cursor: pointer !important;
  pointer-events: none;            /* default off — diaktifkan saat sidebar open */
}

body.as-sidebar-open .as-sidebar-overlay{
  pointer-events: auto !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* ====== SIDEBAR CONTAINER ====== */
.as-sidebar{
  background: var(--sb-bg) !important;
  box-shadow:
    4px 0 32px rgba(0,0,0,.6),
    inset -1px 0 0 rgba(168,85,247,.15) !important;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  z-index: 10050 !important;     /* WAJIB di atas .as-sidebar-overlay (9000) */
}

/* ====== HEADER (Menu + X) ====== */
.as-sidebar-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 16px 14px !important;
  border-bottom: 1px solid rgba(168,85,247,.12) !important;
  background: rgba(168,85,247,.06);
  flex-shrink: 0;
}

.as-sidebar-title{
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.5) !important;
}

.as-sidebar-close{
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.7) !important;
  font-size: 18px !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s ease;
  line-height: 1;
}
.as-sidebar-close:hover{
  background: rgba(239,68,68,.15) !important;
  border-color: rgba(239,68,68,.3) !important;
  color: #fff !important;
}

/* ====== USER SECTION ====== */
.as-sidebar-user{
  padding: 16px !important;
  border-bottom: 1px solid rgba(255,255,255,.05) !important;
  background: var(--sb-bg2);
  flex-shrink: 0;
}

.as-sidebar-user-top{
  display: flex;
  align-items: center;
  gap: 12px;
}

.as-sidebar-avatar{
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  object-fit: cover;
  box-shadow:
    0 0 0 2px var(--sb-bg),
    0 0 0 3.5px var(--sb-purple),
    0 4px 14px rgba(168,85,247,.4) !important;
  flex-shrink: 0;
}

.as-sidebar-avatar--placeholder{
  background: linear-gradient(135deg, var(--sb-purple), var(--sb-pink)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  color: #fff !important;
}

.as-sidebar-user-name{
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #fff !important;
  line-height: 1.2;
}

.as-sidebar-user-role{
  font-size: 11px !important;
  color: var(--sb-gold) !important;
  font-weight: 600 !important;
  letter-spacing: .3px;
}

/* ====== NAV CONTAINER ====== */
.as-sidebar-nav{
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 8px 0 24px !important;
  /* custom scrollbar */
  scrollbar-width: thin;
  scrollbar-color: rgba(168,85,247,.4) transparent;
}

.as-sidebar-nav::-webkit-scrollbar{ width: 4px; }
.as-sidebar-nav::-webkit-scrollbar-track{ background: transparent; }
.as-sidebar-nav::-webkit-scrollbar-thumb{
  background: rgba(168,85,247,.4);
  border-radius: 999px;
}

/* ====== NAV GROUP ====== */
.as-nav-group{
  margin-bottom: 4px;
}

/* ====== SECTION HEADING (Akun, Admin) — HANYA LABEL, TIDAK ADA ACTIVE STATE ====== */
.as-nav-heading{
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 18px 18px 6px !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: rgba(255,255,255,.38) !important;
  cursor: default !important;
  /* SELALU transparent — heading bukan clickable item */
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  text-decoration: none;
  min-height: 0 !important;
}

/* Active pada heading = TIDAK ADA STYLE — cuma label */
.as-nav-heading.active{
  background: transparent !important;
  box-shadow: none !important;
  color: rgba(255,255,255,.45) !important;
  font-weight: 800 !important;
}

.as-nav-heading .as-nav-icon{
  font-size: 13px !important;
  opacity: .6;
  width: 18px !important;
}

/* ====== BASE NAV ITEM ====== */
.as-nav-item{
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 9px 14px !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,.72) !important;
  text-decoration: none;
  border-radius: 8px !important;
  margin: 1px 8px !important;
  transition: background .15s ease, color .15s ease;
  cursor: pointer;
  min-height: 40px !important;
  line-height: 1.3;
}

.as-nav-item:hover{
  background: rgba(168,85,247,.10) !important;
  color: rgba(255,255,255,.95) !important;
}

/* ====== ACTIVE ITEM — hanya untuk sub items, bukan heading ====== */
.as-nav-sub.active,
.as-nav-item.active:not(.as-nav-heading){
  background: linear-gradient(135deg, rgba(168,85,247,.22), rgba(236,72,153,.10)) !important;
  color: #fff !important;
  font-weight: 700 !important;
  box-shadow: inset 3px 0 0 var(--sb-purple) !important;
}

/* ====== SUB ITEMS (Profil Akun, Proses Tugas, dll) ====== */
.as-nav-sub{
  padding-left: 30px !important;
  font-size: 13px !important;
  color: rgba(255,255,255,.62) !important;
  min-height: 38px !important;
}

.as-nav-sub:hover{
  background: rgba(168,85,247,.08) !important;
  color: rgba(255,255,255,.92) !important;
}

/* Active sub item TIDAK PERLU override terpisah — sudah covered di atas */

/* ====== NAV ICON ====== */
.as-nav-icon{
  font-size: 15px !important;
  flex-shrink: 0;
  width: 20px !important;
  text-align: center;
}

/* Remove "•" bullet from sub items label — keep icon clean */
.as-nav-sub .as-nav-label{
  color: inherit;
}

/* ====== SPECIAL ITEMS ====== */

/* Daftar Tugas — accent gold */
.as-nav-item[href="index.php"] .as-nav-icon,
.as-nav-item[href="index.php"]:hover .as-nav-icon{
  filter: drop-shadow(0 0 4px rgba(251,191,36,.6));
}

/* Logout — merah saat hover */
.as-nav-item[href="logout.php"]{
  color: rgba(252,165,165,.8) !important;
  margin-top: 8px;
}
.as-nav-item[href="logout.php"]:hover{
  background: rgba(239,68,68,.12) !important;
  color: #fca5a5 !important;
}

/* ====== DIVIDER antara group (sebelum standalone items) ====== */
.as-sidebar-nav > a.as-nav-item:first-of-type{
  margin-top: 6px;
  border-top: 1px solid rgba(255,255,255,.05);
  padding-top: 14px !important;
}

/* ====== MOBILE (tampilan lebih compact) ====== */
@media (max-width: 768px){
  .as-sidebar{
    width: min(300px, 85vw) !important;
  }

  .as-sidebar-header{
    padding: 16px 14px 12px !important;
  }

  .as-sidebar-user{
    padding: 14px !important;
  }

  .as-sidebar-avatar{
    width: 40px !important;
    height: 40px !important;
  }

  .as-nav-heading{
    padding: 16px 14px 5px !important;
    font-size: 10px !important;
    min-height: 0 !important;
  }

  .as-nav-item{
    padding: 9px 12px !important;
    margin: 1px 6px !important;
    font-size: 13.5px !important;
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
  }

  .as-nav-sub{
    padding-left: 26px !important;
    font-size: 13px !important;
    min-height: 40px !important;
  }
}
