/* ============================================
   CSS Grid Layout - Substitui o layout do AdminLTE v2
   ============================================ */

/* --- Variáveis de largura do sidebar --- */
:root {
  --sidebar-width-expanded: 230px;
  --sidebar-transition: 0.3s ease-in-out;
}

/* --- Body como flex column para acomodar debug-bar + wrapper --- */
body {
  display: flex;
  flex-direction: column;
  height: 100dvh;
  margin: 0;
}

/* --- Container principal com Grid --- */
.wrapper {
  display: grid;
  grid-template-columns: var(--sidebar-width-expanded) 1fr;
  grid-template-rows: auto 1fr;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  transition: grid-template-columns var(--sidebar-transition);
}

/* --- Sidebar: coluna 1, full height, logo fixo + menu com scroll --- */
.wrapper > .main-sidebar {
  grid-column: 1;
  grid-row: 1 / -1;
  min-height: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.wrapper > .main-sidebar > .sidebar {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
}

/* Scrollbar estilizada no sidebar (Chrome/Edge/Safari) */
.wrapper > .main-sidebar > .sidebar::-webkit-scrollbar {
  width: 5px;
}

.wrapper > .main-sidebar > .sidebar::-webkit-scrollbar-track {
  background: transparent;
}

.wrapper > .main-sidebar > .sidebar::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 3px;
}

.wrapper > .main-sidebar > .sidebar::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.35);
}

/* --- Logo no topo do sidebar --- */
.sidebar-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  padding: 0 15px;
  color: #b8c7ce;
  font-size: 18px;
  font-weight: 300;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-logo:hover {
  color: #fff;
  text-decoration: none;
}

/* --- Header: coluna 2, linha 1, sticky --- */
.wrapper > .main-header {
  grid-column: 2;
  grid-row: 1;
  position: sticky;
  top: 0;
  z-index: 1030;
  min-width: 0;
}

/* --- Content wrapper: coluna 2, linha 2, scroll independente --- */
.wrapper > .content-wrapper {
  grid-column: 2;
  grid-row: 2;
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.15) transparent;
}

/* Scrollbar estilizada no content (Chrome/Edge/Safari) */
.wrapper > .content-wrapper::-webkit-scrollbar {
  width: 6px;
}

.wrapper > .content-wrapper::-webkit-scrollbar-track {
  background: transparent;
}

.wrapper > .content-wrapper::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 3px;
}

.wrapper > .content-wrapper::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.3);
}

/* --- Estado colapsado (desktop): esconde o sidebar completamente --- */
.sidebar-collapse .wrapper {
  grid-template-columns: 0 1fr;
}

.sidebar-collapse .wrapper > .main-sidebar {
  overflow: hidden;
}

/* --- Mobile: coluna única, sidebar off-screen --- */
@media (max-width: 767px) {
  .wrapper,
  .sidebar-collapse .wrapper {
    grid-template-columns: 1fr;
  }

  .wrapper > .main-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: var(--sidebar-width-expanded);
    z-index: 1040;
    transform: translateX(-100%);
    transition: transform var(--sidebar-transition);
    grid-column: unset;
    grid-row: unset;
  }

  .wrapper > .main-header {
    grid-column: 1;
    grid-row: 1;
  }

  .wrapper > .content-wrapper {
    grid-column: 1;
    grid-row: 2;
  }

  /* Mobile: sidebar aberto */
  .sidebar-open .wrapper > .main-sidebar {
    transform: translateX(0);
  }
}

/* --- Backdrop para mobile --- */
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1035;
}

.sidebar-open .sidebar-backdrop {
  display: block;
}

/* --- SweetAlert2: impede que classes do swal2 quebrem o layout --- */
body.swal2-height-auto.swal2-shown {
  height: 100dvh !important;
}
