/*
|--------------------------------------------------------------------------
| Archivo principal de estilos
|--------------------------------------------------------------------------
| Organizacion:
| 01. Variables base y reset global
| 02. Componentes heredados generales
| 03. Pantalla publica de acceso
| 04. Shell interno de la aplicacion
| 05. Panel administrativo
| 06. Vistas de usuario heredadas
| 07. Carrito base de miscelaneos
| 08. Interfaz amplia profesional
| 09. Miscelaneos tactil
| 10. Historiales buscables
| 11. Tablero de llaves tactil
| 12. Administracion de llaves
|
| Nota de mantenimiento:
| El orden importa. Los bloques inferiores refinan o sobrescriben reglas
| declaradas arriba para pantallas especificas como Miscelaneos y Tablero.
*/

/* ==========================================================================
   01. Variables base y reset global
   Define la paleta inicial, el box model y reglas globales minimas.
   ========================================================================== */
:root{--bg:#f5f7fb;--card:#fff;--text:#17202a;--primary:#0d6efd;--accent:#7c3aed;--success:#198754;--danger:#dc3545;--secondary:#334155;--border:#dbe4f0}
*{box-sizing:border-box}[hidden]{display:none!important}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}

/* ==========================================================================
   02. Componentes heredados generales
   Base comun de tarjetas, botones, formularios, tablas y grillas iniciales.
   Se conserva para compatibilidad con vistas existentes.
   ========================================================================== */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#0f172a;color:#fff;gap:12px}.container,.guest-container{max-width:1300px;margin:0 auto;padding:24px}.guest-body{display:flex;min-height:100vh;align-items:center}
.hero-card,.auth-card,.panel,.stat-card,.catalog-card,.mini-card{background:var(--card);border-radius:8px;box-shadow:0 10px 30px rgba(15,23,42,.08);padding:24px;border:1px solid var(--border)}
.center{text-align:center}.two-columns,.module-grid,.admin-grid,.stats-grid,.card-grid{display:grid;gap:20px}.two-columns{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.module-grid,.admin-grid{grid-template-columns:1.1fr 1fr}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin-bottom:20px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.big-button{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:220px;border-radius:8px;text-decoration:none;color:#fff;font-size:2rem;padding:24px}.big-button small{font-size:1rem;margin-top:10px}.big-button.primary{background:linear-gradient(135deg,var(--primary),#1e40af)}.big-button.accent{background:linear-gradient(135deg,var(--accent),#4c1d95)}.emoji{font-size:3rem;margin-bottom:8px}
.auth-card{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;width:100%}.form-card{display:grid;gap:12px}.hint-box{background:#eef2ff;padding:20px;border-radius:8px}
input,select,textarea,button{font:inherit}input,select,textarea{width:100%;padding:14px 16px;border-radius:8px;border:1px solid #cbd5e1;background:#fff}textarea{min-height:110px;resize:vertical}
.btn{border:none;border-radius:8px;padding:12px 16px;color:#fff;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:48px}.btn-xl{min-height:60px;font-size:1.05rem}.btn-primary{background:var(--primary)}.btn-secondary{background:var(--secondary)}.btn-success{background:var(--success)}.btn-danger{background:var(--danger)}
.alert{padding:14px 16px;border-radius:8px;margin-bottom:16px}.alert-success{background:#d1fae5;color:#065f46}.alert-error{background:#fee2e2;color:#991b1b}.badge{display:inline-block;padding:8px 12px;background:#e2e8f0;border-radius:8px}.muted{opacity:.75}
.image-placeholder{width:72px;height:72px;border-radius:8px;background:#e0e7ff;display:flex;align-items:center;justify-content:center;font-size:2rem;margin-bottom:12px}.catalog-card h3{margin:0 0 8px}.catalog-card p{min-height:54px}
.table-scroll{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left}.search-input{margin-bottom:16px;font-size:1.05rem}.action-row,.inline-form,.topbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:space-between}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.mini-card{margin-bottom:10px;padding:16px}.menu-tags{display:flex;flex-wrap:wrap;gap:8px}.stat-card strong{font-size:2rem;display:block}.link-back{display:inline-block;text-align:center;margin-top:8px}
@media (max-width:900px){.module-grid,.admin-grid,.auth-card{grid-template-columns:1fr}.topbar{flex-direction:column;align-items:flex-start}.guest-body{display:block}}

/* ==========================================================================
   03. Pantalla publica de acceso
   Layout del login con selector de modulo a la izquierda y formulario a la
   derecha. Incluye variables visuales usadas por toda la app interna.
   ========================================================================== */
:root{
  --surface:#ffffff;
  --page:#f4f6f8;
  --ink:#17211f;
  --muted-ink:#60706b;
  --line:#d9e2df;
  --teal:#176f5d;
  --teal-strong:#0f5547;
  --rose:#a33b55;
  --gold:#b58b22;
}

body{background:var(--page);color:var(--ink)}
.guest-body{
  position:relative;
  isolation:isolate;
  align-items:stretch;
  background:
    linear-gradient(120deg,rgba(8,19,17,.18),rgba(14,44,38,.58)),
    url('../img/baco3.jpg') center/cover fixed no-repeat;
}
.guest-body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(180deg,rgba(255,255,255,.05) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(120deg,rgba(0,0,0,.55),transparent 72%);
}
.guest-container{width:100%;max-width:1180px;display:flex;align-items:center}
.access-shell{
  width:100%;
  display:grid;
  grid-template-columns:minmax(280px,.9fr) minmax(360px,1.1fr);
  min-height:680px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.55);
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 26px 70px rgba(6,18,15,.32);
  backdrop-filter:blur(18px);
  

}

.access-modules{display:flex;flex-direction:column;justify-content:space-between;gap:28px;padding:34px;background:rgba(248,250,249,.92);border-right:1px solid var(--line)}
.brand-block h1,.login-copy h2{margin:8px 0 12px;line-height:1.04;letter-spacing:0}
.brand-block h1{font-size:2.4rem;max-width:9ch}
.brand-block p,.login-copy p,.module-choice small,.hint-box p{color:var(--muted-ink);line-height:1.55}
.eyebrow{display:inline-flex;font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:0;color:var(--teal)}
.module-choice-list{display:grid;gap:12px}
.module-choice{display:grid;gap:8px;text-decoration:none;color:var(--ink);background:#fff;border:1px solid var(--line);border-left:4px solid transparent;border-radius:8px;padding:18px;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}
.module-choice:hover,.module-choice.is-active{border-color:#b8c8c3;border-left-color:var(--teal);box-shadow:0 10px 24px rgba(23,111,93,.12);transform:translateY(-1px)}
.module-choice:nth-child(2).is-active{border-left-color:var(--rose)}
.module-choice span{width:max-content;border:1px solid var(--line);border-radius:8px;padding:4px 10px;font-size:.78rem;color:var(--muted-ink);background:#f5f7f6}
.module-choice strong{font-size:1.25rem}
.access-login{display:flex;flex-direction:column;justify-content:center;gap:22px;padding:48px 56px}
.login-copy h2{font-size:2rem}
.access-form{display:grid;gap:16px}
.access-form label{display:grid;gap:8px;font-weight:700;color:#263330}
input,select,textarea{border-radius:8px;border-color:var(--line);min-height:50px}
input:focus,select:focus,textarea:focus{outline:3px solid rgba(23,111,93,.18);border-color:var(--teal)}
.btn{border-radius:8px}
.btn-primary{background:var(--teal)}
.btn-primary:hover{background:var(--teal-strong)}
.hint-box.compact{border-radius:8px;background:#f6f8f7;border:1px solid var(--line);padding:16px}
.hint-box.compact p{margin:.35rem 0}

@media (max-width:900px){
  .guest-container{padding:14px;align-items:stretch}
  .access-shell{grid-template-columns:1fr;min-height:auto}
  .access-modules{border-right:0;border-bottom:1px solid var(--line);padding:24px}
  .brand-block h1{max-width:none;font-size:2rem}
  .access-login{padding:26px}
}

/* ==========================================================================
   04. Shell interno de la aplicacion
   Estructura comun autenticada: sidebar, encabezado, contenedor principal,
   paneles, estados vacios y tablas. Este bloque soporta admin y usuarios.
   ========================================================================== */
html{min-height:100%}
body{min-height:100vh}
.guest-body{display:block}
.guest-container{min-height:100vh;width:100%;max-width:1120px;padding:36px 20px;margin:0 auto;display:grid;align-content:center;gap:16px}
.guest-container>.alert{width:100%;max-width:960px;margin:0 auto}
.access-shell{max-width:960px;margin:0 auto;min-height:560px;grid-template-columns:360px 1fr}
.access-modules{padding:28px}
.access-login{padding:34px 44px}
.brand-block h1{font-size:2rem}
.login-copy h2{font-size:1.75rem}
.module-choice{padding:16px}
.hint-box.compact{font-size:.95rem}

/* Cuerpo de aplicacion autenticada y navegacion lateral de administracion. */
.app-body{background:#f4f6f8;color:#16211e;min-height:100vh}
.app-body.has-sidebar{display:grid;grid-template-columns:280px 1fr}
.sidebar{position:sticky;top:0;height:100vh;background:#10231f;color:#fff;padding:24px;display:flex;flex-direction:column;gap:24px}
.sidebar-brand{display:grid;gap:6px}
.sidebar-brand span{font-size:.74rem;text-transform:uppercase;letter-spacing:0;color:#a7c7bd}
.sidebar-brand strong{font-size:1.45rem;line-height:1.1}
.sidebar-brand small{color:#b6cbc5;font-weight:700}
.sidebar-nav{display:grid;gap:10px}
.sidebar-nav a{display:grid;gap:4px;color:#e8f2ef;text-decoration:none;padding:14px;border-radius:8px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.04)}
.sidebar-nav a:hover{background:rgba(255,255,255,.10)}
.sidebar-nav small{color:#b6cbc5}
.sidebar-logout{margin-top:auto}
.sidebar-logout .btn{width:100%}
.app-main{padding:28px;max-width:1440px;width:100%}
.app-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}
.app-header h1{margin:6px 0 0;font-size:2rem;line-height:1.1}
.user-chip{display:grid;gap:2px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 14px;text-align:right}
.user-chip small{color:var(--muted-ink)}
.floating-logout{position:fixed;right:18px;top:18px}

/* Componentes internos reutilizables. */
.panel,.stat-card,.mini-card{border-radius:8px;box-shadow:none;border:1px solid var(--line);background:#fff}
.panel{padding:22px}
.section-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:18px}
.section-head h2{margin:4px 0 0;font-size:1.35rem}
.section-head p{margin:6px 0 0;color:var(--muted-ink);line-height:1.5}
.stats-grid{grid-template-columns:repeat(6,minmax(120px,1fr));gap:12px;margin-bottom:18px}
.stat-card{padding:16px}
.stat-card span{color:var(--muted-ink);font-size:.88rem}
.stat-card strong{font-size:1.8rem;margin-top:8px}
/* ==========================================================================
   05. Panel administrativo
   Tarjetas de metricas, solicitudes pendientes, acciones operativas y auditoria.
   ========================================================================== */
.admin-workspace{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;margin-bottom:18px}
.admin-side{display:grid;gap:18px;align-content:start}
.request-group+.request-group{margin-top:22px}
.request-group h3{margin:0 0 10px}
.request-row,.history-row,.simple-row,.audit-row{border:1px solid var(--line);border-radius:8px;background:#fbfcfc}
.request-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px;margin-bottom:10px}
.request-row small,.history-row small,.simple-row small,.audit-row span{display:block;color:var(--muted-ink);margin-top:4px}
.action-buttons{justify-content:flex-end}
.action-buttons .btn{min-height:40px;padding:9px 12px}
.compact-form{display:grid;gap:14px}
.compact-form label{display:grid;gap:8px;font-weight:700}
.mini-card{display:grid;gap:5px;padding:14px;margin-bottom:10px}
.audit-list{display:grid;gap:10px}
.audit-row{padding:13px 14px}
.empty-state{padding:14px;border:1px dashed var(--line);border-radius:8px;color:var(--muted-ink);background:#fbfcfc}
.admin-module-shell,.reports-shell{display:grid;gap:18px}
.branch-context-panel{margin-bottom:18px}
.branch-context-panel h2{margin:4px 0 8px;color:var(--text-strong)}
.branch-context-panel p{margin:0;color:var(--muted-ink);line-height:1.5}
.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.admin-form-grid label{display:grid;gap:8px;font-weight:800;color:#263330}
.admin-form-grid .form-wide{grid-column:1 / -1}
.admin-form-grid .btn{width:max-content;min-width:180px}
.report-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}

/* ==========================================================================
   06. Vistas de usuario heredadas
   Soporte para pantallas simples anteriores. Miscelaneos y Tablero modernos
   tienen bloques especificos mas abajo.
   ========================================================================== */
.user-body .app-main{max-width:1180px;margin:0 auto;padding:72px 20px 28px}
.user-body .app-header{padding-right:90px}
.user-workspace{display:grid;grid-template-columns:minmax(0,1.1fr) 360px;gap:18px;align-items:start}
.request-panel{min-height:420px}
.user-side{display:grid;gap:18px}
.history-list,.simple-list{display:grid;gap:10px;max-height:420px;overflow:auto}
.history-row{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;padding:12px}
.history-row small{grid-column:1 / -1}
.simple-row{padding:12px}
.table-scroll{border:1px solid var(--line);border-radius:8px;background:#fff}
table th{background:#f7f9f8;color:#4d5f59;font-size:.86rem;text-transform:uppercase;letter-spacing:0}
table td strong{display:block}
table td small{display:block;color:var(--muted-ink);margin-top:4px}

@media (max-width:1100px){
  .stats-grid{grid-template-columns:repeat(3,1fr)}
  .admin-workspace,.user-workspace{grid-template-columns:1fr}
}

@media (max-width:820px){
  .app-body.has-sidebar{display:block}
  .sidebar{position:relative;height:auto}
  .sidebar-nav{grid-template-columns:1fr}
  .app-main,.user-body .app-main{padding:20px 14px 90px}
  .app-header{display:grid}
  .user-body .app-header{padding-right:0}
  .floating-logout{left:14px;right:14px;top:auto;bottom:14px}
  .floating-logout .btn{width:100%}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .request-row{display:grid}
  .action-buttons{justify-content:start}
  .access-shell{grid-template-columns:1fr}
}

/* ==========================================================================
   07. Carrito base de miscelaneos
   Estilos generales para tarjetas de productos y filas del carrito. Luego son
   compactados por el bloque tactil de Miscelaneos.
   ========================================================================== */
.materials-shop{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px;align-items:start}
.materials-catalog{min-height:620px}
.material-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.material-card{display:grid;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;min-height:360px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.material-card:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(23,33,31,.10);border-color:#b9cac4}
.material-card img{width:100%;height:150px;object-fit:cover;background:#e9eeec}
.material-card-body{padding:14px 14px 8px;display:grid;align-content:start;gap:8px}
.material-card-body h3{margin:0;font-size:1.16rem;line-height:1.15}
.material-card-body p{margin:0;color:var(--muted-ink);line-height:1.45}
.material-card-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px;border-top:1px solid var(--line);margin-top:auto}
.material-card-foot strong{font-size:.92rem;color:#33433f}
.material-card-foot .btn{min-height:40px;padding:9px 13px}
.material-card-foot .btn:disabled{opacity:.55;cursor:not-allowed;background:#7b8a86}
.cart-column{display:grid;gap:18px;position:sticky;top:18px}
.cart-panel{display:grid;gap:16px}
.cart-empty{border:1px dashed var(--line);border-radius:8px;background:#f8faf9;padding:18px;display:grid;gap:6px;color:var(--muted-ink)}
.cart-empty strong{color:var(--ink)}
.cart-list{display:grid;gap:12px}
.cart-row{display:grid;grid-template-columns:72px 1fr auto;gap:12px;align-items:start;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:10px;transition:box-shadow .2s ease,border-color .2s ease}
.cart-row.is-highlighted{border-color:var(--teal);box-shadow:0 0 0 4px rgba(23,111,93,.12)}
.cart-row img{width:72px;height:72px;object-fit:cover;border-radius:8px;background:#e9eeec}
.cart-row-main{display:grid;gap:8px}
.cart-row-main strong{line-height:1.2}
.cart-row-main small{color:var(--muted-ink)}
.cart-row-main label{display:grid;gap:6px;font-size:.86rem;font-weight:700;color:#33433f}
.cart-row-main input[type=number]{min-height:42px;padding:8px 10px}
.cart-remove{width:34px;height:34px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#8d1d2c;font-size:1.3rem;line-height:1;cursor:pointer}
.cart-remove:hover{background:#fff1f2;border-color:#fecdd3}

@media (max-width:1100px){
  .materials-shop{grid-template-columns:1fr}
  .cart-column{position:relative;top:auto;grid-row:1}
}

@media (max-width:620px){
  .material-grid{grid-template-columns:1fr}
  .cart-row{grid-template-columns:58px 1fr auto}
  .cart-row img{width:58px;height:58px}
}

/* ==========================================================================
   08. Interfaz amplia profesional
   Navbar superior, dimensiones globales del shell moderno y ajustes de escala
   para que la app se sienta mas robusta en uso masivo.
   ========================================================================== */
:root{
  --nav-height:78px;
  --sidebar-width:300px;
  --sidebar-collapsed-width:88px;
  --content-max:1680px;
  --text-strong:#101816;
  --soft-shadow:0 16px 36px rgba(16,24,22,.08);
}

/* Navbar superior compartido por usuarios y administradores. */
body{font-size:17px}
.main-navbar{position:sticky;top:0;z-index:30;height:var(--nav-height);display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:26px;padding:0 32px;background:rgba(255,255,255,.96);border-bottom:1px solid var(--line);backdrop-filter:blur(16px)}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--text-strong);min-width:270px}
.brand img{width:46px;height:46px;border-radius:8px}
.brand span{display:grid;gap:2px}
.brand strong{font-size:1.12rem;line-height:1;letter-spacing:0}
.brand small{color:var(--muted-ink);font-size:.84rem}
.navbar-toggle{display:none}
.navbar-menu{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:26px;min-width:0}
.navbar-links{display:flex;align-items:center;gap:8px}
.navbar-links a{text-decoration:none;color:#31433e;font-weight:700;padding:10px 14px;border-radius:8px}
.navbar-links a:hover{background:#edf4f1;color:var(--teal-strong)}
.navbar-user{display:flex;align-items:center;gap:12px}
.navbar-user>div:not(.user-avatar){display:grid;gap:2px;text-align:right}
.navbar-user strong{font-size:.96rem;line-height:1.1}
.navbar-user small{color:var(--muted-ink)}
.branch-chip{display:grid;gap:2px;text-align:right;border:1px solid var(--line);border-radius:8px;background:#f7faf9;padding:8px 12px;min-width:170px}
.branch-chip span{font-size:.72rem;text-transform:uppercase;color:var(--muted-ink);font-weight:800}
.branch-chip strong{font-size:.92rem;color:var(--teal-strong)}
.user-avatar{width:42px;height:42px;border-radius:8px;display:grid;place-items:center;background:#12342d;color:#fff;font-weight:800}
.navbar-user .btn{min-height:40px;padding:9px 13px}

/* Reacomodo del shell cuando existe navbar superior mas sidebar lateral. */
.app-body.has-sidebar{grid-template-columns:var(--sidebar-width) 1fr;grid-template-rows:var(--nav-height) 1fr}
.has-sidebar .main-navbar{grid-column:1 / -1}
.has-sidebar .navbar-menu{grid-template-columns:auto;justify-self:end}
.has-sidebar .navbar-links{display:none}
.sidebar{grid-row:2;top:var(--nav-height);height:calc(100vh - var(--nav-height));background:#10231f;padding:26px;overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable}
.sidebar::-webkit-scrollbar{width:10px}
.sidebar::-webkit-scrollbar-track{background:#10231f}
.sidebar::-webkit-scrollbar-thumb{background:#35544c;border-radius:8px;border:2px solid #10231f}
.sidebar-nav{padding-bottom:18px}
.sidebar-collapse-toggle{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:44px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:rgba(255,255,255,.06);color:#e8f2ef;font-weight:900;cursor:pointer}
.sidebar-collapse-toggle:hover{background:rgba(255,255,255,.12)}
.sidebar-collapse-toggle span{width:20px;height:20px;display:inline-block;position:relative;border:1px solid rgba(255,255,255,.24);border-radius:8px}
.sidebar-collapse-toggle span::before,.sidebar-collapse-toggle span::after{content:"";position:absolute;left:6px;width:8px;height:2px;border-radius:2px;background:currentColor;transform-origin:left center}
.sidebar-collapse-toggle span::before{top:7px;transform:rotate(-38deg)}
.sidebar-collapse-toggle span::after{top:11px;transform:rotate(38deg)}
.sidebar-collapse-toggle strong{font-size:.9rem}
.sidebar-label{display:block;margin:12px 4px 4px;color:#a7c7bd;font-size:.72rem;text-transform:uppercase;font-weight:900;letter-spacing:0}
.app-body.has-sidebar.is-sidebar-animating{transition:grid-template-columns .22s ease}
.app-body.has-sidebar.is-sidebar-animating .sidebar{transition:padding .22s ease,gap .22s ease}
.admin-sidebar-collapsed .app-body.has-sidebar{grid-template-columns:var(--sidebar-collapsed-width) 1fr}
.admin-sidebar-collapsed .sidebar{padding:18px 14px;gap:16px;overflow-x:hidden}
.admin-sidebar-collapsed .sidebar-brand{place-items:center;text-align:center}
.admin-sidebar-collapsed .sidebar-brand span,
.admin-sidebar-collapsed .sidebar-brand small,
.admin-sidebar-collapsed .sidebar-label,
.admin-sidebar-collapsed .sidebar-nav a strong,
.admin-sidebar-collapsed .sidebar-nav a small,
.admin-sidebar-collapsed .sidebar-collapse-toggle strong{display:none}
.admin-sidebar-collapsed .sidebar-brand strong{font-size:1rem}
.admin-sidebar-collapsed .sidebar-brand strong::after{content:"Admin"}
.admin-sidebar-collapsed .sidebar-brand strong{font-size:0}
.admin-sidebar-collapsed .sidebar-brand strong::after{font-size:1rem}
.admin-sidebar-collapsed .sidebar-collapse-toggle{min-height:46px;padding:0}
.admin-sidebar-collapsed .sidebar-collapse-toggle span::before{left:7px;transform:rotate(38deg)}
.admin-sidebar-collapsed .sidebar-collapse-toggle span::after{left:7px;transform:rotate(-38deg)}
.admin-sidebar-collapsed .sidebar-nav{gap:8px}
.admin-sidebar-collapsed .sidebar-nav a{display:grid;place-items:center;min-height:48px;padding:0}
.admin-sidebar-collapsed .sidebar-nav a::before{content:attr(data-short);display:grid;place-items:center;width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.10);color:#e8f2ef;font-weight:900}
.app-body.has-sidebar{
  --nav-height:64px;
  --sidebar-width:240px;
  --sidebar-collapsed-width:72px;
  --content-max:1800px;
  font-size:14px;
}
.has-sidebar .main-navbar{gap:18px;padding:0 24px}
.has-sidebar .brand{min-width:220px;gap:11px}
.has-sidebar .brand img{width:38px;height:38px}
.has-sidebar .brand strong{font-size:1rem}
.has-sidebar .brand small{font-size:.76rem}
.has-sidebar .navbar-user{gap:9px}
.has-sidebar .branch-chip{min-width:140px;padding:7px 10px}
.has-sidebar .branch-chip strong{font-size:.82rem}
.has-sidebar .user-avatar{width:36px;height:36px}
.has-sidebar .navbar-user .btn{min-height:36px;padding:7px 11px}
.has-sidebar .sidebar{padding:20px;gap:18px}
.has-sidebar .sidebar-brand strong{font-size:1.2rem}
.has-sidebar .sidebar-brand small{font-size:.78rem}
.has-sidebar .sidebar-nav{gap:8px}
.has-sidebar .sidebar-nav a{padding:11px 12px}
.has-sidebar .sidebar-nav a strong{font-size:.92rem}
.has-sidebar .sidebar-nav a small{font-size:.78rem}
.has-sidebar .sidebar-collapse-toggle{min-height:38px}
.has-sidebar .app-main{padding:26px 30px 38px}
.has-sidebar .app-header{margin-bottom:18px}
.has-sidebar .app-header h1{font-size:1.88rem}
.has-sidebar .panel{padding:22px}
.has-sidebar .section-head{margin-bottom:14px}
.has-sidebar .section-head h2{font-size:1.36rem}
.has-sidebar .section-head p{font-size:.9rem}
.has-sidebar .btn{min-height:42px;padding:9px 13px}
.has-sidebar input,.has-sidebar select,.has-sidebar textarea{min-height:46px;padding:11px 13px;font-size:.92rem}
.has-sidebar .admin-hero h2,.has-sidebar .admin-module-header h2{font-size:1.6rem}
.has-sidebar .admin-hero p,.has-sidebar .admin-module-header p{font-size:.9rem}
.has-sidebar .stat-card{padding:16px}
.has-sidebar .stat-card strong{font-size:1.8rem}
.has-sidebar .admin-stats-grid .stat-card{min-height:104px}
.admin-sidebar-collapsed .app-body.has-sidebar .sidebar{padding:14px 10px;gap:14px}
.admin-sidebar-collapsed .app-body.has-sidebar .sidebar-brand strong::after{font-size:.9rem}
.admin-sidebar-collapsed .app-body.has-sidebar .sidebar-collapse-toggle{min-height:40px;padding:0}
.admin-sidebar-collapsed .app-body.has-sidebar .sidebar-nav a{display:grid;place-items:center;min-height:42px;padding:0}
.admin-sidebar-collapsed .app-body.has-sidebar .sidebar-nav a::before{width:30px;height:30px;font-size:.84rem}
.app-main{grid-column:2;grid-row:2;max-width:var(--content-max);padding:34px 38px 46px}
.user-body .app-main{max-width:var(--content-max);padding:34px 38px 46px}
.app-header{margin-bottom:26px}
.app-header h1{font-size:2.35rem;font-weight:800;color:var(--text-strong)}
.eyebrow{font-size:.78rem;letter-spacing:0}
.panel,.stat-card,.mini-card{border-color:#d7e2de;box-shadow:var(--soft-shadow)}
.panel{padding:28px}
.section-head h2{font-size:1.7rem;letter-spacing:0;color:var(--text-strong)}
.section-head p{font-size:1.02rem;max-width:780px}
input,select,textarea{font-size:1rem;min-height:56px;padding:15px 16px}
textarea{min-height:128px}
.btn{font-weight:800;min-height:52px}
.btn-xl{min-height:64px;font-size:1.08rem}
.alert{max-width:var(--content-max);border-radius:8px;font-weight:700}

/* Escala visual inicial del flujo de productos y carrito. */
.materials-shop{grid-template-columns:minmax(0,1fr) 440px;gap:24px}
.materials-catalog{min-height:calc(100vh - 170px)}
.material-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.material-card{min-height:440px;border-radius:8px}
.material-card img{height:210px}
.material-card-body{padding:18px;gap:10px}
.material-card-body h3{font-size:1.48rem}
.material-card-body p{font-size:1rem}
.material-card .badge{font-size:.9rem;padding:7px 11px}
.material-card-foot{padding:18px}
.material-card-foot strong{font-size:1rem}
.material-card-foot .btn{min-width:118px}
.cart-column{top:102px}
.cart-panel{gap:18px}
.cart-panel .section-head h2{font-size:1.9rem}
.cart-empty{padding:22px;font-size:1.02rem}
.cart-row{grid-template-columns:92px 1fr auto;padding:14px;gap:14px}
.cart-row img{width:92px;height:92px}
.cart-row-main strong{font-size:1.08rem}
.cart-row-main input[type=number]{max-width:150px;min-height:48px;font-weight:800}
.cart-remove{width:38px;height:38px}
.history-row{font-size:1rem;padding:14px}
.catalog-summary{display:grid;place-items:center;text-align:center;min-width:132px;border:1px solid var(--line);border-radius:8px;background:#f7faf9;padding:12px 16px}
.catalog-summary strong{font-size:1.8rem;line-height:1;color:var(--teal-strong)}
.catalog-summary span{font-size:.86rem;color:var(--muted-ink);margin-top:4px}
.cart-summary-line{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:8px;background:#f7faf9;padding:14px 16px}
.cart-summary-line span{color:var(--muted-ink);font-weight:700}
.cart-summary-line strong{font-size:1.4rem;color:var(--teal-strong)}

/* Ajustes de densidad para admin dentro del shell moderno. */
.stats-grid{gap:16px}
.stat-card{padding:20px}
.stat-card strong{font-size:2.25rem}
.admin-workspace{grid-template-columns:minmax(0,1fr) 410px;gap:24px}
.request-row{padding:18px}
.request-row strong{font-size:1.08rem}
.hero-card,.auth-card,.catalog-card,.hint-box,.image-placeholder,.badge{border-radius:8px}
.eyebrow,.sidebar-brand span,table th{letter-spacing:0}

/* Portada administrativa separada por modulo. */
.admin-hero{display:flex;align-items:center;justify-content:space-between;gap:22px;margin-bottom:18px}
.admin-hero h2{margin:4px 0 8px;font-size:2rem;color:var(--text-strong)}
.admin-hero p{margin:0;color:var(--muted-ink);line-height:1.5;max-width:820px}
.admin-hero-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.dashboard-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px;align-items:stretch}
.chart-panel{display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px;min-height:360px}
.chart-box{position:relative;min-height:280px;width:100%}
.chart-box canvas{width:100%!important;height:100%!important}
.admin-stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:14px;margin-bottom:26px}
.balanced-stats .stat-card{text-align:center}
.admin-stats-grid .stat-card{min-height:126px;display:grid;align-content:center}
.admin-module-section{display:grid;gap:18px;margin-bottom:28px;scroll-margin-top:calc(var(--nav-height) + 18px)}
.admin-module-header{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;padding:4px 2px 0}
.admin-module-header h2{margin:5px 0 8px;font-size:2rem;color:var(--text-strong)}
.admin-module-header p{margin:0;color:var(--muted-ink);line-height:1.5;max-width:820px}
.module-metrics{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.module-metrics span{display:grid;place-items:center;min-width:132px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px 14px;color:var(--muted-ink);font-weight:800;box-shadow:var(--soft-shadow)}
.module-metrics strong{font-size:1.8rem;line-height:1;color:var(--teal-strong)}
.admin-section-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}
.admin-list-panel{display:grid;gap:14px;align-content:start;min-height:360px}
.admin-request-list{display:grid;gap:12px;max-height:680px;overflow:auto;padding-right:4px}
.admin-request-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:16px}
.request-main{display:grid;gap:7px;min-width:0}
.request-title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.request-title-row strong,.request-main>strong{font-size:1.08rem;color:var(--text-strong);line-height:1.2}
.request-main p{margin:0;color:#33433f;line-height:1.4}
.request-main small{color:var(--muted-ink);font-weight:700}
.request-actions{display:grid;gap:8px;justify-items:end}
.request-actions .btn{min-height:44px;padding:9px 12px;white-space:nowrap}
.split-actions{grid-template-columns:repeat(3,auto)}
.split-actions form{display:grid}
.admin-collapsible{padding:0;overflow:hidden}
.admin-collapsible summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 24px}
.admin-collapsible summary::-webkit-details-marker{display:none}
.admin-collapsible summary span{display:grid;gap:5px}
.admin-collapsible summary strong{font-size:1.2rem;color:var(--text-strong)}
.admin-collapsible summary small{color:var(--muted-ink);font-weight:700}
.admin-collapsible summary b{border:1px solid var(--line);border-radius:8px;background:#f7faf9;color:var(--teal-strong);padding:8px 12px;white-space:nowrap}
.admin-collapsible .key-admin-grid{max-height:620px;overflow:auto;padding:0 24px 24px}
.stock-list{display:grid;gap:10px;max-height:680px;overflow:auto;padding-right:4px}
.admin-audit-panel{margin-top:8px}
.compact-list{max-height:420px}
.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:14px}
.wide-card{grid-template-columns:repeat(2,minmax(0,1fr));align-items:start}
.wide-card>div,.wide-card .form-wide,.wide-card .btn{grid-column:1 / -1}
.product-cost{display:block;color:var(--teal-strong);font-weight:900;line-height:1.2}
.admin-catalog-table{max-height:680px;overflow:auto}
.admin-catalog-table table{min-width:1080px;table-layout:fixed}
.admin-catalog-table th:nth-child(1),.admin-catalog-table td:nth-child(1){width:34%}
.admin-catalog-table th:nth-child(2),.admin-catalog-table td:nth-child(2){width:16%}
.admin-catalog-table th:nth-child(3),.admin-catalog-table td:nth-child(3){width:13%}
.admin-catalog-table th:nth-child(4),.admin-catalog-table td:nth-child(4){width:17%}
.admin-catalog-table th:nth-child(5),.admin-catalog-table td:nth-child(5){width:10%}
.admin-catalog-table th:nth-child(6),.admin-catalog-table td:nth-child(6){width:10%}
.admin-catalog-table th,.admin-catalog-table td{vertical-align:top;white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.35}
.admin-catalog-table td strong{line-height:1.25}
.admin-catalog-table td small{display:block;color:var(--muted-ink);margin-top:4px}
.admin-catalog-table .btn{min-height:40px;padding:8px 12px;white-space:nowrap}
.permissions-shell{grid-template-columns:minmax(360px,.85fr) minmax(0,1.15fr);align-items:start}
.permission-form{align-items:end}
.permission-badge{display:inline-flex;align-items:center;min-height:34px;border:1px solid var(--line);border-radius:8px;background:#f7faf9;color:var(--teal-strong);font-weight:900;padding:6px 10px}
.permission-checks{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;border:0;margin:0;padding:0;min-width:0}
.permission-checks legend{grid-column:1 / -1;font-weight:800;color:#263330}
.permission-checks label{display:flex;align-items:center;gap:8px;min-height:46px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:10px 12px;font-weight:800;color:#263330}
.permission-checks input{width:18px;height:18px;accent-color:var(--teal)}
.permission-checks input:disabled+span{color:var(--muted-ink)}
.permission-checks small{grid-column:1 / -1;color:var(--muted-ink);font-weight:700;line-height:1.35}
.permissions-table table{min-width:900px;table-layout:fixed}
.permissions-table th,.permissions-table td{vertical-align:top;white-space:normal;overflow-wrap:anywhere;line-height:1.35}
.permissions-table th:nth-child(1),.permissions-table td:nth-child(1){width:28%}
.permissions-table th:nth-child(2),.permissions-table td:nth-child(2){width:16%}
.permissions-table th:nth-child(3),.permissions-table td:nth-child(3){width:17%}
.permissions-table th:nth-child(4),.permissions-table td:nth-child(4){width:18%}
.permissions-table th:nth-child(5),.permissions-table td:nth-child(5){width:10%}
.permissions-table th:nth-child(6),.permissions-table td:nth-child(6){width:11%}
.permissions-table .btn{min-height:40px;padding:8px 12px;white-space:nowrap}
.purchases-shell{grid-template-columns:minmax(0,1.15fr) minmax(360px,.85fr);align-items:start}
.purchase-picker{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end;margin-bottom:16px}
.purchase-picker label,.purchase-notes{display:grid;gap:8px;font-weight:800;color:#263330}
.purchase-table table{min-width:980px;table-layout:fixed}
.purchase-table th,.purchase-table td,.purchase-history-table th,.purchase-history-table td{vertical-align:top;white-space:normal;overflow-wrap:anywhere;line-height:1.35}
.purchase-table th:nth-child(1),.purchase-table td:nth-child(1){width:30%}
.purchase-table th:nth-child(2),.purchase-table td:nth-child(2){width:13%}
.purchase-table th:nth-child(3),.purchase-table td:nth-child(3){width:18%}
.purchase-table th:nth-child(4),.purchase-table td:nth-child(4){width:16%}
.purchase-table th:nth-child(5),.purchase-table td:nth-child(5){width:13%}
.purchase-table th:nth-child(6),.purchase-table td:nth-child(6){width:10%}
.purchase-table input{min-height:44px;padding:9px 10px}
.purchase-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0}
.purchase-summary span{display:grid;gap:4px;border:1px solid var(--line);border-radius:8px;background:#f7faf9;padding:12px;color:var(--muted-ink);font-weight:800}
.purchase-summary strong{font-size:1.35rem;color:var(--teal-strong)}
.purchase-notes{margin-bottom:14px}
.purchase-history-table table{min-width:860px}
.purchase-history-table .btn{min-height:40px;padding:8px 12px}
.purchase-history-action{margin:0}
.muted-cell{display:inline-flex;align-items:center;min-height:40px;color:var(--muted-ink);font-weight:800}
.purchase-table tr.is-highlighted{outline:3px solid rgba(23,111,93,.18);outline-offset:-3px}
.purchase-workspace{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:22px;align-items:start;margin:8px 0 18px}
.purchase-form-column{position:sticky;top:calc(var(--nav-height) + 18px);min-width:0}
.purchase-form-panel{display:grid;gap:13px;max-height:calc(100vh - var(--nav-height) - 48px);overflow:auto}
.operation-type-toggle{display:grid;grid-template-columns:1fr 1fr;gap:10px;border:0;margin:0;padding:0;min-width:0}
.operation-type-toggle legend{grid-column:1 / -1;margin-bottom:2px;font-weight:900;color:#263330}
.operation-option{position:relative;display:grid;min-width:0}
.operation-option input{position:absolute;opacity:0;pointer-events:none}
.operation-option span{display:grid;gap:4px;min-height:68px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:11px 12px;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease,background .18s ease}
.operation-option strong{color:var(--text-strong)}
.operation-option small{color:var(--muted-ink);font-weight:700;line-height:1.3}
.operation-option input:checked+span{border-color:var(--teal);background:#f4faf8;box-shadow:0 0 0 3px rgba(23,111,93,.10)}
.purchase-empty{border:1px dashed var(--line);border-radius:8px;background:#f8faf9;padding:14px 16px;display:grid;gap:6px;color:var(--muted-ink)}
.purchase-empty strong{color:var(--ink)}
.purchase-rate-field{display:grid;gap:8px;font-weight:800;color:#263330}
.purchase-rate-field small{color:var(--muted-ink);font-weight:700;line-height:1.35}
.purchase-entry-list{display:grid;gap:10px;max-height:300px;overflow:auto;padding-right:6px}
.purchase-entry-row{display:grid;grid-template-columns:minmax(76px,.6fr) minmax(118px,.9fr) minmax(0,1.2fr) minmax(96px,.65fr);gap:10px;align-items:end;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:12px;transition:box-shadow .2s ease,border-color .2s ease}
.purchase-entry-row.is-highlighted{border-color:var(--teal);box-shadow:0 0 0 4px rgba(23,111,93,.12)}
.purchase-entry-product{grid-column:1 / -1;display:grid;gap:5px;min-width:0}
.purchase-entry-product strong{line-height:1.32;color:var(--text-strong);overflow-wrap:break-word;word-break:normal}
.purchase-entry-product small{color:var(--muted-ink);font-weight:800}
.purchase-entry-row label{display:grid;gap:6px;color:#33433f;font-size:.82rem;font-weight:800;min-width:0}
.purchase-entry-row input{min-height:40px;padding:8px 10px}
.purchase-entry-totals{grid-column:3;display:grid;grid-template-columns:1fr 1fr;gap:8px}
.purchase-entry-totals span{display:grid;gap:3px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px 9px;color:var(--muted-ink);font-size:.78rem;font-weight:800;min-width:0}
.purchase-entry-totals strong{font-size:1rem;color:var(--teal-strong);overflow-wrap:break-word}
.purchase-entry-row .btn{grid-column:4;min-height:40px;padding:8px 10px;width:100%}
.purchase-catalog{display:grid;grid-template-rows:auto auto minmax(0,1fr);height:calc(100vh - var(--nav-height) - 48px);min-height:520px;overflow:hidden}
.purchase-product-grid{min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));align-content:start;gap:10px;padding-right:4px}
.purchase-product-card{display:grid;grid-template-rows:auto minmax(0,1fr) auto;border:1px solid var(--line);border-radius:8px;background:#fff;overflow:hidden;min-height:238px;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}
.purchase-product-card:hover{border-color:#b9cac4;box-shadow:0 14px 28px rgba(23,33,31,.10);transform:translateY(-1px)}
.purchase-product-card img{width:100%;height:88px;object-fit:cover;background:#e9eeec}
.purchase-product-card>div{display:grid;align-content:start;gap:6px;padding:10px;min-width:0}
.purchase-product-card h3{margin:0;font-size:.98rem;line-height:1.18;color:var(--text-strong);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.purchase-product-card p{margin:0;color:var(--muted-ink);font-size:.82rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.purchase-product-card small{color:var(--muted-ink);font-weight:800}
.purchase-product-card .btn{margin:0 10px 10px;width:calc(100% - 20px);min-height:40px;padding:8px 10px}
.purchase-history-panel{margin-top:18px}
.app-modal{position:fixed;inset:0;z-index:80;display:none;place-items:center;padding:18px;background:rgba(7,18,16,.56)}
.app-modal.is-open{display:grid}
.has-modal-open{overflow:hidden}
.app-modal-panel{width:min(920px,100%);max-height:min(86vh,860px);overflow:auto;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 24px 70px rgba(8,18,16,.32);padding:22px}
.modal-close{width:42px;height:42px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#22312e;font-size:1.4rem;line-height:1;cursor:pointer}
.misc-admin-focus{display:grid;margin-bottom:22px}
.misc-requests-panel{min-height:0}
.misc-approval-list{display:grid;gap:16px}
.misc-approval-card{display:grid;grid-template-columns:minmax(0,1fr) 210px;gap:18px;align-items:stretch;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:18px}
.misc-approval-main{display:grid;gap:10px;min-width:0}
.misc-request-meta{display:flex;flex-wrap:wrap;gap:8px}
.misc-request-meta span{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--teal-strong);font-weight:900;padding:7px 10px}
.misc-item-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px;margin-top:2px}
.misc-item-list span{border:1px solid #d7e2de;border-radius:8px;background:#fff;padding:10px 12px;color:#263330;font-weight:800;line-height:1.25}
.misc-approval-actions{align-content:center;justify-items:stretch}
.misc-approval-actions .btn,.misc-approval-actions form{width:100%}
.admin-shortcuts-panel{display:grid;gap:16px}
.admin-shortcuts-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.admin-shortcuts-grid .mini-card{display:grid;gap:6px;text-decoration:none;color:inherit;min-height:116px;align-content:center;transition:border-color .18s ease,transform .18s ease}
.admin-shortcuts-grid .mini-card:hover{border-color:#176f5d;transform:translateY(-1px)}
.audit-filter-panel{margin-bottom:18px}
.audit-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr));align-items:end}
.filter-actions{display:flex;gap:10px;align-items:center}
.filter-actions .btn{flex:1}
.reports-shell{display:grid;gap:24px}
.reports-shell .admin-section-grid .admin-list-panel{grid-column:1 / -1;min-height:0}
.reports-shell .admin-stats-grid{margin-bottom:0}
.report-hero-actions{display:flex;align-items:center;justify-content:space-between;gap:20px}
.report-picker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.report-picker-card{display:grid;gap:10px;text-decoration:none;color:inherit;min-height:220px;align-content:center;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}
.report-picker-card:hover{transform:translateY(-2px);border-color:#176f5d;box-shadow:0 18px 46px rgba(18,53,45,.14)}
.report-picker-card strong{font-size:1.55rem;color:var(--text-strong);line-height:1.15}
.report-picker-card small{font-size:1rem;color:var(--muted-ink);line-height:1.5;max-width:560px}
.report-stats-grid .stat-card strong{font-size:1.9rem}
.report-export-form{display:grid;grid-template-columns:minmax(170px,1fr) minmax(150px,1fr) auto;gap:8px;align-items:center}
.report-export-form select{min-height:52px;background:#fff}
.report-export-form .btn{white-space:nowrap}
.table-scroll td small{display:block;color:var(--muted-ink);font-weight:700;margin-top:4px}

@media (max-width:1200px){
  .materials-shop,.admin-workspace{grid-template-columns:1fr}
  .dashboard-overview-grid{grid-template-columns:1fr}
  .report-picker-grid{grid-template-columns:1fr}
  .admin-shortcuts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .audit-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .report-export-form{grid-template-columns:1fr}
  .admin-stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .admin-section-grid,.permissions-shell,.purchases-shell{grid-template-columns:1fr}
  .reports-shell .admin-section-grid .admin-list-panel{grid-column:auto}
  .cart-column{position:relative;top:auto;grid-row:1}
}

@media (max-width:980px){
  .purchase-workspace{grid-template-columns:1fr}
  .purchase-form-column{position:relative;top:auto}
  .purchase-form-panel{max-height:none;overflow:visible}
  .operation-type-toggle{grid-template-columns:1fr}
  .purchase-catalog{height:auto;min-height:0;overflow:visible}
  .purchase-product-grid{max-height:none;overflow:visible}
  .purchase-entry-list{max-height:420px;overflow:auto}
}

@media (max-width:920px){
  .main-navbar{height:auto;min-height:64px;grid-template-columns:minmax(0,1fr) auto;padding:10px 14px;gap:10px}
  .navbar-toggle{position:relative;display:inline-grid;place-items:center;width:46px;height:46px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text-strong);cursor:pointer}
  .navbar-toggle span{grid-area:1 / 1;display:block;width:22px;height:2px;border-radius:2px;background:currentColor;transition:transform .18s ease,opacity .18s ease}
  .navbar-toggle span:nth-child(1){transform:translateY(-7px)}
  .navbar-toggle span:nth-child(2){transform:translateY(0)}
  .navbar-toggle span:nth-child(3){transform:translateY(7px)}
  .main-navbar.is-open .navbar-toggle span:nth-child(1){transform:translateY(0) rotate(45deg)}
  .main-navbar.is-open .navbar-toggle span:nth-child(2){opacity:0}
  .main-navbar.is-open .navbar-toggle span:nth-child(3){transform:translateY(0) rotate(-45deg)}
  .navbar-menu{grid-column:1 / -1;display:none;grid-template-columns:1fr;gap:12px;padding:12px 0 4px;border-top:1px solid var(--line)}
  .main-navbar.is-open .navbar-menu{display:grid}
  .has-sidebar .navbar-menu{grid-template-columns:1fr;justify-self:stretch}
  .has-sidebar .navbar-links{display:grid}
  .navbar-links{display:grid;grid-template-columns:1fr;gap:8px;overflow:visible;padding-bottom:0}
  .navbar-links a{padding:13px 14px;background:#f1f6f4;border:1px solid var(--line)}
  .navbar-user{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
  .branch-chip{text-align:left;min-width:0}
  .admin-form-grid{grid-template-columns:1fr}
  .app-body.has-sidebar{display:block}
  .sidebar{display:none}
  .has-sidebar .main-navbar{grid-column:auto}
  .app-main,.user-body .app-main{padding:24px 16px 96px}
  .admin-hero,.admin-module-header{display:grid;align-items:start}
  .report-hero-actions{display:grid;align-items:start}
  .admin-hero-actions,.module-metrics{justify-content:start}
  .admin-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .chart-panel{min-height:310px}
  .chart-box{min-height:230px}
  .admin-request-card{grid-template-columns:1fr}
  .misc-approval-card{grid-template-columns:1fr}
  .misc-item-list{grid-template-columns:1fr}
  .admin-card-grid{grid-template-columns:1fr}
  .wide-card{grid-template-columns:1fr}
  .request-actions{justify-items:stretch}
  .request-actions .btn,.request-actions form{width:100%}
  .split-actions{grid-template-columns:1fr}
  .admin-shortcuts-grid,
  .audit-filter-grid{grid-template-columns:1fr}
  .filter-actions{display:grid}
  .admin-collapsible summary{align-items:flex-start}
  .material-grid{grid-template-columns:1fr}
}

/* ==========================================================================
   09. Miscelaneos tactil
   Pantalla principal de solicitudes de insumos. Mantiene carrito a la izquierda
   y catalogo a la derecha, con scroll interno apto para mouse y tactil.
   ========================================================================== */
.route-miscelaneos .app-header{display:none}
.route-miscelaneos .app-main{max-width:none;padding:18px 24px 24px}
.route-miscelaneos.user-body .app-main{padding:18px 24px 24px}
/* Contenedor 40/60: carrito operativo y catalogo de productos. */
.route-miscelaneos .materials-shop{
  height:calc(100vh - var(--nav-height) - 42px);
  min-height:620px;
  display:grid;
  grid-template-columns:minmax(440px,4fr) minmax(0,6fr);
  gap:18px;
  align-items:stretch;
}
/* Columna del carrito, siempre visible en escritorio. */
.route-miscelaneos .cart-column{
  position:relative;
  top:auto;
  display:grid;
  grid-template-rows:minmax(0,1fr);
  gap:14px;
  min-width:0;
  min-height:0;
}
.route-miscelaneos .materials-catalog,
.route-miscelaneos .cart-panel,
.route-miscelaneos .history-panel{
  min-height:0;
  padding:18px;
}
.route-miscelaneos .materials-catalog,
.route-miscelaneos .cart-panel{
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr);
}
.route-miscelaneos .cart-panel{
  grid-template-rows:auto auto minmax(0,1fr) auto auto;
}
.route-miscelaneos .compact-head{
  align-items:center;
  margin-bottom:12px;
}
.route-miscelaneos .compact-head h2{
  font-size:1.55rem;
  margin-top:2px;
}
.route-miscelaneos .search-input{
  margin-bottom:12px;
  min-height:52px;
}
/* Catalogo compacto con scroll propio para evitar desplazar toda la pagina. */
.route-miscelaneos .material-grid{
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  grid-auto-rows:auto;
  align-content:start;
  align-items:start;
  gap:12px;
  padding-right:4px;
}
.route-miscelaneos .material-card{
  min-height:230px;
  height:auto;
  min-width:0;
  grid-template-rows:auto minmax(0,1fr) auto;
  align-content:stretch;
}
.route-miscelaneos .material-card img{height:96px}
.route-miscelaneos .material-card-body{padding:10px 12px;gap:7px;min-width:0}
.route-miscelaneos .material-card-body h3{
  font-size:1.08rem;
  line-height:1.18;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.route-miscelaneos .material-card-body p{
  font-size:.9rem;
  line-height:1.3;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.route-miscelaneos .material-card .badge{font-size:.78rem;padding:4px 8px}
.route-miscelaneos .product-cost{font-size:.82rem}
.route-miscelaneos .material-card-foot{padding:10px 12px;gap:8px;align-items:center}
.route-miscelaneos .material-card-foot strong{font-size:.88rem}
.route-miscelaneos .material-card-foot .btn{
  min-height:46px;
  min-width:104px;
}
/* Lista de items del carrito con scroll interno. */
.route-miscelaneos .cart-list{
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  padding-right:4px;
}
.route-miscelaneos .cart-row{
  grid-template-columns:76px 1fr auto;
  padding:12px;
}
.route-miscelaneos .cart-row img{
  width:76px;
  height:76px;
}
.route-miscelaneos .cart-empty{padding:18px}
.route-miscelaneos .cart-panel textarea{min-height:86px}
.route-miscelaneos .cart-summary-line{min-width:92px}

@media (max-width:1180px){
  .route-miscelaneos .materials-shop{
    height:auto;
    min-height:0;
    grid-template-columns:1fr;
  }
  .route-miscelaneos .cart-column{grid-row:1}
  .route-miscelaneos .material-grid,
  .route-miscelaneos .cart-list{max-height:none;overflow:visible}
}

@media (max-width:720px){
  .route-miscelaneos .app-main,
  .route-miscelaneos.user-body .app-main{padding:12px}
  .route-miscelaneos .materials-shop{gap:12px}
  .route-miscelaneos .materials-catalog,
  .route-miscelaneos .cart-panel,
  .route-miscelaneos .history-panel{padding:14px}
  .route-miscelaneos .material-grid{grid-template-columns:1fr;gap:12px}
  .route-miscelaneos .material-card{min-height:0}
  .route-miscelaneos .material-card img{height:120px}
  .route-miscelaneos .material-card-foot{display:grid}
  .route-miscelaneos .material-card-foot .btn{width:100%}
}

/* ==========================================================================
   10. Historiales buscables
   Pantallas de consulta para Miscelaneos y Tablero. Incluye filtros, metricas,
   cards de resultado, estados visuales y acciones como cancelar.
   ========================================================================== */
.route-miscelaneos-historial .app-main{max-width:none;padding:26px 32px 40px}
.history-workspace{display:grid;gap:18px}
.history-hero{display:flex;align-items:center;justify-content:space-between;gap:18px}
.history-hero h2{font-size:2.2rem;margin:4px 0 0;color:var(--text-strong)}
.history-metrics{display:flex;gap:12px}
.history-metrics div{min-width:150px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:14px 18px;text-align:center;box-shadow:var(--soft-shadow)}
.history-metrics strong{display:block;font-size:2rem;color:var(--teal-strong);line-height:1}
.history-metrics span{color:var(--muted-ink);font-weight:700}
/* Barra de filtros horizontal en escritorio; cae a columnas en mobile. */
.history-filters{display:grid;grid-template-columns:minmax(280px,1fr) 220px 180px 180px auto auto;gap:14px;align-items:end;padding:18px}
.history-filters label{display:grid;gap:6px;font-weight:800;color:#263330}
.history-filters .btn{min-height:56px}
.history-results{display:grid;gap:12px;padding:18px;min-height:420px}
/* Card de solicitud: informacion a la izquierda y estado/acciones a la derecha. */
.history-card{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:18px;align-items:center;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:18px}
.history-card-main{display:grid;gap:7px}
.history-card h3{font-size:1.35rem;margin:0;color:var(--text-strong)}
.history-card p{margin:0;color:#33433f;line-height:1.45}
.history-card small{color:var(--muted-ink)}
.history-card-side{text-align:right;display:grid;gap:4px}
.history-card-side strong{font-size:2rem;line-height:1;color:var(--teal-strong)}
.history-card-side span{color:var(--muted-ink);font-weight:800}
.history-card-side time{color:#51635e;font-size:.92rem}
.history-card-side form{margin-top:8px}
.history-card-side .btn{width:100%;min-height:46px}
/* Colores de estado usados por solicitudes de insumos y llaves. */
.status-pendiente{background:#fff7ed;color:#9a3412}
.status-aprobada{background:#ecfdf5;color:#047857}
.status-rechazada{background:#fef2f2;color:#b91c1c}
.status-entregada{background:#eef2ff;color:#3730a3}
.status-cancelada{background:#f1f5f9;color:#475569}
.status-devuelta{background:#f0fdfa;color:#0f766e}

@media (max-width:1100px){
  .history-filters{grid-template-columns:1fr 1fr}
  .history-card{grid-template-columns:1fr}
  .history-card-side{text-align:left}
}

@media (max-width:720px){
  .route-miscelaneos-historial .app-main{padding:16px 12px 24px}
  .history-hero{display:grid}
  .history-metrics{display:grid;grid-template-columns:1fr 1fr}
  .history-metrics div{min-width:0}
  .history-filters{grid-template-columns:1fr}
}

/* ==========================================================================
   11. Tablero de llaves tactil
   Flujo de prestamo de llaves para usuarios: seleccion visual por tarjetas,
   panel de solicitud y catalogo con estado disponible/prestada.
   ========================================================================== */
.route-tablero .app-main{max-width:none;padding:18px 24px 24px}
.route-tablero.user-body .app-main{padding:18px 24px 24px}
/* Layout operativo del tablero: solicitud a la izquierda, llaves a la derecha. */
.keys-workspace{
  height:calc(100vh - var(--nav-height) - 42px);
  min-height:620px;
  display:grid;
  grid-template-columns:minmax(420px,4fr) minmax(0,6fr);
  gap:18px;
  align-items:stretch;
}
.key-request-column{min-width:0;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:14px;overflow:hidden}
.key-request-panel,
.keys-catalog{
  min-height:0;
  height:100%;
  padding:18px;
}
.key-request-panel{
  display:grid;
  grid-template-rows:auto auto minmax(0,1fr) auto;
  gap:16px;
}
/* Estado inicial antes de elegir una llave. */
.selected-key-empty{
  border:1px dashed var(--line);
  border-radius:8px;
  background:#f8faf9;
  padding:18px;
  display:grid;
  gap:6px;
  color:var(--muted-ink);
}
.selected-key-empty strong{color:var(--ink)}
/* Resumen de la llave seleccionada antes de enviar la solicitud. */
.selected-key-card{
  border:1px solid #b9cac4;
  border-radius:8px;
  background:#f7fbf9;
  padding:18px;
  display:grid;
  gap:10px;
}
.selected-key-card span{width:max-content;border-radius:8px;background:#10231f;color:#fff;font-weight:800;padding:6px 10px}
.selected-key-card strong{font-size:1.45rem;color:var(--text-strong)}
.selected-key-card small{color:var(--muted-ink);font-weight:700}
.key-request-panel textarea{min-height:120px}
.key-return-panel{display:grid;gap:12px;padding:18px}
.key-return-panel .selected-key-empty{margin:0}
.key-return-list{display:grid;gap:10px;max-height:260px;overflow:auto;padding-right:4px}
.key-return-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:12px}
.key-return-card>div{display:grid;gap:6px;min-width:0}
.key-return-card strong{color:var(--text-strong);line-height:1.15}
.key-return-card small{color:var(--muted-ink);font-weight:700}
.key-return-card .key-sku{width:max-content}
.key-return-card .btn{min-height:44px}
.keys-catalog{display:grid;grid-template-rows:auto auto minmax(0,1fr)}
/* Parrilla de llaves con scroll interno para uso tactil. */
.key-grid{
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  align-content:start;
  gap:12px;
  padding-right:4px;
}
/* Tarjeta individual de llave. Disponible se puede seleccionar; prestada queda apagada. */
.key-card{
  border:1px solid var(--line);
  border-radius:8px;
  background:#fff;
  min-height:218px;
  padding:14px;
  display:grid;
  gap:10px;
  align-content:start;
  cursor:pointer;
  transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease;
}
.key-card:hover,
.key-card.is-selected{border-color:var(--teal);box-shadow:0 12px 24px rgba(23,111,93,.12);transform:translateY(-1px)}
.key-card.is-unavailable{opacity:.62;cursor:not-allowed}
.key-card-top{display:flex;justify-content:space-between;gap:10px;align-items:center}
.key-sku{border-radius:8px;background:#10231f;color:#fff;font-weight:900;padding:6px 9px}
.key-card h3{font-size:1.18rem;margin:0;color:var(--text-strong)}
.key-card p{margin:0;color:var(--muted-ink);line-height:1.35}
.key-card .btn{margin-top:auto;width:100%;min-height:48px}

/* Estanteria visual: cada slot representa un gancho fisico del tablero. */
.key-board{
  min-height:0;
  overflow:auto;
  overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  align-content:start;
  gap:14px;
  padding:14px;
  border:1px solid #d7e2de;
  border-radius:8px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.78),rgba(255,255,255,.9)),
    repeating-linear-gradient(0deg,#eef3f1 0,#eef3f1 86px,#dce7e3 87px,#dce7e3 91px);
}
.key-slot{
  position:relative;
  min-height:252px;
  padding:12px;
  gap:10px;
  grid-template-rows:auto 1fr auto;
  background:#fff;
}
.key-slot.is-empty{
  background:#f8faf9;
  border-style:dashed;
}
.key-slot-label{display:grid;gap:4px}
.key-slot-label strong{
  font-size:1.1rem;
  line-height:1.1;
  color:var(--text-strong);
}
.key-slot-label small{
  color:var(--muted-ink);
  font-weight:700;
}
.key-hook-scene{
  position:relative;
  min-height:116px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:linear-gradient(180deg,#f6f9f8,#eef4f1);
  border:1px solid var(--line);
  overflow:hidden;
}
.peg{
  position:absolute;
  top:16px;
  width:28px;
  height:28px;
  border-radius:50%;
  background:#10231f;
  box-shadow:inset 0 0 0 7px #d9e2df;
}
.hook{
  position:absolute;
  top:38px;
  width:4px;
  height:34px;
  border-radius:8px;
  background:#10231f;
}
.hook::after{
  content:"";
  position:absolute;
  left:-12px;
  bottom:-15px;
  width:28px;
  height:24px;
  border:4px solid #10231f;
  border-top:0;
  border-radius:0 0 18px 18px;
}
.hanging-key{
  position:absolute;
  top:58px;
  width:42px;
  height:76px;
  filter:drop-shadow(0 10px 12px rgba(16,24,22,.18));
}
.key-head{
  position:absolute;
  top:0;
  left:5px;
  width:32px;
  height:32px;
  border:8px solid #b58b22;
  border-radius:50%;
  background:#fff9dc;
}
.key-stem{
  position:absolute;
  top:28px;
  left:18px;
  width:8px;
  height:42px;
  border-radius:8px;
  background:#b58b22;
}
.key-tooth{
  position:absolute;
  height:8px;
  border-radius:0 4px 4px 0;
  background:#b58b22;
}
.key-tooth.one{left:22px;top:56px;width:18px}
.key-tooth.two{left:22px;top:68px;width:13px}
.missing-key{
  position:absolute;
  top:58px;
  width:74px;
  height:74px;
  display:grid;
  place-items:center;
  border:2px dashed #b6c7c1;
  border-radius:8px;
  color:#60706b;
  font-weight:900;
  background:rgba(255,255,255,.5);
}
.key-check{
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:8px;
  background:#f7faf9;
  color:#243430;
  font-weight:900;
  cursor:pointer;
}
.key-check input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.key-check span{
  width:24px;
  height:24px;
  border:2px solid #9fb4ad;
  border-radius:8px;
  background:#fff;
  display:grid;
  place-items:center;
}
.key-check span::after{
  content:"";
  width:11px;
  height:7px;
  border-left:3px solid #fff;
  border-bottom:3px solid #fff;
  transform:rotate(-45deg) translate(1px,-1px);
  opacity:0;
}
.key-check input:checked + span{
  border-color:var(--teal);
  background:var(--teal);
}
.key-check input:checked + span::after{opacity:1}
.key-check.is-disabled{
  color:#7b8a86;
  cursor:not-allowed;
  background:#eef3f1;
}
/* El historial de llaves reutiliza los estilos generales de historiales. */
.route-tablero-historial .app-main{max-width:none;padding:26px 32px 40px}

/* ==========================================================================
   12. Administracion de llaves
   Prestamos activos para devolucion y edicion manual del SKU/codigo interno.
   ========================================================================== */
.loan-list{display:grid;gap:10px}
.loan-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:12px}
.loan-row strong{display:block;color:var(--text-strong)}
.loan-row small{color:var(--muted-ink)}
.loan-row .btn{min-height:44px}
.key-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.key-admin-card{border:1px solid var(--line);border-radius:8px;background:#fbfcfc;padding:14px;display:grid;gap:12px}
.key-admin-card strong{display:block;color:var(--text-strong)}
.key-admin-card small{color:var(--muted-ink)}
.key-admin-card label{display:grid;gap:6px;font-weight:800}

@media (max-width:1180px){
  .keys-workspace{height:auto;min-height:0;grid-template-columns:1fr}
  .key-request-column{grid-row:1;overflow:visible}
  .key-grid,.key-board{overflow:visible}
}

@media (max-width:720px){
  .route-tablero .app-main,
  .route-tablero.user-body .app-main,
  .route-tablero-historial .app-main{padding:12px}
  .keys-workspace{gap:12px}
  .key-request-panel,
  .key-return-panel,
  .keys-catalog{padding:14px}
  .key-return-card{grid-template-columns:1fr}
  .key-return-card .btn{width:100%}
  .key-grid,.key-board{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .key-card{min-height:230px}
  .key-board{padding:10px}
  .key-slot{min-height:238px}
  .loan-row{grid-template-columns:1fr}
  .loan-row .btn{width:100%}
}

/* ==========================================================================
   13. Experiencia movil tipo app
   Prioriza formularios cortos, catalogos primero y paneles administrativos
   compactos. Este bloque pisa reglas anteriores solo en pantallas pequenas.
   ========================================================================== */
@media (max-width:640px){
  body{font-size:16px}

  .guest-body{
    background:#f4f6f8;
  }
  .guest-body::before{display:none}
  .guest-container{
    min-height:100vh;
    padding:0;
    align-content:stretch;
  }
  .access-shell{
    min-height:100vh;
    width:100%;
    border:0;
    border-radius:0;
    box-shadow:none;
    background:#fff;
  }
  .access-modules{
    gap:14px;
    padding:18px 16px 12px;
    border-bottom:1px solid var(--line);
  }
  .brand-block h1{
    font-size:1.55rem;
    margin:4px 0 6px;
  }
  .brand-block p{margin:0}
  .module-choice-list{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .module-choice{
    padding:12px;
    gap:4px;
    border-left-width:0;
    text-align:left;
  }
  .module-choice small{display:none}
  .module-choice strong{font-size:1rem}
  .module-choice span{font-size:.72rem;padding:3px 8px}
  .access-login{
    padding:18px 16px 22px;
    gap:14px;
  }
  .login-copy h2{
    font-size:1.45rem;
    margin-bottom:6px;
  }
  .login-copy p{margin:0}
  .access-form{gap:12px}
  .hint-box.compact{display:none}
  input,select,textarea{min-height:52px}
  .btn-xl{min-height:56px}

  .main-navbar{
    position:sticky;
    top:0;
    grid-template-columns:minmax(0,1fr) auto;
    padding:9px 10px;
    gap:8px;
  }
  .brand{
    min-width:0;
    gap:10px;
  }
  .brand img{
    width:38px;
    height:38px;
  }
  .brand strong{font-size:1rem}
  .brand small{font-size:.78rem}
  .navbar-toggle{
    width:44px;
    height:44px;
  }
  .navbar-menu{
    grid-column:1 / -1;
    display:none;
    grid-template-columns:1fr;
    gap:10px;
    padding:10px 0 2px;
    border-top:1px solid var(--line);
  }
  .main-navbar.is-open .navbar-menu{display:grid}
  .navbar-links{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    overflow:visible;
    padding-bottom:0;
  }
  .navbar-links::-webkit-scrollbar{display:none}
  .navbar-links a{
    padding:12px;
    background:#f1f6f4;
    border:1px solid var(--line);
    font-size:.9rem;
  }
  .navbar-user{
    display:grid;
    grid-template-columns:1fr auto;
    gap:8px;
  }
  .navbar-user .user-avatar,
  .navbar-user>div:not(.branch-chip):not(.user-avatar){display:none}
  .navbar-user form{grid-column:2}
  .navbar-user .btn{
    min-height:44px;
    padding:8px 12px;
  }
  .branch-chip{
    grid-column:1;
    text-align:left;
    padding:8px 10px;
  }

  .app-main,
  .user-body .app-main{
    padding:12px 12px 88px;
  }
  .app-header{
    margin-bottom:12px;
  }
  .app-header h1{
    font-size:1.45rem;
  }
  .panel{
    padding:14px;
  }
  .section-head{
    margin-bottom:12px;
  }
  .section-head h2{
    font-size:1.25rem;
  }
  .section-head p{
    font-size:.95rem;
  }
  .catalog-summary{display:none}
  .search-input{
    min-height:50px;
    margin-bottom:10px;
  }

  .route-miscelaneos .app-main,
  .route-miscelaneos.user-body .app-main,
  .route-tablero .app-main,
  .route-tablero.user-body .app-main{
    padding:10px 10px 86px;
  }
  .route-miscelaneos .materials-shop,
  .keys-workspace{
    display:flex;
    flex-direction:column;
    gap:10px;
  }
  .route-miscelaneos .materials-catalog,
  .keys-catalog{order:1}
  .route-miscelaneos .cart-column,
  .key-request-column{order:2}
  .route-miscelaneos .materials-catalog,
  .route-miscelaneos .cart-panel,
  .key-return-panel,
  .key-request-panel,
  .keys-catalog{
    padding:12px;
  }
  .route-miscelaneos .material-grid{
    grid-template-columns:1fr;
    gap:8px;
  }
  .route-miscelaneos .material-card{
    min-height:0;
    grid-template-columns:96px minmax(0,1fr);
    grid-template-rows:auto auto;
  }
  .route-miscelaneos .material-card img{
    grid-row:1 / span 2;
    width:96px;
    height:100%;
    min-height:148px;
  }
  .route-miscelaneos .material-card-body{
    padding:12px 12px 6px;
    min-width:0;
  }
  .route-miscelaneos .material-card-body h3{
    font-size:1rem;
    margin:0;
    -webkit-line-clamp:2;
  }
  .route-miscelaneos .material-card-body p{display:none}
  .route-miscelaneos .material-card-foot{
    padding:6px 12px 12px;
    display:grid;
    gap:8px;
  }
  .route-miscelaneos .material-card-foot .btn{
    min-height:44px;
  }
  .route-miscelaneos .cart-panel{
    grid-template-rows:auto auto auto auto auto;
  }
  .route-miscelaneos .cart-empty{
    padding:12px;
  }
  .route-miscelaneos .cart-row{
    grid-template-columns:1fr auto;
  }
  .route-miscelaneos .cart-row img{display:none}
  .route-miscelaneos .cart-row-main input[type=number]{
    max-width:none;
    width:100%;
  }

  .key-board{
    grid-template-columns:1fr;
    padding:8px;
    gap:8px;
    background:#f6f9f8;
  }
  .key-slot{
    min-height:0;
    grid-template-columns:1fr auto;
    align-items:center;
  }
  .key-hook-scene{
    display:none;
  }
  .key-check{
    min-width:118px;
    min-height:48px;
  }
  .selected-key-empty,
  .selected-key-card{
    padding:12px;
  }
  .key-request-panel textarea{
    min-height:88px;
  }

  .sidebar{display:none}
  .app-body.has-sidebar{display:block}
  .has-sidebar .main-navbar{grid-column:auto}
  .app-body.has-sidebar .app-main{
    grid-column:auto;
    grid-row:auto;
  }
  .branch-context-panel{
    margin-bottom:10px;
  }
  .admin-hero{
    margin-bottom:10px;
    padding:14px;
  }
  .admin-hero h2,
  .admin-module-header h2{
    font-size:1.35rem;
  }
  .admin-hero-actions{
    display:grid;
    grid-template-columns:1fr;
  }
  .admin-stats-grid{
    grid-template-columns:1fr 1fr;
    gap:8px;
    margin-bottom:14px;
  }
  .admin-stats-grid .stat-card{
    min-height:96px;
  }
  .admin-module-section{
    gap:12px;
    margin-bottom:18px;
  }
  .admin-module-header{
    gap:10px;
  }
  .module-metrics{
    display:grid;
    grid-template-columns:1fr 1fr;
    width:100%;
    gap:8px;
  }
  .module-metrics span{
    min-width:0;
    padding:10px;
  }
  .admin-list-panel,
  .admin-collapsible,
  .admin-audit-panel{
    padding:14px;
  }
  .admin-collapsible{padding:0}
  .admin-collapsible summary{
    padding:14px;
    display:grid;
  }
  .admin-collapsible .key-admin-grid{
    padding:0 14px 14px;
    max-height:none;
  }
  .admin-request-list,
  .stock-list{
    max-height:none;
    overflow:visible;
  }
  .admin-request-card{
    padding:12px;
  }
  .app-modal{
    padding:10px;
    align-items:start;
  }
  .app-modal-panel{
    max-height:92vh;
    padding:14px;
  }
  .misc-approval-card{
    padding:12px;
  }
  .misc-request-meta{
    display:grid;
    grid-template-columns:1fr 1fr;
  }
  .request-title-row{
    align-items:flex-start;
    display:grid;
  }
  .branch-context-panel h2{
    font-size:1.25rem;
  }
  .branch-context-panel p{
    font-size:.92rem;
  }
  .stats-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px;
    margin-bottom:10px;
  }
  .stat-card{
    padding:12px;
  }
  .stat-card span{
    font-size:.78rem;
  }
  .stat-card strong{
    font-size:1.55rem;
    margin-top:4px;
  }
  .admin-workspace{
    gap:10px;
  }
  .request-row,
  .loan-row,
  .audit-row{
    padding:12px;
  }
  .action-buttons{
    display:grid;
    grid-template-columns:1fr;
  }
  .action-buttons form,
  .action-buttons .btn{
    width:100%;
  }
  .admin-form-grid{
    gap:10px;
  }
  .admin-form-grid .btn{
    width:100%;
  }
  .table-scroll{
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }
  table{
    min-width:620px;
    font-size:.92rem;
  }
  .report-hero{
    display:grid;
  }

  .purchase-entry-row{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .purchase-entry-product,
  .purchase-entry-totals,
  .purchase-entry-row .btn{
    grid-column:1 / -1;
    grid-row:auto;
  }
  .purchase-entry-totals{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .purchase-product-grid{
    grid-template-columns:1fr;
  }
  .purchase-product-card{
    min-height:0;
    grid-template-columns:96px minmax(0,1fr);
    grid-template-rows:auto auto;
  }
  .purchase-product-card img{
    grid-row:1 / span 2;
    width:96px;
    height:100%;
    min-height:150px;
  }
  .purchase-product-card .btn{
    margin:0 12px 12px;
    width:auto;
  }

  .route-miscelaneos-historial .app-main,
  .route-tablero-historial .app-main{
    padding:12px 10px 86px;
  }
  .history-hero h2{
    font-size:1.45rem;
  }
  .history-metrics{
    grid-template-columns:1fr 1fr;
    gap:8px;
  }
  .history-metrics div{
    padding:10px;
  }
  .history-metrics strong{
    font-size:1.45rem;
  }
  .history-filters,
  .history-results{
    padding:12px;
  }
  .history-card{
    padding:12px;
    gap:10px;
  }
  .history-card h3{
    font-size:1.1rem;
  }
}
