/* ============================================================
   TURING ERP v2 — Shell overrides for the ERPNicaragua app
   Glues the v2 shell (rail + topbar + main) with legacy module
   markup rendered inside .content-wrapper.
   ============================================================ */

/* ---- Base: drop AdminLTE body classes ---- */
body.hold-transition{transition:none}
body.sidebar-mini,
body.skin-blue{background:var(--bg-app);color:var(--fg-1)}

/* ---- Shell grid ---- */
html,body{height:100%}
.shell{min-height:100vh}

/* Rail — sticky column */
.rail{position:sticky;top:0;align-self:start}
.rail a,
.rail a:hover,
.rail a:focus{text-decoration:none;color:inherit}

/* ---- Rail expanded (user-toggleable wide mode with visible labels) ---- */
:root{ --rail-expanded-w: 200px; }
body.rail-expanded .shell{ grid-template-columns: var(--rail-expanded-w) 1fr; }
body.rail-expanded .rail{ align-items: stretch; padding: 8px 10px; }
body.rail-expanded .rail-brand{ align-self: flex-start; margin-bottom: 10px; }
body.rail-expanded .rail-items{ align-items: stretch; padding: 4px 0; }
body.rail-expanded .rail-item{
  width: 100%; height: clamp(28px, 4.2vh, 34px); display: flex; align-items: center; gap: 10px;
  padding: 0 10px; border-radius: var(--r-2); justify-content: flex-start;
  font-size: clamp(12px, 1.4vh, 13px);
}
body.rail-expanded .rail-item > i{ width: 18px; flex: 0 0 18px; text-align: center; font-size: 14px; }
body.rail-expanded .rail-item > .rail-primary{
  position: static; inset: auto; display: flex; align-items: center; gap: 10px;
  place-items: unset; flex: 1 1 auto; min-width: 0;
}
body.rail-expanded .rail-item > .rail-primary > i{ width: 18px; flex: 0 0 18px; text-align: center; font-size: 14px; }
/* Los items con submenú (has-children) no tienen <span class="tip">; inyectamos
   el label vía ::after usando el aria-label del propio <a class="rail-primary">. */
body.rail-expanded .rail-item.has-children > .rail-primary::after{
  content: attr(aria-label);
  font-size: 13px; font-weight: 500; color: inherit;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1 1 auto; min-width: 0;
}
body.rail-expanded .rail-item .tip{
  position: static; opacity: 1; transform: none; background: transparent; color: inherit;
  padding: 0; font-size: 13px; font-weight: 500; box-shadow: none; pointer-events: auto;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1 1 auto; min-width: 0;
}
body.rail-expanded .rail-item.active .tip{ color: var(--accent-ink); }
body.rail-expanded .rail-item.active::before{ left: -10px; }
body.rail-expanded .rail-item.has-children::after{ right: 10px; }
body.rail-expanded .rail-divider{ width: auto; margin: 6px 6px; }
body.rail-expanded .rail-foot{ align-items: stretch; padding: 0 0 6px; }
/* En modo expandido la posición del flyout la calcula JS (positionRailFlyout). */

/* Collapse/expand toggle button */
.rail{position:sticky} /* keep rail positioned so button can anchor */
.rail-collapse-btn{
  position: absolute; top: 12px; right: -12px;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--bg-surface); border: 1px solid var(--border-strong);
  color: var(--fg-2); display: grid; place-items: center; cursor: pointer;
  box-shadow: var(--sh-md); z-index: 20; font-size: 10px; padding: 0;
  transition: transform .15s ease, background .1s ease, color .1s ease;
}
.rail-collapse-btn:hover{ background: var(--bg-hover); color: var(--fg-1); }
body.rail-expanded .rail-collapse-btn{ transform: rotate(180deg); }
@media (max-width:820px){ .rail-collapse-btn{ display: none; } }

/* Primary anchor inside a grouped rail-item (has flyout siblings) */
.rail-item > .rail-primary{
  position:absolute;inset:0;display:grid;place-items:center;
  color:inherit;text-decoration:none;border-radius:inherit;font-size:15px;
}

/* Brand link (logo) */
.rail-brand a,
.rail-brand a:hover{color:inherit;text-decoration:none;display:grid;place-items:center;width:100%;height:100%}

/* Foot section (Ajustes / Salir, pushed to bottom) */
.rail-foot{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:clamp(1px,.3vh,2px);padding-bottom:clamp(2px,.6vh,6px);width:100%}

/* Rail sub-menu flyout (hover sections with children)
   position:fixed para que no lo recorte ningún overflow del rail.
   JS (shell.js → positionRailFlyout) le asigna left/top exactos. */
.rail-item .flyout{
  position:fixed;left:0;top:0;
  min-width:220px;max-width:320px;padding:6px;
  background:#0a0e27;color:#fff;border-radius:var(--r-3);
  box-shadow:0 16px 40px rgba(0,0,0,.35);
  opacity:0;pointer-events:none;transition:opacity .12s ease;
  z-index:120;display:flex;flex-direction:column;gap:2px;
  max-height:calc(100vh - 16px);overflow-y:auto;overflow-x:visible;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent;
}
.rail-item .flyout::-webkit-scrollbar{width:6px}
.rail-item .flyout::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:6px}
.rail-item:hover .flyout,
.rail-item .flyout:hover,
.rail-item.open .flyout{opacity:1;pointer-events:auto}
.rail-item .flyout::before{
  content:"";position:absolute;left:-6px;top:14px;
  border:6px solid transparent;border-right-color:#0a0e27;
}
/* Puente invisible que cubre el gap entre ícono y flyout, para que el
   cursor no pierda :hover al transitar del ícono hacia los enlaces. */
.rail-item .flyout::after{
  content:"";position:absolute;
  left:-14px;top:0;width:14px;height:100%;
  background:transparent;
}
.rail-item .flyout .fly-title{
  font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.55);padding:6px 10px 4px;
}
.rail-item .flyout a{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:var(--r-2);
  color:rgba(255,255,255,.88);font-size:12.5px;line-height:1.2;
}
.rail-item .flyout a:hover{background:rgba(255,255,255,.08);color:#fff}
.rail-item .flyout a i{width:14px;text-align:center;opacity:.75;font-size:11.5px}
.rail-item.has-children::after{
  content:"";position:absolute;right:4px;top:50%;
  width:4px;height:4px;border-right:1.5px solid currentColor;border-top:1.5px solid currentColor;
  transform:translateY(-50%) rotate(45deg);opacity:.5;
}
:root[data-theme="dark"] .rail-item .flyout{background:#2b2d36}
:root[data-theme="dark"] .rail-item .flyout::before{border-right-color:#2b2d36}

/* ---- Flyout nivel 2: submódulos del menú "Reportes" ----
 * Cada .fly-submenu se muestra como una fila dentro del flyout nivel 1.
 * Al hacer hover (desktop) o tap (touch) se expande un flyout anidado
 * posicionado a la derecha. En touch se alterna la clase .open
 * del contenedor (ver bindReportsSubmenus en shell.js). */
.rail-item .flyout .fly-divider{
  height:1px;background:rgba(255,255,255,.1);margin:6px 4px 4px;
}
.rail-item .flyout .fly-section{
  font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:rgba(255,255,255,.45);padding:4px 10px 4px;
}
.rail-item .flyout .fly-submenu{
  position:relative;
}
.rail-item .flyout .fly-submenu-head{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:var(--r-2);
  color:rgba(255,255,255,.88);font-size:12.5px;line-height:1.2;
  cursor:pointer;user-select:none;
}
.rail-item .flyout .fly-submenu-head:hover,
.rail-item .flyout .fly-submenu.open > .fly-submenu-head{
  background:rgba(255,255,255,.08);color:#fff;
}
.rail-item .flyout .fly-submenu-head > i:first-child{
  width:14px;text-align:center;opacity:.75;font-size:11.5px;
}
.rail-item .flyout .fly-submenu-head .fly-submenu-label{flex:1;min-width:0;}
.rail-item .flyout .fly-submenu-head .fly-submenu-arrow{
  font-size:9px;opacity:.6;margin-left:auto;
}
.rail-item .flyout .flyout-l2{
  position:fixed;left:0;top:0;
  min-width:260px;max-width:340px;padding:6px;
  background:#0a0e27;color:#fff;border-radius:var(--r-3);
  box-shadow:0 16px 40px rgba(0,0,0,.35);
  opacity:0;pointer-events:none;transition:opacity .12s ease;
  z-index:121;display:flex;flex-direction:column;gap:2px;
  max-height:calc(100vh - 16px);overflow-y:auto;
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent;
}
.rail-item .flyout .flyout-l2::-webkit-scrollbar{width:6px}
.rail-item .flyout .flyout-l2::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:6px}
.rail-item .flyout .flyout-l2::before{
  content:"";position:absolute;left:-6px;top:14px;
  border:6px solid transparent;border-right-color:#0a0e27;
}
.rail-item .flyout .flyout-l2::after{
  content:"";position:absolute;left:-14px;top:0;width:14px;height:100%;background:transparent;
}
.rail-item .flyout .fly-submenu:hover > .flyout-l2,
.rail-item .flyout .fly-submenu.open > .flyout-l2{opacity:1;pointer-events:auto;}
:root[data-theme="dark"] .rail-item .flyout .flyout-l2{background:#2b2d36;}
:root[data-theme="dark"] .rail-item .flyout .flyout-l2::before{border-right-color:#2b2d36;}

/* Badges de tier en reportes avanzados */
.rail-item .flyout .tier-badge{
  margin-left:auto;font-size:9.5px;font-weight:600;
  padding:1px 6px;border-radius:999px;line-height:1.4;
  letter-spacing:.02em;text-transform:uppercase;
}
.rail-item .flyout .tier-badge.tier-b{background:#fbbf24;color:#78350f;}
.rail-item .flyout .tier-badge.tier-c{background:#a78bfa;color:#2e1065;}
.rail-item .flyout .fly-report-label{flex:1;min-width:0;}

/* Modo móvil/tablet: flyout nivel 2 se apila verticalmente bajo el head */
@media (hover: none), (pointer: coarse){
  .rail-item .flyout .flyout-l2{
    position:static;opacity:1;pointer-events:none;
    box-shadow:none;padding:0 0 0 14px;margin:2px 0 4px;
    min-width:0;background:transparent;
    max-height:0;overflow:hidden;transition:max-height .18s ease;
  }
  .rail-item .flyout .flyout-l2::before,
  .rail-item .flyout .flyout-l2::after{display:none;}
  .rail-item .flyout .fly-submenu.open > .flyout-l2{
    pointer-events:auto;max-height:500px;
  }
  .rail-item .flyout .fly-submenu-head .fly-submenu-arrow{
    transition:transform .15s ease;
  }
  .rail-item .flyout .fly-submenu.open > .fly-submenu-head .fly-submenu-arrow{
    transform:rotate(90deg);
  }
}

/* ---- Main column ---- */
.main{min-width:0}

/* Topbar tweaks */
.topbar{backdrop-filter:saturate(1.2) blur(6px);background:color-mix(in oklab, var(--bg-app) 85%, transparent)}
.topbar .input-wrap .input{height:30px;padding-left:30px;font-size:12.5px}
.topbar-user .avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.topbar-user .who{font-size:12px;line-height:1.2}
.topbar-user .who b{font-weight:600;color:var(--fg-1)}
.topbar-user .who .sub{color:var(--fg-3);font-size:11px}

/* User dropdown — absolute panel (jQuery toggle) */
.user-dropdown{position:relative}
.user-dropdown .user-menu{
  position:absolute;right:0;top:calc(100% + 6px);
  min-width:240px;background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-3);box-shadow:var(--sh-lg);
  display:none;z-index:50;overflow:hidden;
}
.user-dropdown.open .user-menu{display:block}
.user-menu .user-header{padding:14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--divider)}
.user-menu .user-header .avatar{width:40px;height:40px;font-size:14px}
.user-menu .user-header .who b{display:block;font-weight:600;font-size:13px;color:var(--fg-1)}
.user-menu .user-header .who .sub{font-size:11.5px;color:var(--fg-3)}
.user-menu .user-body{padding:6px}
.user-menu .user-body a,
.user-menu .user-body button{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:8px 10px;border-radius:var(--r-2);
  color:var(--fg-1);font-size:13px;background:transparent;border:0;
  cursor:pointer;text-align:left;text-decoration:none;
}
.user-menu .user-body a:hover,
.user-menu .user-body button:hover{background:var(--bg-hover)}
.user-menu .user-body a i,
.user-menu .user-body button i{width:16px;text-align:center;color:var(--fg-3)}
.user-menu .user-body .divider{height:1px;background:var(--divider);margin:4px 2px}
.user-menu .user-body button#enableNotifications.is-active{color:#2e7d32}
.user-menu .user-body button#enableNotifications.is-active i{color:#2e7d32}
[data-theme="dark"] .user-menu .user-body button#enableNotifications.is-active,
[data-theme="dark"] .user-menu .user-body button#enableNotifications.is-active i{color:#66bb6a}

/* Branch switcher (topbar) */
.branch-dropdown{position:relative}
.branch-dropdown .branch-menu{
  position:absolute;right:0;top:calc(100% + 6px);
  min-width:280px;background:var(--bg-surface);border:1px solid var(--border);
  border-radius:var(--r-3);box-shadow:var(--sh-lg);
  display:none;z-index:50;overflow:hidden;
}
.branch-dropdown.open .branch-menu{display:block}
.branch-menu .branch-head{padding:10px 12px;border-bottom:1px solid var(--divider);font-size:11px;font-weight:600;text-transform:uppercase;color:var(--fg-3);letter-spacing:.03em}
.branch-menu .branch-body{max-height:340px;overflow:auto;padding:6px}
.branch-menu .branch-switch-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 10px;border-radius:var(--r-2);
  cursor:pointer;color:var(--fg-1);font-size:12.5px;
}
.branch-menu .branch-switch-item:hover{background:var(--bg-hover)}
.branch-menu .branch-switch-item.active{background:var(--accent-soft);color:var(--accent-ink)}
.branch-menu .branch-switch-item i{width:16px;text-align:center;color:var(--fg-3)}
.branch-menu .branch-switch-item.active i{color:var(--accent-ink)}
.branch-menu .branch-switch-item .meta{font-size:11px;color:var(--fg-3);margin-left:auto}

/* Topbar "current branch" chip */
.branch-chip{
  display:inline-flex;align-items:center;gap:6px;
  height:28px;padding:0 10px;font-size:12px;font-weight:500;
  color:var(--fg-1);background:var(--bg-surface);border:1px solid var(--border-strong);
  border-radius:var(--r-pill);cursor:pointer;
}
.branch-chip:hover{background:var(--bg-hover)}
.branch-chip i{color:var(--fg-3);font-size:11px}

/* ---- Content slot (where modules render) ---- */
.main .content-wrapper{
  background:transparent;
  margin:0;min-height:0;
  padding:20px 24px 40px;
}
.main .content-wrapper > .content-header{
  padding:0 0 14px;margin:0;
}
.main .content-wrapper > .content-header > h1{
  font-size:var(--fs-display);line-height:var(--lh-display);
  letter-spacing:var(--ls-display);font-weight:600;color:var(--fg-1);
  margin:0;display:flex;align-items:baseline;gap:10px;
}
.main .content-wrapper > .content-header > h1 > small{
  font-size:13px;color:var(--fg-3);font-weight:400;letter-spacing:0;
}
.main .content-wrapper > .content-header > .breadcrumb{
  margin:4px 0 0;padding:0;background:transparent;
  font-size:12px;color:var(--fg-3);display:flex;gap:6px;list-style:none;
}
.main .content-wrapper > .content-header > .breadcrumb > li{display:inline-flex;align-items:center;gap:6px}
.main .content-wrapper > .content-header > .breadcrumb > li + li::before{content:"/";color:var(--fg-4);padding:0 4px}
.main .content-wrapper > .content-header > .breadcrumb > li > a{color:var(--fg-3);text-decoration:none}
.main .content-wrapper > .content-header > .breadcrumb > li.active{color:var(--fg-1);font-weight:550}
.main .content-wrapper > .content{padding:0;margin:0}

/* Legacy AdminLTE surfaces — never paint full-width gutters again */
.wrapper{display:contents}
.main-header,
.main-sidebar,
.left-side,
.sidebar,
.main-footer,
.user-panel{display:none !important}

/* Responsive rail → hide on mobile, show top hamburger (topbar) */
.rail-toggle{display:none;background:transparent;border:0;color:var(--fg-2);width:32px;height:32px;border-radius:var(--r-2);cursor:pointer}
.rail-toggle:hover{background:var(--bg-hover);color:var(--fg-1)}
@media (max-width:820px){
  .shell{grid-template-columns:1fr}
  .rail{position:fixed;left:-60px;top:0;width:var(--rail-w);z-index:100;transition:left .18s ease;box-shadow:var(--sh-lg)}
  body.rail-open .rail{left:0}
  body.rail-open::after{content:"";position:fixed;inset:0;background:rgba(10,14,39,.35);z-index:99}
  .rail-toggle{display:grid;place-items:center}
  .main .content-wrapper{padding:16px 14px 32px}
  .topbar{padding:0 10px;gap:6px}
  .topbar-search{max-width:none}
  .topbar-user .who{display:none}
}

/* Dispositivos sin puntero fino (táctiles): el hover es simulado y
   poco confiable. Bloqueamos el flyout por :hover/:focus-within y
   solo lo mostramos cuando JS agrega la clase .open al item. Así, el
   primer tap del usuario en el icono abre el submenú (no navega), y
   un segundo tap o un tap en un <a> del flyout navega. */
@media (hover: none), (pointer: coarse){
  .rail-item:hover .flyout,
  .rail-item:focus-within .flyout,
  .rail-item .flyout:hover{opacity:0;pointer-events:none}
  .rail-item.open .flyout{opacity:1;pointer-events:auto}
}

/* Print — hide chrome */
@media print{
  .rail,.topbar{display:none !important}
  .main .content-wrapper{padding:0}
}
