/* ==============================
   LAYOUT.CSS - Sidebar & Layout
   ============================== */

.sidebar{
  position: fixed;
  inset: 0 auto 0 0; /* top right bottom left */
  width: 260px;
  height: 100vh;
  background: #3D4224;
  color: #fff;
  display: flex;
  flex-direction: column;
  z-index: 9999;
  overflow: hidden;
  transition: width .2s ease;
}

.sidebar.is-collapsed{ width: 78px; }

.sidebar__top{
  padding: 16px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.sidebar__brand-text{
  font-size: 18px;
  font-weight: 600;
  white-space: nowrap;
}

.sidebar.is-collapsed .sidebar__brand-text{ display:none; }

.sidebar__toggle{
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  padding: 8px 10px;
  border-radius: 10px;
  cursor: pointer;
  line-height: 1;
}

.sidebar__toggle:hover{
  background: rgba(255,255,255,.14);
}

/* NAV */
.sidebar__nav{
  padding: 14px;
  flex: 1;
  overflow-y: auto;
}

/* scroll discreto */
.sidebar__nav::-webkit-scrollbar{ width: 8px; }
.sidebar__nav::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.18);
  border-radius: 10px;
}

/* Secciones */
.sidebar__section{
  margin: 16px 8px 8px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: rgba(255,255,255,.75);
}

.sidebar.is-collapsed .sidebar__section{ display:none; }

/* Links */
.sidebar__link{
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  margin: 8px 0;
  border-radius: 12px;
  color: #fff;
  border: 1px solid rgba(255,255,255,.10);
  transition: 0.2s ease;
  text-decoration: none;
}

.sidebar__link:hover{
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.18);
}

.sidebar__link:focus{
  outline: 2px solid rgba(216,212,174,.65);
  outline-offset: 2px;
}

.sidebar__link.is-active{
  background: #676A4A;
  border-color: rgba(255,255,255,.25);
}

/* Icono y texto */
.sidebar__icon{
  font-size: 18px;
  width: 22px;
  min-width: 22px;
  text-align: center;
  line-height: 1;
}

.sidebar__text{
  white-space: nowrap;
}

/* ======= MODO COLAPSADO ======= */
.sidebar.is-collapsed .sidebar__text{
  display: none;
}

/* Links centrados y cuadraditos */
.sidebar.is-collapsed .sidebar__link{
  justify-content: center;
  padding: 12px 0;
}

/* hace que todos los botones se vean iguales y centrados */
.sidebar.is-collapsed .sidebar__link{
  width: 50px;
  margin-left: auto;
  margin-right: auto;
  border-radius: 14px;
}

/* Layout del contenido */
body{
  padding-left: 260px;
  transition: padding-left .2s ease;
}

body.sidebar-collapsed{
  padding-left: 78px;
}

.app-main{
  padding: 24px;
}
/* ==============================
   Seguro: no aplicar layout en login
   ============================== */
body.login-page{
  padding-left: 0 !important;
}

body.login-page.sidebar-collapsed{
  padding-left: 0 !important;
}