/* ==========================================================================
   ÓNIX · SHELL (Sidebar + Topbar + Layout wrapper)
   Requiere: onx-layout.css (tokens, base y componentes compartidos)
   ========================================================================== */

/* --------------------------------------------------------------------------
   Sidebar: contenedor exterior y tarjeta interna
   -------------------------------------------------------------------------- */
.sidebar-col{
  padding:16px;
  height:100dvh;
  position:relative;
  z-index:10;
}

.sidebar-card{
  background:var(--sidebar-bg);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px 10px;

  height:100%;
  min-height:0;

  display:flex;
  flex-direction:column;
  overflow:visible;
}

/* --------------------------------------------------------------------------
   Brand: logo + toggle de colapsado (desktop)
   -------------------------------------------------------------------------- */
.brand{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;

  padding:10px 8px 14px;
  margin-bottom:6px;
  border-bottom:1px solid var(--line);

  position:relative;
  overflow:visible;
}

.brand img,
.brand .logo{
  width:36px;
  height:36px;
  display:block;
  transition:opacity .25s ease;
}

/* Variantes de logo por tema */
.brand .logo-dark{ display:none; }
body.dark .brand .logo-light{ display:none; }
body.dark .brand .logo-dark{ display:block; }

/* Toggle de colapsado: se posiciona al borde derecho del sidebar */
.sidebar-collapse-toggle{
  position:absolute;
  right:-18px;
  top:50%;
  transform:translateY(-50%);
  z-index:50;
}
body.sidebar-collapsed .brand .sidebar-collapse-toggle{
  transform:translateY(-50%) rotate(180deg);
}

/* --------------------------------------------------------------------------
   Menú principal (items de primer nivel)
   -------------------------------------------------------------------------- */
.menu{
  list-style:none;
  padding-left:0;
  margin:10px 0 0;
  flex:1 1 auto;
}
.menu li{ margin:6px 0; }

.menu a{
  display:flex;
  align-items:center;
  gap:12px;

  padding:10px 12px;
  border-radius:12px;

  color:var(--link-inactivo);
  text-decoration:none;

  transition:background .24s ease, color .24s ease;
}
.menu a:hover{
  background:var(--link-activo-bg);
  color:var(--link-activo);
}
.menu a ion-icon{
  font-size:20px;
  min-width:20px;
  opacity:.85;
  color:inherit;
}

/* Badge (contador / etiqueta) alineado al extremo derecho */
.menu .badge{
  margin-left:auto;
  background:var(--pill-bg);
  color:var(--pill-texto);
  border-radius:999px;
  padding:2px 7px;
  font-size:11px;
}
.menu .badge.hidden{ display:none; }

/* --------------------------------------------------------------------------
   Flyout submenu (desktop cuando el sidebar está colapsado)
   -------------------------------------------------------------------------- */
@media (min-width:992px){
  /* Evita que el flyout se recorte por overflow en contenedores */
  body.sidebar-collapsed .menu-nav,
  body.sidebar-collapsed .menu,
  body.sidebar-collapsed .sidebar-col,
  body.sidebar-collapsed .sidebar-card{
    overflow:visible !important;
  }

  body.sidebar-collapsed .menu li.has-submenu{ position:relative; }
  body.sidebar-collapsed .menu li.has-submenu .submenu-caret{ display:none !important; }
  body.sidebar-collapsed .menu li.has-submenu > a{ justify-content:center; }

  body.sidebar-collapsed .menu li.has-submenu > .submenu{
    display:block;
    position:fixed;
    left:-9999px;
    top:-9999px;

    width:240px;
    padding:10px;
    margin:0;

    background:var(--surface);
    border:1px solid var(--line);
    border-radius:14px;
    box-shadow:var(--shadow);
    z-index:2000;

    color:var(--texto);

    opacity:0;
    transform:translateY(6px) scale(.985);
    transform-origin:top left;

    visibility:hidden;
    pointer-events:none;

    transition:
      opacity .18s ease,
      transform .22s cubic-bezier(.2,.9,.2,1),
      visibility 0s linear .22s;

    will-change:opacity, transform;
  }

  body.sidebar-collapsed .menu li.has-submenu:hover > .submenu,
  body.sidebar-collapsed .menu li.has-submenu:focus-within > .submenu{
    opacity:1;
    transform:translateY(0) scale(1);
    visibility:visible;
    pointer-events:auto;

    transition:
      opacity .18s ease,
      transform .22s cubic-bezier(.2,.9,.2,1),
      visibility 0s;
  }

  /* Título del flyout (proviene del atributo data-flyout-title) */
  body.sidebar-collapsed .menu li.has-submenu > .submenu::before{
    content:attr(data-flyout-title);
    display:block;
    font-weight:800;
    font-size:12px;
    color:var(--muted);
    padding:2px 6px 8px;
  }

  body.sidebar-collapsed .menu li.has-submenu > .submenu a{
    font-size:13px !important;
    justify-content:flex-start !important;
    padding:9px 10px !important;
    border-radius:10px;
    color:var(--texto) !important;
  }

  body.sidebar-collapsed .menu li.has-submenu > .submenu a .link-text{
    opacity:1 !important;
    transform:none !important;
    color:inherit !important;
  }

  body.sidebar-collapsed .menu li.has-submenu > .submenu a:hover{
    color:var(--link-activo) !important;
  }

  /* Área de tolerancia para evitar que el flyout cierre al cruzar el gap */
  body.sidebar-collapsed .menu li.has-submenu > .submenu::after{
    content:"";
    position:absolute;
    left:-12px;
    top:0;
    width:12px;
    height:100%;
    background:transparent;
  }
}

@media (prefers-reduced-motion:reduce){
  @media (min-width:992px){
    body.sidebar-collapsed .menu li.has-submenu > .submenu{
      transition:none !important;
      transform:none !important;
    }
  }
}

/* --------------------------------------------------------------------------
   Submenús inline (expand/collapse)
   -------------------------------------------------------------------------- */
.menu li.has-submenu > a{ position:relative; }

.menu li.has-submenu .submenu-caret{
  margin-left:auto;
  font-size:16px;
  opacity:.7;
  transition:transform .18s ease, opacity .18s ease;
}
.menu li.has-submenu.is-open > a .submenu-caret{
  transform:rotate(180deg);
  opacity:.9;
}

.submenu{
  list-style:none;
  margin:2px 0 8px;
  padding:0 0 0 30px;

  max-height:0;
  opacity:0;
  transform:translateY(-4px);
  overflow:hidden;

  transition:
    max-height .28s cubic-bezier(.22,.61,.36,1),
    opacity .20s ease,
    transform .20s ease;

  will-change:max-height, opacity, transform;
}

.menu li.has-submenu.is-open > .submenu{
  opacity:1;
  transform:translateY(0);
  max-height:var(--submenu-h, 400px);

  display:grid;
  gap:4px;
  padding-top:4px;
  padding-bottom:4px;
}

.submenu a{
  display:flex;
  align-items:center;
  gap:10px;

  padding:8px 10px;
  border-radius:10px;

  color:var(--link-inactivo);
  text-decoration:none;
  font-size:13px;

  transition:background .2s ease, color .2s ease;
}
.submenu a:hover{
  background:var(--link-activo-bg);
  color:var(--link-activo);
}

@media (prefers-reduced-motion:reduce){
  .submenu{ transition:none !important; transform:none !important; }
}

/* Icono del submenú: chip con fondo sutil */
.submenu a ion-icon{
  width:15px;
  height:15px;
  min-width:15px;

  display:inline-grid;
  place-items:center;

  padding:5px;
  border-radius:9px;

  background:rgba(255,138,0,.10);
  border:1px solid rgba(255,138,0,.18);

  opacity:1;
  color:var(--link-activo);
}
.submenu a:hover ion-icon{
  background:rgba(255,138,0,.14);
  border-color:rgba(255,138,0,.26);
}
body.dark .submenu a ion-icon{
  background:rgba(255,138,0,.14);
  border-color:rgba(255,138,0,.22);
}
@media (min-width:992px){
  body.sidebar-collapsed .menu li.has-submenu > .submenu a ion-icon{
    width:15px;
    height:15px;
    min-width:15px;
    border-radius:9px;
  }

  body.sidebar-collapsed .menu li.has-submenu.flyout-open > .submenu{
    opacity:1;
    transform:translateY(0) scale(1);
    visibility:visible;
    pointer-events:auto;

    transition:
      opacity .18s ease,
      transform .22s cubic-bezier(.2,.9,.2,1),
      visibility 0s;
  }

  /* (Opcional pero recomendable) aumentar tolerancia del “puente” */
  body.sidebar-collapsed .menu li.has-submenu > .submenu::after{
    left:-18px;
    width:18px;
  }
}

/* --------------------------------------------------------------------------
   Logout (bloque inferior del sidebar)
   -------------------------------------------------------------------------- */
.logout{
  border-top:1px solid var(--line);
  padding-top:10px;
  margin-top:10px;
}
.logout a{
  display:flex;
  align-items:center;
  gap:10px;

  color:var(--link-logout-activo);
  text-decoration:none;

  padding:8px 10px;
  border-radius:12px;
}
.logout a ion-icon{ color:inherit; }
.logout a:hover,
.logout a:focus-visible{
  color:var(--link-logout-activo);
  background:var(--btn-logout-bg-hover);
  outline:none;
}

/* --------------------------------------------------------------------------
   Scroll interno del sidebar (lista + logout al fondo)
   -------------------------------------------------------------------------- */
.menu-nav{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  min-height:0;

  overflow-y:auto;
  overflow-x:hidden;

  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;

  padding-right:6px;
}
.logout{ margin-top:auto; }

/* --------------------------------------------------------------------------
   Topbar (cabecera superior)
   -------------------------------------------------------------------------- */
.topbar{
  padding:20px 10px;
  background:var(--bg);

  display:flex;
  flex-direction:column;
  gap:16px;

  flex:0 0 auto; /* ✅ nunca “empuja” el content */
}

.topbar-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.topbar-main-left,
.topbar-main-right{
  display:flex;
  align-items:center;
  gap:10px;
}

.welcome-box{ display:flex; flex-direction:column; }

.welcome{
  margin:0;
  font-weight:800;
  font-size:var(--fs-welcome);
}

.notif-text{
  margin:6px 0 0;
  color:var(--muted);
}
.notif-number{ font-weight:700; }

/* --------------------------------------------------------------------------
   Botones de icono (topbar / acciones)
   -------------------------------------------------------------------------- */
.btn-icon{
  background:var(--surface);
  border:1px solid var(--line);
  width:38px;
  height:38px;
  border-radius:12px;
  box-shadow:var(--shadow);
  display:grid;
  place-items:center;
  line-height:0;
  color:var(--texto);
  outline:0;
  cursor:pointer;
}
.btn-icon:hover{ color:var(--link-activo); }

ion-icon{ color:currentColor; transition:color .25s ease; }
.nav-toggle ion-icon{ transform:translateY(.5px); }
.btn-icon ion-icon{
  width:20px;
  height:20px;
  display:block;
}

/* --------------------------------------------------------------------------
   User chip + menú (dropdown)
   -------------------------------------------------------------------------- */
.user-chip{
  display:flex;
  align-items:center;
  gap:10px;

  background:var(--surface);
  border:1px solid var(--line);
  padding:6px 10px;
  border-radius:12px;
  box-shadow:var(--shadow);
}

.user-chip .avatar{
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--color-primario);
  display:inline-block;
}

.user-info{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}
.user-info .name{ font-weight:700; font-size:var(--fs-user-name); }
.user-info .position{ font-size:var(--fs-user-pos); color:var(--muted); }

/* Avatar: imagen + fallback con iniciales */
.user-chip .avatar,
.user-menu .avatar.sm{
  overflow:hidden;
  position:relative;
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:800;
  letter-spacing:.5px;
}
.user-chip .avatar img,
.user-menu .avatar.sm img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.avatar-initials{ font-size:12px; line-height:1; }
.user-menu .avatar.sm .avatar-initials{ font-size:11px; }

/* Colores por rol */
.user-trigger.is-admin,
.user-menu .avatar.sm.is-admin{ background:var(--perfil-admin-bg) !important; }
.user-trigger.is-empleado,
.user-menu .avatar.sm.is-empleado{ background:var(--perfil-empleado-bg) !important; }
.user-trigger.is-agente,
.user-menu .avatar.sm.is-agente{ background:var(--perfil-usuario-bg) !important; }
.user-trigger.is-usuario,
.user-menu .avatar.sm.is-usuario{ background:var(--perfil-usuario-bg) !important; }

.user-trigger:focus-visible{
  outline:2px solid var(--link-activo);
  outline-offset:2px;
}

.user-dropdown{ position:relative; }

.user-trigger{
  border:0;
  background:transparent;
  width:28px;
  height:28px;
  border-radius:50%;
  cursor:pointer;

  padding:0;
  line-height:0;
  display:grid;
  place-items:center;
  overflow:hidden;
}

.user-menu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);

  background:var(--surface);
  color:var(--texto);
  border:1px solid var(--line);
  border-radius:12px;
  box-shadow:var(--shadow);

  min-width:220px;
  padding:10px;

  opacity:0;
  transform:translateY(-6px) scale(.985);
  transform-origin:top right;
  visibility:hidden;
  pointer-events:none;

  transition:
    opacity .18s ease,
    transform .22s cubic-bezier(.2,.9,.2,1),
    visibility 0s linear .22s;
  will-change:opacity, transform;
}
.user-menu.open{
  opacity:1;
  transform:translateY(0) scale(1);
  visibility:visible;
  pointer-events:auto;

  transition:
    opacity .18s ease,
    transform .22s cubic-bezier(.2,.9,.2,1),
    visibility 0s;
}
@media (prefers-reduced-motion:reduce){
  .user-menu{ transition:none !important; transform:none !important; }
}

.user-menu-header{
  display:flex;
  align-items:center;
  gap:10px;
  padding:6px 4px 8px;
}
.user-menu .avatar.sm{
  width:28px;
  height:28px;
  background:var(--perfil-usuario-bg);
  border-radius:50%;
  display:inline-block;
}
.user-menu .name{ font-weight:700; }
.user-menu .position{ font-size:12px; color:var(--muted); }

.user-menu a{
  display:flex;
  align-items:center;
  gap:8px;
  padding:8px;
  border-radius:8px;
  color:inherit;
  text-decoration:none;
}
.user-menu a:hover{ background:var(--link-activo-bg); }

/* --------------------------------------------------------------------------
   Desktop: topbar en una sola fila y sin controles móviles
   -------------------------------------------------------------------------- */
@media (min-width:992px){
  .topbar{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    gap:16px;
  }

  .topbar-row--welcome{
    order:1;
    flex:1 1 auto;
    min-width:0;
  }
  .topbar-row--main{
    order:2;
    flex:0 0 auto;
  }

  .topbar-main-left{ display:none; }
}

/* --------------------------------------------------------------------------
   Tipografía: tokens aplicados a elementos del shell
   -------------------------------------------------------------------------- */
.notif-text{ font-size:var(--fs-subtle); }
.onx-btn-link,
.onx-item__footer .onx-link{ font-size:var(--fs-button); }

/* --------------------------------------------------------------------------
   Layout wrapper (sidebar + contenido)
   -------------------------------------------------------------------------- */
.layout-row{
  display:flex;
  align-items:stretch;
  min-height:100dvh;
}

.main-col{
  display:flex;
  flex-direction:column;
  min-width:0;

  height:100dvh;
  overflow:hidden;
}

/* ✅ Scroll “tipo sidebar”: vive aquí */
.main-col .content{
  display:flex;
  flex-direction:column;

  flex:1 1 auto;
  min-height:0;

  overflow: hidden;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
}

/* Si una vista usa contenedores de scroll internos, que puedan crecer */
.main-col .content .onx-scroll-list,
.main-col .content .onx-scroll-y{
  flex:1 1 auto;
  min-height:0;
}

/* --------------------------------------------------------------------------
   Responsive: móvil/tablet (off-canvas) y desktop
   -------------------------------------------------------------------------- */
@media (max-width:991.98px){
  .sidebar-col{
    position:fixed;
    top:0;
    left:0;
    bottom:0;

    padding:0;
    width:280px;

    z-index:1040;
    background:var(--sidebar-bg);
    border-right:1px solid var(--line);

    transform:translateX(-110%);
    transition:transform .25s ease;

    height:100dvh;
    overflow:hidden;
  }

  .sidebar-card{
    height:100%;
    min-height:100%;
    border-radius:0;
    box-shadow:none;
    padding:16px 12px;
    border:0;
  }

  body.sidebar-open .sidebar-col{ transform:translateX(0); }

  .sidebar-backdrop{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.35);
    opacity:0;
    visibility:hidden;
    transition:opacity .25s ease, visibility .25s ease;
    z-index:1030;
  }

  body.sidebar-open .sidebar-backdrop{
    opacity:1;
    visibility:visible;
  }

  .nav-toggle{ display:inline-grid; place-items:center; }
  .user-chip{ padding:6px; border-radius:999px; }
  .user-info{ display:none; }
  .brand .sidebar-collapse-toggle{ display:none !important; }

  :root{ --sidebar-w:0px; }

  .layout-row{ margin-left:0; margin-right:0; }
  .layout-row > .main-col{
    width:100% !important;
    float:none !important;
  }

  .container-fluid.wrapper{
    padding-left:0;
    padding-right:0;
  }

  .topbar{ padding:16px var(--page-gutters); }
  .welcome{ font-size:20px; }
}

@media (min-width:992px){
  body.sidebar-collapsed .sidebar-collapse-toggle{ right:-34px; }

  .nav-toggle{ display:none !important; }
  .user-menu{ display:none !important; }

  .layout-row > .sidebar-col,
  .layout-row > .main-col{
    float:none;
    width:auto;
  }

  .sidebar-card{ width:260px; }
  body.sidebar-collapsed .sidebar-card{ width:76px; }

  .layout-row > .main-col{
    flex:1 1 auto;
    min-width:0;
  }

  /* Sidebar colapsado: solo iconos en nivel principal */
  body.sidebar-collapsed .menu a{
    padding:10px;
    justify-content:center;
    font-size:0;
  }

  body.sidebar-collapsed .menu a ion-icon{
    font-size:20px;
    opacity:.95;
  }

  body.sidebar-collapsed .menu .badge{ display:none; }

  body.sidebar-collapsed .logout a{
    justify-content:center;
    font-size:0;
  }

  body.sidebar-collapsed .logout a ion-icon{ font-size:20px; }

  body.sidebar-collapsed{ --sidebar-w:76px; }

  .sidebar-card{
    transition:width .28s cubic-bezier(.22,.61,.36,1);
    will-change:width;
  }

  .menu a,
  .logout a{
    transition:
      padding .28s cubic-bezier(.22,.61,.36,1),
      background .24s ease,
      color .24s ease;
  }

  .brand .sidebar-collapse-toggle{
    transition:
      transform .28s cubic-bezier(.22,.61,.36,1),
      background .2s ease,
      color .2s ease;
  }

  .menu a .link-text,
  .logout a .link-text{
    display:inline-block;
    font:inherit;
    letter-spacing:0;
    transition:opacity .24s ease, transform .24s ease;
    transform-origin:left center;
  }

  body.sidebar-collapsed .menu a .link-text,
  body.sidebar-collapsed .logout a .link-text{
    opacity:0;
    transform:translateX(-6px);
  }

  .brand{ overflow:visible; }
}

/* --------------------------------------------------------------------------
   Ajuste de gutters cuando el sidebar no reserva ancho (desktop/tablet)
   -------------------------------------------------------------------------- */
@media (min-width:992px) and (max-width:1200px){
  :root{ --sidebar-w:0px !important; }

  .layout-row,
  .main-col,
  .main-col .content{
    width:100%;
    max-width:100%;
  }

  .content,
  .container-fluid.wrapper{
    padding-left:var(--page-gutters) !important;
    padding-right:var(--page-gutters) !important;
  }
}

/* --------------------------------------------------------------------------
   Accesibilidad: reduce motion (desactiva transiciones no esenciales)
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
  .sidebar-card,
  .menu a,
  .logout a,
  .brand .sidebar-collapse-toggle,
  .menu a .link-text,
  .logout a .link-text{
    transition:none !important;
  }
}

/* --------------------------------------------------------------------------
   Pantallas con poca altura: reduce padding para ganar espacio vertical
   -------------------------------------------------------------------------- */
@media (max-height:720px){
  .menu a{ padding:8px 10px; gap:10px; }
  .submenu{ padding-left:30px; }
  .submenu a{ padding:6px 10px; font-size:12.5px; }
  .brand{ padding:8px 8px 10px; }
  .sidebar-card{ padding:12px 10px; }
}

/* =========================================================
   FIX: Flyout submenu NO debe usar el "inline collapse"
   ========================================================= */
@media (min-width: 992px) {
  /* Estado base (oculto) */
  body.sidebar-collapsed .menu li.has-submenu > .submenu{
    /* Mata el comportamiento inline */
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;

    /* Si quieres limitar por viewport y permitir scroll dentro del flyout: */
    max-height: calc(100vh - 24px) !important;
    overflow: auto !important;

    /* Asegura layout “natural” aunque el inline use grid */
    display: block !important;
    opacity: 0;                 /* tu animación */
    transform: translateY(6px) scale(.985);
    visibility: hidden;
    pointer-events: none;
  }

  /* Estado visible */
  body.sidebar-collapsed .menu li.has-submenu:hover > .submenu,
  body.sidebar-collapsed .menu li.has-submenu:focus-within > .submenu{
    max-height: calc(100vh - 24px) !important;
    height: auto !important;
    overflow: auto !important;

    opacity: 1;
    transform: translateY(0) scale(1);
    visibility: visible;
    pointer-events: auto;
  }
}

/* =========================================================
   FIX pantallas altas:
   la zona scroll debe estirar y empujar el paginador abajo
   ========================================================= */
.main-col .content{
  display:flex;
  flex-direction:column;
  min-height:0;
}

/* La lista/scroll: que sea el “relleno” */
.main-col .content .onx-scroll-list,
.main-col .content .onx-scroll-y{
  flex: 1 1 auto;
  min-height: 0;
  max-height: none !important;  /* mata el 70vh */
  overflow: auto;
}
