/*
 * Custom sidebar polish for the POS AdminLTE shell.
 * Scoped to .app-sidebar so AdminLTE defaults remain intact elsewhere.
 */
.app-sidebar {
  width: 285px;
  background: #151b22;
  box-shadow: 5px 0 22px rgba(14, 22, 33, 0.18);
}

.app-sidebar::before {
  width: 285px;
}

.app-sidebar .brand-link {
  min-height: 70px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  background: #0f171f;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.app-sidebar .brand-mark {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 46px;
  width: 46px;
  height: 46px;
  color: #102027;
  background: #13242b;
  border: 1px solid rgba(128, 224, 199, 0.38);
  border-radius: 8px;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
}

.app-sidebar .brand-mark::before {
  content: "";
  position: absolute;
  inset: 5px;
  background: #80e0c7;
  border-radius: 7px;
  box-shadow: 0 0 0 4px rgba(128, 224, 199, 0.1);
}

.app-sidebar .brand-mark-inner {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  color: #102027;
  background: #f2b84b;
  border-radius: 7px;
  font-size: 0.95rem;
  box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.16);
}

.app-sidebar .brand-mark-inner img {
  display: block;
  width: 30px !important;
  height: 30px !important;
  max-width: 30px !important;
  max-height: 30px !important;
  object-fit: contain;
}

.app-sidebar .brand-copy {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.app-sidebar .brand-text {
  min-width: 0;
  color: #ffffff;
  font-size: 1.02rem;
  font-weight: 900 !important;
  line-height: 1.05;
  white-space: normal;
  text-transform: uppercase;
}

.app-sidebar .brand-subtitle {
  display: block;
  margin-top: 4px;
  color: #80e0c7;
  font-size: 0.68rem;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.app-sidebar .sidebar {
  padding: 12px 10px 18px;
}

.app-sidebar .nav-sidebar > .nav-item {
  margin-bottom: 5px;
}

.app-sidebar .nav-sidebar .nav-link {
  position: relative;
  min-height: 42px;
  display: flex;
  align-items: center;
  margin-bottom: 0;
  padding: 9px 12px;
  border-radius: 8px;
  color: #cfd8e3;
  transition: background-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.app-sidebar .nav-sidebar .nav-link p {
  min-width: 0;
  margin: 0;
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
}

.app-sidebar .nav-sidebar > .nav-item > .nav-link .nav-icon {
  width: 30px;
  min-width: 30px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0 9px 0 0;
  border-radius: 8px;
  color: #8fdcc4;
  background: rgba(32, 201, 151, 0.1);
  font-size: 0.95rem;
}

.app-sidebar .nav-sidebar .nav-link:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.08);
}

.app-sidebar .nav-sidebar > .nav-item.menu-open > .nav-link,
.app-sidebar .nav-sidebar > .nav-item > .nav-link.active {
  color: #ffffff;
  background: #1e6f68;
  box-shadow: inset 3px 0 0 #f2b84b, 0 8px 18px rgba(0, 0, 0, 0.16);
}

.app-sidebar .nav-sidebar > .nav-item.menu-open > .nav-link .nav-icon,
.app-sidebar .nav-sidebar > .nav-item > .nav-link.active .nav-icon {
  color: #122027;
  background: #f2b84b;
}

.app-sidebar .nav-sidebar .nav-link > p > .right {
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  color: rgba(255, 255, 255, 0.6);
}

.app-sidebar .nav-sidebar .menu-open > .nav-link i.right {
  transform: translateY(-50%) rotate(-90deg);
}

.app-sidebar .nav-treeview {
  margin: 5px 0 7px 14px;
  padding: 5px 0 4px 10px !important;
  border-left: 1px solid rgba(143, 220, 196, 0.28);
}

.app-sidebar .nav-treeview > .nav-item > .nav-link {
  min-height: 36px;
  padding: 7px 10px;
  color: #aeb9c7;
  border-radius: 7px;
}

.app-sidebar .nav-treeview > .nav-item > .nav-link .nav-icon {
  width: 18px;
  min-width: 18px;
  margin-right: 8px;
  color: #f2b84b;
  font-size: 0.55rem;
}

.app-sidebar .nav-treeview > .nav-item > .nav-link:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.07);
}

.app-sidebar .nav-treeview > .nav-item > .nav-link.active,
.app-sidebar .nav-treeview > .nav-item > .nav-link.active:hover {
  color: #ffffff;
  background: rgba(32, 201, 151, 0.18);
  box-shadow: inset 3px 0 0 #20c997;
}

.sidebar-collapse .app-sidebar .brand-link {
  justify-content: center;
  padding-left: 8px;
  padding-right: 8px;
}

.sidebar-collapse .app-sidebar:hover .brand-link {
  justify-content: flex-start;
  padding-left: 14px;
  padding-right: 14px;
}

.sidebar-collapse .app-sidebar:not(:hover) .brand-text,
.sidebar-collapse .app-sidebar:not(:hover) .brand-subtitle,
.sidebar-collapse .app-sidebar:not(:hover) .nav-sidebar .nav-link p {
  display: none;
}

.sidebar-collapse .app-sidebar:not(:hover) .nav-sidebar > .nav-item > .nav-link {
  justify-content: center;
  padding-left: 8px;
  padding-right: 8px;
}

.sidebar-collapse .app-sidebar:not(:hover) .nav-sidebar > .nav-item > .nav-link .nav-icon {
  margin-right: 0;
}

.sidebar-collapse .app-sidebar:not(:hover) .nav-treeview {
  display: none !important;
}

@media (min-width: 768px) {
  body:not(.sidebar-mini-md) .content-wrapper,
  body:not(.sidebar-mini-md) .main-footer,
  body:not(.sidebar-mini-md) .main-header {
    margin-left: 285px;
  }

  body.sidebar-collapse:not(.sidebar-mini-md) .content-wrapper,
  body.sidebar-collapse:not(.sidebar-mini-md) .main-footer,
  body.sidebar-collapse:not(.sidebar-mini-md) .main-header {
    margin-left: 0;
  }

  .layout-fixed .brand-link {
    width: 285px;
  }
}

.sidebar-collapse .app-sidebar,
.sidebar-collapse .app-sidebar::before {
  margin-left: -285px;
}

.sidebar-open .app-sidebar,
.sidebar-open .app-sidebar::before {
  margin-left: 0;
}

@media (max-width: 767.98px) {
  .app-sidebar,
  .app-sidebar::before {
    margin-left: -285px;
  }
}
