/* ============================================================
   La Estancia Black — Sistema visual "Soft Enterprise Glass"
   v7.23.0 · Paso 1 · Tokens + base globales
   ============================================================ */

/* ────────────────────────────────────────────────────────────
   1. TOKENS (CSS custom properties)
   ──────────────────────────────────────────────────────────── */
:root {
  /* ── Paleta base (del sistema visual) ── */
  --la-bg-deep:        #1A1209;   /* Fondo profundo · negro anaranjado cálido */
  --la-brown-warm:     #453027;   /* Marrón cálido · L2 */
  --la-accent:         #FF6D29;   /* Accent principal */
  --la-gray-ui:        #BABABA;   /* Gris UI */
  --la-white:          #FFFFFF;

  /* ── Variantes funcionales del accent ── */
  --la-accent-hi:      #FF8348;   /* Hover / brillo */
  --la-accent-lo:      #E55A1F;   /* Pressed */
  --la-accent-glow:    rgba(255, 109, 41, 0.35);
  --la-accent-tint-12: rgba(255, 109, 41, 0.12);
  --la-accent-tint-08: rgba(255, 109, 41, 0.08);
  --la-accent-tint-04: rgba(255, 109, 41, 0.04);

  /* ── Texto (jerarquía por opacidad sobre fondo oscuro) ── */
  --la-text-primary:   rgba(255, 255, 255, 0.96);
  --la-text-secondary: rgba(255, 255, 255, 0.66);
  --la-text-muted:     rgba(255, 255, 255, 0.42);
  --la-text-faint:     rgba(255, 255, 255, 0.24);

  /* ── Estados semánticos (suaves, no saturados) ── */
  --la-success:        #6ED27A;
  --la-success-tint:   rgba(110, 210, 122, 0.14);
  --la-danger:         #E5564A;
  --la-danger-tint:    rgba(229, 86, 74, 0.14);
  --la-warning:        #E8B341;
  --la-warning-tint:   rgba(232, 179, 65, 0.14);
  --la-info:           #6AA9E9;
  --la-info-tint:      rgba(106, 169, 233, 0.14);

  /* ── Superficies de vidrio (L4 · Soft Enterprise Glass) ── */
  --la-glass-bg:       rgba(255, 255, 255, 0.03);
  --la-glass-bg-hi:    rgba(255, 255, 255, 0.05);   /* hover */
  --la-glass-border:   rgba(255, 255, 255, 0.08);
  --la-glass-border-hi:rgba(255, 255, 255, 0.14);   /* hover */
  --la-glass-divider:  rgba(255, 255, 255, 0.06);   /* tablas, separadores */

  /* ── Superficies opacas (cuando el blur no es deseable) ── */
  --la-surface-1:      #1A1A1A;   /* sidebar, cards opacas */
  --la-surface-2:      #1E1E1E;   /* inputs, selects */
  --la-surface-3:      #252525;   /* hover de inputs */

  /* ── Blur (backdrop-filter) ── */
  --la-blur-sm:        8px;
  --la-blur-md:        16px;
  --la-blur-lg:        20px;      /* default de cards */
  --la-blur-xl:        32px;      /* modales */

  /* ── Radius ── */
  --la-r-xs:           4px;
  --la-r-sm:           8px;
  --la-r-md:           10px;
  --la-r-lg:           12px;      /* default de cards */
  --la-r-xl:           14px;      /* KPIs grandes */
  --la-r-pill:         999px;

  /* ── Spacing scale (regla: nunca arbitrario) ── */
  --la-s-1:            4px;
  --la-s-2:            8px;
  --la-s-3:            12px;
  --la-s-4:            16px;
  --la-s-5:            24px;
  --la-s-6:            32px;
  --la-s-7:            48px;
  --la-s-8:            64px;

  /* ── Layout ── */
  --la-sidebar-w:      240px;
  --la-topbar-h:       72px;
  --la-content-gap:    24px;
  --la-content-max:    1440px;

  /* ── Tipografía ── */
  --la-font-ui:        "Inter Tight", "Neue Montreal", "Satoshi",
                       "SF Pro Display", system-ui, -apple-system,
                       "Segoe UI", sans-serif;
  --la-font-mono:      "JetBrains Mono", ui-monospace, "SF Mono",
                       Menlo, Consolas, monospace;
  --la-font-display:   "Fraunces", "Inter Tight", serif;

  /* Escala tipográfica */
  --la-fs-11:          11px;
  --la-fs-12:          12px;
  --la-fs-13:          13px;
  --la-fs-14:          14px;
  --la-fs-15:          15px;
  --la-fs-16:          16px;
  --la-fs-18:          18px;
  --la-fs-20:          20px;
  --la-fs-24:          24px;
  --la-fs-28:          28px;
  --la-fs-32:          32px;
  --la-fs-36:          36px;
  --la-fs-40:          40px;
  --la-fs-48:          48px;

  /* Pesos */
  --la-fw-regular:     400;
  --la-fw-medium:      500;
  --la-fw-semibold:    600;
  --la-fw-bold:        700;

  /* Tracking (letter-spacing) */
  --la-tr-tight:       -0.02em;   /* títulos grandes */
  --la-tr-snug:        -0.01em;   /* títulos y KPIs */
  --la-tr-normal:       0;
  --la-tr-wide:         0.04em;   /* labels uppercase eventuales */

  /* Line-heights */
  --la-lh-tight:       1.1;
  --la-lh-snug:        1.25;
  --la-lh-normal:      1.45;
  --la-lh-loose:       1.6;

  /* ── Sombras y glows ── */
  --la-shadow-sm:      0 1px 2px rgba(0, 0, 0, 0.30);
  --la-shadow-md:      0 6px 18px rgba(0, 0, 0, 0.35);
  --la-shadow-lg:      0 18px 48px rgba(0, 0, 0, 0.45);
  --la-shadow-xl:      0 32px 80px rgba(0, 0, 0, 0.55);
  --la-glow-accent:    0 0 24px rgba(255, 109, 41, 0.28);
  --la-glow-accent-sm: 0 0 12px rgba(255, 109, 41, 0.22);

  /* ── Transiciones ── */
  --la-dur-fast:       120ms;
  --la-dur-base:       180ms;     /* hover global del sistema */
  --la-dur-slow:       280ms;
  --la-dur-xslow:      420ms;
  --la-ease-out:       cubic-bezier(0.22, 1, 0.36, 1);
  --la-ease-in-out:    cubic-bezier(0.65, 0, 0.35, 1);
  --la-ease-soft:      cubic-bezier(0.4, 0, 0.2, 1);

  /* ── Z-index ── */
  --la-z-base:         1;
  --la-z-sidebar:      40;
  --la-z-topbar:       50;
  --la-z-dropdown:     200;
  --la-z-overlay:      900;
  --la-z-modal:        1000;
  --la-z-toast:        1100;
  --la-z-tooltip:      1200;
}

/* ────────────────────────────────────────────────────────────
   2. RESET MÍNIMO
   ──────────────────────────────────────────────────────────── */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html, body {
  margin: 0;
  padding: 0;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

img, svg, video, canvas {
  display: block;
  max-width: 100%;
}

button, input, select, textarea {
  font: inherit;
  color: inherit;
  background: transparent;
  border: none;
  outline: none;
}

button {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* ────────────────────────────────────────────────────────────
   3. BASE GLOBAL
   ──────────────────────────────────────────────────────────── */
html {
  background: var(--la-bg-deep);
  color-scheme: dark;
}

body {
  min-height: 100vh;
  font-family: var(--la-font-ui);
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-regular);
  line-height: var(--la-lh-normal);
  letter-spacing: var(--la-tr-normal);
  color: var(--la-text-primary);

  /* ── Layering del fondo (L1 + L2 + L3) ──
     L1 · base sólida              → var(--la-bg-deep)
     L2 · gradiente marrón cálido  → radial suave hacia los bordes
     L3 · glow naranja difuso      → halo superior-izquierdo            */
  background-color: #1A1209;
  background-image:
    /* Luz izquierda · vértice superior-izquierdo */
    radial-gradient(
      ellipse 72% 80% at -8% -8%,
      rgba(255, 120, 30, 1.00) 0%,
      rgba(240, 95,  18, 0.80) 20%,
      rgba(210, 72,  12, 0.50) 40%,
      rgba(160, 50,   8, 0.20) 60%,
      rgba(0,   0,   0,  0.00) 78%
    ),
    /* Luz derecha · vértice inferior-derecho */
    radial-gradient(
      ellipse 72% 80% at 108% 108%,
      rgba(255, 120, 30, 0.95) 0%,
      rgba(238, 92,  16, 0.75) 20%,
      rgba(205, 70,  11, 0.44) 40%,
      rgba(155, 48,   7, 0.18) 60%,
      rgba(0,   0,   0,  0.00) 78%
    );
  background-attachment: fixed;
  background-repeat: no-repeat;

  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11", "calt";

  overflow-x: hidden;
}

/* Números siempre tabulares en interfaces densas (KPIs, tablas) */
.la-num,
.la-tabular {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

/* ────────────────────────────────────────────────────────────
   4. TIPOGRAFÍA UTILITARIA (jerarquía del doc)
   ──────────────────────────────────────────────────────────── */
.la-h1 {
  font-size: var(--la-fs-40);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: var(--la-lh-tight);
  color: var(--la-text-primary);
}

.la-h2 {
  font-size: var(--la-fs-32);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: var(--la-lh-tight);
  color: var(--la-text-primary);
}

.la-h3 {
  font-size: var(--la-fs-20);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: var(--la-lh-snug);
  color: var(--la-text-primary);
}

.la-kpi-value {
  font-size: var(--la-fs-40);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: var(--la-lh-tight);
  color: var(--la-text-primary);
  font-variant-numeric: tabular-nums;
}

.la-label {
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-secondary);
  line-height: var(--la-lh-snug);
}

.la-caption {
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-regular);
  color: var(--la-text-muted);
  line-height: var(--la-lh-normal);
}

/* ────────────────────────────────────────────────────────────
   5. SELECCIÓN, FOCUS, SCROLLBAR
   ──────────────────────────────────────────────────────────── */
::selection {
  background: var(--la-accent-tint-12);
  color: var(--la-white);
}

:focus-visible {
  outline: 2px solid var(--la-accent);
  outline-offset: 2px;
  border-radius: var(--la-r-xs);
}

/* Scrollbar sutil para Webkit */
*::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
*::-webkit-scrollbar-track {
  background: transparent;
}
*::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.08);
  border-radius: var(--la-r-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
}
*::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.16);
  background-clip: padding-box;
  border: 2px solid transparent;
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.10) transparent;
}

/* ────────────────────────────────────────────────────────────
   6. ACCESIBILIDAD
   ──────────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

.la-sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================
   PASO 2 · LOGIN
   Split layout editorial: stage izquierda · formulario derecha
   Markup base: #login-screen.lp-split > .lp-box > (.lp-stage | .lp-form-wrap)
   ============================================================ */

/* ── Contenedor full-viewport ── */
#login-screen.lp-split {
  position: fixed;
  inset: 0;
  z-index: var(--la-z-overlay);
  display: grid;
  place-items: center;
  padding: var(--la-s-6);
  /* Login · mismo estilo original de capas, base neutra sin tinte */
  background:
    radial-gradient(
      1000px 700px at 18% 30%,
      rgba(255, 109, 41, 0.18) 0%,
      rgba(255, 109, 41, 0.06) 35%,
      rgba(255, 109, 41, 0.00) 65%
    ),
    radial-gradient(
      1100px 800px at 82% 70%,
      rgba(69, 48, 39, 0.55) 0%,
      rgba(69, 48, 39, 0.18) 40%,
      rgba(69, 48, 39, 0.00) 72%
    ),
    linear-gradient(180deg, #111111 0%, #0F0F0F 100%);
}

/* ── Card contenedor con el split ── */
.lp-box {
  width: min(1080px, 100%);
  height: min(660px, calc(100vh - 64px));
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  border-radius: var(--la-r-xl);
  overflow: hidden;
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow:
    var(--la-shadow-xl),
    inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

/* ============================================================
   STAGE · panel izquierdo editorial
   ============================================================ */
.lp-stage {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: var(--la-s-7);
  overflow: hidden;
  isolation: isolate;
  color: var(--la-text-primary);
  background: linear-gradient(
    135deg,
    #2a1d18 0%,
    #1f1614 50%,
    #181214 100%
  );
}

/* Capas de la escena */
.lp-stage-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}

/* Mesh — gradiente cónico suave que da color de fondo cinematográfico */
.lp-stage-mesh {
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(
      420px 320px at 25% 28%,
      rgba(255, 109, 41, 0.28) 0%,
      rgba(255, 109, 41, 0.00) 70%
    ),
    radial-gradient(
      520px 420px at 78% 22%,
      rgba(69, 48, 39, 0.65) 0%,
      rgba(69, 48, 39, 0.00) 70%
    ),
    radial-gradient(
      640px 520px at 60% 90%,
      rgba(255, 109, 41, 0.16) 0%,
      rgba(255, 109, 41, 0.00) 65%
    );
  filter: blur(8px);
  opacity: 0.95;
}

/* Curve — arco diagonal de luz */
.lp-stage-curve {
  position: absolute;
  width: 720px;
  height: 720px;
  right: -260px;
  bottom: -260px;
  border-radius: 50%;
  background: radial-gradient(
    closest-side,
    rgba(255, 109, 41, 0.16) 0%,
    rgba(255, 109, 41, 0.06) 45%,
    rgba(255, 109, 41, 0.00) 75%
  );
  filter: blur(20px);
}

/* Glow — halo cálido por detrás del logo */
.lp-stage-glow {
  position: absolute;
  width: 360px;
  height: 360px;
  top: -90px;
  left: -90px;
  border-radius: 50%;
  background: radial-gradient(
    closest-side,
    rgba(255, 109, 41, 0.40) 0%,
    rgba(255, 109, 41, 0.12) 45%,
    rgba(255, 109, 41, 0.00) 75%
  );
  filter: blur(8px);
}

/* Grain — textura SVG inline */
.lp-stage-grain {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.45 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  background-size: 160px 160px;
  opacity: 0.06;
  mix-blend-mode: overlay;
}

/* Bloque superior — logo WAGON */
.lp-stage-top {
  position: relative;
  z-index: 1;
}
.lp-stage-wagon-mark {
  display: block;
  height: 28px;
  width: auto;
  opacity: 0.95;
  filter: drop-shadow(0 6px 18px rgba(0, 0, 0, 0.45));
}

/* Bloque inferior — copy editorial */
.lp-stage-bottom {
  position: relative;
  z-index: 1;
  max-width: 420px;
}
.lp-stage-eyebrow {
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--la-accent);
  margin-bottom: var(--la-s-4);
}
.lp-stage-title {
  font-family: var(--la-font-display);
  font-size: clamp(32px, 3.4vw, 44px);
  font-weight: var(--la-fw-regular);
  letter-spacing: -0.015em;
  line-height: 1.08;
  color: var(--la-white);
  margin: 0 0 var(--la-s-4);
}
.lp-stage-title em {
  font-style: italic;
  color: var(--la-text-secondary);
}
.lp-stage-sub {
  font-size: var(--la-fs-14);
  line-height: var(--la-lh-loose);
  color: var(--la-text-secondary);
  margin: 0;
  max-width: 360px;
}

/* ============================================================
   FORM · panel derecho
   ============================================================ */
.lp-form-wrap {
  position: relative;
  display: grid;
  place-items: center;
  padding: var(--la-s-7) var(--la-s-7);
  background:
    linear-gradient(
      180deg,
      rgba(22, 19, 22, 0.55) 0%,
      rgba(22, 19, 22, 0.80) 100%
    );
}

.lp-form-inner {
  width: 100%;
  max-width: 360px;
  display: flex;
  flex-direction: column;
  gap: var(--la-s-5);
}

/* Identidad mínima — avatar + nombre */
.lp-mark {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
}
.lp-mark-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--la-surface-2);
  border: 1px solid var(--la-glass-border);
  display: grid;
  place-items: center;
}
.lp-mark-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lp-mark-meta {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.lp-mark-name {
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-primary);
  letter-spacing: var(--la-tr-snug);
}
.lp-mark-eyebrow {
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* Hero */
.lp-hero {
  margin-top: var(--la-s-2);
}
.lp-headline {
  font-size: var(--la-fs-36);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-tight);
  line-height: 1.05;
  color: var(--la-text-primary);
  margin: 0 0 var(--la-s-3);
}
.lp-headline em {
  font-style: normal;
  color: var(--la-accent);
}
.lp-subhead {
  font-size: var(--la-fs-14);
  color: var(--la-text-secondary);
  line-height: var(--la-lh-normal);
  margin: 0;
}

/* Form */
.lp-form {
  display: flex;
  flex-direction: column;
  gap: var(--la-s-4);
  margin-top: var(--la-s-2);
}

.lf {
  display: flex;
  flex-direction: column;
  gap: var(--la-s-2);
}
.lf > label {
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  letter-spacing: 0.04em;
}

/* Wrap genérico de input/select */
.lp-field-wrap {
  position: relative;
  display: flex;
  align-items: center;
  height: 44px;
  padding: 0 var(--la-s-4);
  background: var(--la-surface-2);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-sm);
  transition:
    border-color var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out);
}
.lp-field-wrap:hover {
  background: var(--la-surface-3);
  border-color: var(--la-glass-border-hi);
}
.lp-field-wrap:focus-within {
  border-color: var(--la-accent);
  background: var(--la-surface-2);
  box-shadow: 0 0 0 4px var(--la-accent-tint-08);
}

.lp-field-wrap input,
.lp-field-wrap select {
  flex: 1;
  min-width: 0;
  height: 100%;
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-primary);
  background: transparent;
  border: 0;
}
.lp-field-wrap input::placeholder {
  color: var(--la-text-faint);
}
.lp-field-wrap select {
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  padding-right: var(--la-s-5);
  /* Chevron custom */
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.55)' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 12px 12px;
}
.lp-field-wrap select option {
  background: #1c1719;
  color: var(--la-text-primary);
}

/* Variante con avatar a la izquierda del select Miembro */
.lp-field-wrap--avatar {
  padding-left: var(--la-s-2);
  gap: var(--la-s-3);
}
.lp-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--la-accent) 0%, var(--la-accent-lo) 100%);
  color: var(--la-white);
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-semibold);
  letter-spacing: 0;
  flex-shrink: 0;
  box-shadow: var(--la-glow-accent-sm);
}

/* Eye button */
.lp-eye-btn {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: var(--la-r-xs);
  color: var(--la-text-muted);
  transition:
    color var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out);
}
.lp-eye-btn:hover {
  color: var(--la-text-primary);
  background: rgba(255, 255, 255, 0.06);
}
.lp-eye-btn svg {
  display: block;
}

/* CTA */
.btn-login {
  margin-top: var(--la-s-2);
  height: 46px;
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-white);
  background: linear-gradient(180deg, var(--la-accent-hi) 0%, var(--la-accent) 100%);
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition:
    transform var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out);
}
.btn-login:hover {
  background: linear-gradient(180deg, #ff9460 0%, var(--la-accent-hi) 100%);
  box-shadow:
    var(--la-glow-accent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transform: translateY(-1px);
}
.btn-login:active {
  transform: translateY(0);
  background: linear-gradient(180deg, var(--la-accent) 0%, var(--la-accent-lo) 100%);
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

/* Estado de error */
.login-err {
  margin-top: var(--la-s-1);
  padding: var(--la-s-3) var(--la-s-4);
  background: var(--la-danger-tint);
  border: 1px solid rgba(229, 86, 74, 0.28);
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-13);
  color: #ffb1a8;
}

/* Versión (placeholder oculto, JS lo muestra cuando hay Electron) */
#lp-app-version {
  position: absolute;
  top: var(--la-s-5);
  right: var(--la-s-5);
  font-family: var(--la-font-mono);
  font-size: var(--la-fs-11);
  color: var(--la-text-faint);
  letter-spacing: 0.06em;
  padding: 4px 8px;
  border-radius: var(--la-r-pill);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
}

/* ── Responsive: en pantallas chicas, colapsa el stage ── */
@media (max-width: 880px) {
  .lp-box {
    grid-template-columns: 1fr;
    height: auto;
    min-height: 100%;
    max-height: calc(100vh - 32px);
  }
  .lp-stage {
    padding: var(--la-s-5);
    min-height: 220px;
  }
  .lp-stage-bottom { display: none; }
  .lp-form-wrap {
    padding: var(--la-s-6) var(--la-s-5);
  }
}

/* ── Animación de entrada del card ── */
@keyframes la-login-in {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.992);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.lp-box {
  animation: la-login-in var(--la-dur-xslow) var(--la-ease-out) both;
}

/* ============================================================
   PASO 3 · SHELL DEL APP (sidebar + topbar + main)
   Markup: #app > (#sidebar | <main id="main"> > .topbar + #pages)
   ============================================================ */

/* ── App container ── */
#app {
  min-height: 100vh;
  position: relative;
}

/* ── Suprimir flotantes que JS controla (evita render desbocado) ── */
#alerta-venc-overlay,
#urgente-flash,
#urgente-banner,
#sidebar-backdrop,
#modal-overlay,
#changelog-overlay,
#toast-c,
#chat-float,
#mov-inspector,
#modal-caja-cli-overlay,
.tb-nav-dropdown,
.nav-wrap {
  display: none;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
#sidebar {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--la-sidebar-w);
  z-index: var(--la-z-sidebar);
  display: flex;
  flex-direction: column;
  padding: var(--la-s-5) var(--la-s-4) var(--la-s-4);
  /* Translúcido — deja pasar el glow naranja del fondo */
  background: rgba(12, 8, 4, 0.45);
  border-right: 1px solid rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(160%);
}

/* Brand / logo bloque superior */
.sb-logo {
  padding: var(--la-s-1) var(--la-s-3) var(--la-s-4);
  margin-bottom: var(--la-s-2);
}
.sb-logo .brand {
  font-family: var(--la-font-display);
  font-size: var(--la-fs-20);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: 1.05;
  color: var(--la-text-primary);
}
.sb-logo .sub {
  display: block;
  margin-top: 4px;
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--la-text-muted);
}

/* Pill local actual */
.sb-local {
  padding: var(--la-s-2) var(--la-s-3);
  margin-bottom: var(--la-s-4);
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-sm);
}
.sb-local strong {
  display: block;
  margin-top: 2px;
  color: var(--la-text-primary);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
}

/* Lista de navegación (scroll si overflows) */
.sb-nav {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: var(--la-s-1);
  padding-right: 2px;
  margin-right: -2px;
}

/* Item de navegación · default */
.ni {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
  height: 40px;
  padding: 0 var(--la-s-3);
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-secondary);
  cursor: pointer;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    transform var(--la-dur-base) var(--la-ease-out);
  user-select: none;
}
.ni > svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  opacity: 0.85;
  transition: opacity var(--la-dur-base) var(--la-ease-out);
}
.ni:hover {
  background: var(--la-glass-bg-hi);
  color: var(--la-text-primary);
}
.ni:hover > svg { opacity: 1; }

/* Item activo · pill accent */
.ni.active {
  color: var(--la-white);
  background: linear-gradient(180deg, var(--la-accent-hi) 0%, var(--la-accent) 100%);
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.ni.active > svg { opacity: 1; }
.ni.active:hover {
  background: linear-gradient(180deg, #ff9460 0%, var(--la-accent-hi) 100%);
}

/* Botón de "Venta rápida" · variante accent ghost */
.sb-vr-btn {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
  height: 40px;
  padding: 0 var(--la-s-3);
  margin: var(--la-s-2) 0;
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-semibold);
  color: var(--la-accent);
  background: var(--la-accent-tint-08);
  border: 1px solid rgba(255, 109, 41, 0.18);
  cursor: pointer;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out);
}
.sb-vr-btn > svg {
  width: 18px;
  height: 18px;
}
.sb-vr-btn:hover {
  background: var(--la-accent-tint-12);
  border-color: rgba(255, 109, 41, 0.36);
  box-shadow: var(--la-glow-accent-sm);
}

/* Encabezado de grupo colapsable */
.sb-collapsible-head {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
  height: 38px;
  padding: 0 var(--la-s-3);
  margin-top: var(--la-s-2);
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--la-text-muted);
  cursor: pointer;
  transition: color var(--la-dur-base) var(--la-ease-out);
}
.sb-collapsible-head > svg {
  width: 14px;
  height: 14px;
  opacity: 0.5;
}
.sb-collapsible-head:hover {
  color: var(--la-text-secondary);
}
.sb-collapsible-head .sb-chevron {
  margin-left: auto;
  width: 12px;
  height: 12px;
  opacity: 0.5;
  transition: transform var(--la-dur-base) var(--la-ease-out);
}
.sb-collapsible-head.open .sb-chevron {
  transform: rotate(180deg);
}

/* Cuerpo del grupo colapsable */
.sb-collapsible-body {
  display: none;
  flex-direction: column;
  gap: 2px;
  padding-left: var(--la-s-2);
  margin-top: 2px;
  border-left: 1px solid var(--la-glass-divider);
  margin-left: var(--la-s-5);
}
.sb-collapsible-body.open {
  display: flex;
}
/* Items dentro de grupo: ligeramente más compactos */
.sb-collapsible-body .ni {
  height: 36px;
  font-size: var(--la-fs-13);
}

/* Dot de notificación (vencimientos) */
.sb-venc-dot {
  margin-left: auto;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--la-accent);
  box-shadow: 0 0 0 3px rgba(255, 109, 41, 0.18);
}
.sb-venc-dot:empty { display: none; }

/* Badge NUEVO */
.sb-nuevo-badge {
  margin-left: auto;
  padding: 2px 6px;
  font-size: 9px;
  font-weight: var(--la-fw-bold);
  letter-spacing: 0.08em;
  color: var(--la-accent);
  background: var(--la-accent-tint-12);
  border-radius: var(--la-r-pill);
  text-transform: uppercase;
}

/* Footer del sidebar */
.sb-foot {
  padding-top: var(--la-s-4);
  margin-top: var(--la-s-3);
  border-top: 1px solid var(--la-glass-divider);
  display: flex;
  flex-direction: column;
  gap: var(--la-s-3);
}
.wagon-sig {
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  padding: 0 var(--la-s-3);
}
.wagon-label {
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.06em;
  color: var(--la-text-faint);
  text-transform: uppercase;
}
.wagon-logo {
  height: 14px;
  width: auto;
  opacity: 0.7;
}
.btn-out {
  height: 38px;
  border-radius: var(--la-r-sm);
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-secondary);
  background: transparent;
  border: 1px solid var(--la-glass-border);
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    color var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out);
}
.btn-out:hover {
  color: var(--la-text-primary);
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border-hi);
}

/* "Cierre de caja" suelto y "ni" finales fuera de .sb-nav */
#sidebar > .ni {
  margin: 0 0 var(--la-s-1);
}

/* ============================================================
   MAIN · contenido scrollable
   ============================================================ */
main#main {
  margin-left: var(--la-sidebar-w);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  /* Misma capa glass que la sidebar — translúcida, deja pasar el glow */
  background: rgba(12, 8, 4, 0.45);
  backdrop-filter: blur(var(--la-blur-md)) saturate(160%);
  -webkit-backdrop-filter: blur(var(--la-blur-md)) saturate(160%);
}

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  position: sticky;
  top: 0;
  z-index: var(--la-z-topbar);
  display: flex;
  align-items: center;
  gap: var(--la-s-4);
  height: var(--la-topbar-h);
  padding: 0 var(--la-s-5);
  /* Transparente — sin background ni borde */
  background: transparent;
}

/* Brand izquierda (mobile / fallback) */
.tb-brand {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
}
.tb-mobile-menu {
  display: none;
  width: 36px;
  height: 36px;
  border-radius: var(--la-r-sm);
  color: var(--la-text-secondary);
}
.tb-mobile-menu > svg {
  width: 20px;
  height: 20px;
}
.tb-mobile-menu:hover {
  background: var(--la-glass-bg-hi);
  color: var(--la-text-primary);
}
.tb-wagon-logo {
  height: 14px;
  width: auto;
  opacity: 0.85;
}
.tb-engine-sep {
  width: 1px;
  height: 16px;
  background: var(--la-glass-border);
}
.tb-engine {
  font-family: var(--la-font-mono);
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--la-text-muted);
}

/* En desktop ocultamos la brand de la topbar (la sidebar ya tiene el branding) */
@media (min-width: 961px) {
  .tb-brand { display: none; }
}

/* Centro · título de sección */
.tb-nav-center {
  display: flex;
  align-items: center;
}
.tb-section-title {
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--la-text-muted);
}
.tb-section-title #top-title {
  color: var(--la-text-primary);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  text-transform: none;
  font-size: var(--la-fs-14);
}

/* Zona de acciones de la página (se llena dinámicamente) */
.tb-action-zone {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  min-width: 0;
}
.tb-action-zone:empty { flex: 1; }

/* Derecha · indicadores y acciones */
.topbar-right {
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  margin-left: auto;
}

#topbar-action:empty,
#tb-primary-zone:empty { display: none; }

/* Campana de notificaciones */
.tb-notif-btn {
  position: relative;
  width: 38px;
  height: 38px;
  border-radius: var(--la-r-sm);
  color: var(--la-text-secondary);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  display: grid;
  place-items: center;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    color var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out);
}
.tb-notif-btn:hover {
  background: var(--la-glass-bg-hi);
  color: var(--la-text-primary);
  border-color: var(--la-glass-border-hi);
}
.tb-notif-badge {
  position: absolute;
  top: -3px;
  right: -3px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  font-size: 9px;
  font-weight: var(--la-fw-bold);
  color: var(--la-white);
  background: var(--la-accent);
  border-radius: var(--la-r-pill);
  display: grid;
  place-items: center;
  box-shadow: 0 0 0 2px rgba(22, 19, 22, 0.9);
}

/* Pill demo (visible en modo demo) */
.demo-pill {
  padding: 4px 10px;
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-semibold);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--la-warning);
  background: var(--la-warning-tint);
  border: 1px solid rgba(232, 179, 65, 0.28);
  border-radius: var(--la-r-pill);
}

/* Switch de modo de navegación (oscuro/claro) */
.nav-chrome-switch {
  position: relative;
  display: inline-block;
  width: 34px;
  height: 20px;
  cursor: pointer;
}
.nav-chrome-switch input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}
.nav-chrome-switch-track {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: var(--la-r-pill);
  background: var(--la-glass-bg-hi);
  border: 1px solid var(--la-glass-border);
  transition: background var(--la-dur-base) var(--la-ease-out);
}
.nav-chrome-switch-thumb {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--la-text-secondary);
  transition: transform var(--la-dur-base) var(--la-ease-out),
              background var(--la-dur-base) var(--la-ease-out);
}
.nav-chrome-switch input:checked + .nav-chrome-switch-track {
  background: var(--la-accent-tint-12);
  border-color: rgba(255, 109, 41, 0.36);
}
.nav-chrome-switch input:checked + .nav-chrome-switch-track .nav-chrome-switch-thumb {
  transform: translateX(14px);
  background: var(--la-accent);
}

/* ============================================================
   #pages · contenedor de páginas
   ============================================================ */
#pages {
  position: relative;
  flex: 1;
  padding: var(--la-s-5) var(--la-s-5);  /* 24px top/bottom · 24px h */
  width: 100%;
}

#pages > .page {
  display: none;
}
#pages > .page.active {
  display: block;
  animation: la-page-in var(--la-dur-slow) var(--la-ease-out) both;
}
@keyframes la-page-in {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: none; }
}

/* ============================================================
   RESPONSIVE · sidebar drawer en mobile
   ============================================================ */
@media (max-width: 960px) {
  #sidebar {
    transform: translateX(-100%);
    transition: transform var(--la-dur-slow) var(--la-ease-out);
    box-shadow: var(--la-shadow-xl);
  }
  #sidebar.open {
    transform: translateX(0);
  }
  main#main {
    margin-left: 0;
  }
  #sidebar-backdrop.open {
    display: block;
    position: fixed;
    inset: 0;
    z-index: calc(var(--la-z-sidebar) - 1);
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
  }
  .tb-mobile-menu { display: grid; place-items: center; }
  .topbar { padding: 0 var(--la-s-4); gap: var(--la-s-2); }
  #pages { padding: var(--la-s-4); }
}

/* ============================================================
   PASO 4 · CARDS DE VIDRIO + KPI CARDS
   Primitivos reusables que componen el resto del sistema.
   ============================================================ */

/* ── Card base (Soft Enterprise Glass) ──
   Uso: contenedor general de cualquier panel/widget.            */
.la-card {
  position: relative;
  padding: var(--la-s-5);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-lg);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow: var(--la-shadow-md);
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    transform var(--la-dur-base) var(--la-ease-out);
}

/* Hover global de cards (regla del doc: brillo + sombra + borde más visible) */
.la-card.is-interactive,
.la-card[data-interactive] {
  cursor: pointer;
}
.la-card.is-interactive:hover,
.la-card[data-interactive]:hover {
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border-hi);
  box-shadow: var(--la-shadow-lg);
  transform: translateY(-2px);
}

/* Variantes ── */
.la-card--surface {
  /* Cuando el blur no se desea (p.ej. sobre fondos sin contraste) */
  background: var(--la-surface-1);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

.la-card--accent {
  /* Card con halo accent perimetral suave (focus de pantalla) */
  border-color: rgba(255, 109, 41, 0.28);
  box-shadow:
    var(--la-shadow-md),
    0 0 0 1px rgba(255, 109, 41, 0.08),
    var(--la-glow-accent-sm);
}

.la-card--compact { padding: var(--la-s-4); }
.la-card--roomy   { padding: var(--la-s-6); }

/* Header / Body / Footer dentro de cards (opcional) */
.la-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
  margin-bottom: var(--la-s-4);
}
.la-card__title {
  font-size: var(--la-fs-15);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-text-primary);
  margin: 0;
}
.la-card__sub {
  font-size: var(--la-fs-13);
  color: var(--la-text-muted);
  margin: 0;
}
.la-card__actions {
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  margin-left: auto;
}
.la-card__foot {
  margin-top: var(--la-s-4);
  padding-top: var(--la-s-4);
  border-top: 1px solid var(--la-glass-divider);
}

/* ============================================================
   KPI CARD
   Estructura del mock:
     [ label                                      icon ]
     [                                                ]
     [ valor grande                                   ]
     [ ↑ X% vs período anterior                       ]
   ============================================================ */
.la-kpi {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--la-s-3);
  min-height: 128px;
  padding: var(--la-s-5);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-xl);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow: var(--la-shadow-md);
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    transform var(--la-dur-base) var(--la-ease-out);
}
.la-kpi:hover {
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border-hi);
  box-shadow: var(--la-shadow-lg);
  transform: translateY(-2px);
}

/* Fila superior · label + icon */
.la-kpi__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--la-s-3);
}
.la-kpi__label {
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-secondary);
  line-height: var(--la-lh-snug);
  letter-spacing: 0;
}

/* Icon en esquina superior derecha (tinted accent) */
.la-kpi__icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  border-radius: var(--la-r-sm);
  display: grid;
  place-items: center;
  color: var(--la-accent);
  background: var(--la-accent-tint-12);
  border: 1px solid rgba(255, 109, 41, 0.18);
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out);
}
.la-kpi__icon svg {
  width: 18px;
  height: 18px;
}
.la-kpi:hover .la-kpi__icon {
  background: var(--la-accent-tint-12);
  border-color: rgba(255, 109, 41, 0.32);
}

/* Variantes de tinte del icon */
.la-kpi__icon--neutral {
  color: var(--la-text-secondary);
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border);
}
.la-kpi__icon--success {
  color: var(--la-success);
  background: var(--la-success-tint);
  border-color: rgba(110, 210, 122, 0.28);
}
.la-kpi__icon--danger {
  color: var(--la-danger);
  background: var(--la-danger-tint);
  border-color: rgba(229, 86, 74, 0.28);
}
.la-kpi__icon--info {
  color: var(--la-info);
  background: var(--la-info-tint);
  border-color: rgba(106, 169, 233, 0.28);
}

/* Valor principal · numero grande tabular */
.la-kpi__value {
  font-size: var(--la-fs-36);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: 1.05;
  color: var(--la-text-primary);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  margin: 0;
}
.la-kpi__value--lg {
  font-size: var(--la-fs-40);
}

/* Tendencia (↑/↓ + % + sub) */
.la-kpi__trend {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  margin-top: auto;
  line-height: var(--la-lh-snug);
}
.la-kpi__trend-value {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-weight: var(--la-fw-semibold);
  font-variant-numeric: tabular-nums;
}
.la-trend-up    .la-kpi__trend-value { color: var(--la-success); }
.la-trend-down  .la-kpi__trend-value { color: var(--la-danger); }
.la-trend-flat  .la-kpi__trend-value { color: var(--la-text-muted); }
.la-kpi__trend-sub { color: var(--la-text-muted); }

/* Mini arrow utility (puede componerse como span con ↑ o usar svg) */
.la-arrow-up::before    { content: "↑"; margin-right: 2px; }
.la-arrow-down::before  { content: "↓"; margin-right: 2px; }
.la-arrow-flat::before  { content: "→"; margin-right: 2px; }

/* ============================================================
   KPI STRIP · grilla horizontal de KPIs (4–5 columnas)
   ============================================================ */
.la-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--la-content-gap);
}
.la-kpi-grid--4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.la-kpi-grid--5 {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

@media (max-width: 1180px) {
  .la-kpi-grid--5 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .la-kpi-grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
  .la-kpi-grid,
  .la-kpi-grid--4,
  .la-kpi-grid--5 { grid-template-columns: 1fr; }
}

/* ============================================================
   PASO 5 · BOTONES · INPUTS · PILLS · TABS · PAGE HEADERS
   ============================================================ */

/* ============================================================
   BOTONES
   ============================================================ */
.la-btn {
  --la-btn-h: 38px;
  --la-btn-px: 16px;
  --la-btn-fs: var(--la-fs-13);
  --la-btn-fw: var(--la-fw-semibold);

  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--la-s-2);
  height: var(--la-btn-h);
  padding: 0 var(--la-btn-px);
  border-radius: var(--la-r-sm);
  font-size: var(--la-btn-fs);
  font-weight: var(--la-btn-fw);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-text-primary);
  background: transparent;
  border: 1px solid transparent;
  white-space: nowrap;
  user-select: none;
  cursor: pointer;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    color var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    transform var(--la-dur-base) var(--la-ease-out);
}
.la-btn:disabled,
.la-btn[aria-disabled="true"] {
  opacity: 0.45;
  cursor: not-allowed;
  pointer-events: none;
}
.la-btn > svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}

/* Tamaños */
.la-btn--sm {
  --la-btn-h: 32px;
  --la-btn-px: 12px;
  --la-btn-fs: var(--la-fs-12);
}
.la-btn--lg {
  --la-btn-h: 46px;
  --la-btn-px: 22px;
  --la-btn-fs: var(--la-fs-14);
}
.la-btn--xl {
  --la-btn-h: 52px;
  --la-btn-px: 26px;
  --la-btn-fs: var(--la-fs-15);
}

/* Variante primary · CTA */
.la-btn--primary {
  color: var(--la-white);
  background: linear-gradient(180deg, var(--la-accent-hi) 0%, var(--la-accent) 100%);
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}
.la-btn--primary:hover {
  background: linear-gradient(180deg, #ff9460 0%, var(--la-accent-hi) 100%);
  box-shadow:
    var(--la-glow-accent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transform: translateY(-1px);
}
.la-btn--primary:active {
  background: linear-gradient(180deg, var(--la-accent) 0%, var(--la-accent-lo) 100%);
  transform: translateY(0);
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.10);
}

/* Variante secondary · ghost outline */
.la-btn--secondary {
  color: var(--la-text-primary);
  background: var(--la-glass-bg);
  border-color: var(--la-glass-border);
}
.la-btn--secondary:hover {
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border-hi);
}

/* Variante ghost · sin borde, solo hover bg */
.la-btn--ghost {
  color: var(--la-text-secondary);
  background: transparent;
}
.la-btn--ghost:hover {
  color: var(--la-text-primary);
  background: var(--la-glass-bg-hi);
}

/* Variante danger */
.la-btn--danger {
  color: var(--la-danger);
  background: var(--la-danger-tint);
  border-color: rgba(229, 86, 74, 0.28);
}
.la-btn--danger:hover {
  background: rgba(229, 86, 74, 0.22);
  border-color: rgba(229, 86, 74, 0.42);
}

/* Variante accent-soft · CTA secundaria con tinte naranja */
.la-btn--accent-soft {
  color: var(--la-accent);
  background: var(--la-accent-tint-08);
  border-color: rgba(255, 109, 41, 0.18);
}
.la-btn--accent-soft:hover {
  background: var(--la-accent-tint-12);
  border-color: rgba(255, 109, 41, 0.36);
  box-shadow: var(--la-glow-accent-sm);
}

/* Botón icon-only */
.la-btn--icon {
  --la-btn-px: 0;
  width: var(--la-btn-h);
  padding: 0;
}

/* SPLIT BUTTON · primary + chevron pegado a la derecha (como "+ Nueva venta ▼") */
.la-btn-split {
  display: inline-flex;
  align-items: stretch;
  border-radius: var(--la-r-sm);
  isolation: isolate;
  box-shadow:
    var(--la-glow-accent-sm),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
  transition: box-shadow var(--la-dur-base) var(--la-ease-out),
              transform var(--la-dur-base) var(--la-ease-out);
}
.la-btn-split:hover {
  box-shadow:
    var(--la-glow-accent),
    inset 0 1px 0 rgba(255, 255, 255, 0.22);
  transform: translateY(-1px);
}
.la-btn-split:active { transform: translateY(0); }
.la-btn-split > .la-btn {
  box-shadow: none;
  transform: none;
}
.la-btn-split > .la-btn:hover { transform: none; }
.la-btn-split > .la-btn--primary {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  padding-right: 14px;
}
.la-btn-split__divider {
  width: 1px;
  background: rgba(0, 0, 0, 0.20);
  align-self: stretch;
}
.la-btn-split > .la-btn--primary + .la-btn-split__divider + .la-btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  padding: 0 10px;
  width: auto;
}

/* ============================================================
   INPUTS · SELECTS · TEXTAREA
   ============================================================ */
.la-field {
  display: flex;
  flex-direction: column;
  gap: var(--la-s-2);
}
.la-field__label {
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  letter-spacing: 0.04em;
}
.la-field__hint {
  font-size: var(--la-fs-11);
  color: var(--la-text-faint);
  margin-top: 2px;
}
.la-field__error {
  font-size: var(--la-fs-12);
  color: var(--la-danger);
  margin-top: 2px;
}

/* Wrap unificado para input/select/textarea + iconos prefix/suffix */
.la-input {
  position: relative;
  display: flex;
  align-items: center;
  height: 40px;
  padding: 0 var(--la-s-3);
  background: var(--la-surface-2);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-sm);
  transition:
    border-color var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out);
}
.la-input:hover {
  background: var(--la-surface-3);
  border-color: var(--la-glass-border-hi);
}
.la-input:focus-within {
  border-color: var(--la-accent);
  box-shadow: 0 0 0 4px var(--la-accent-tint-08);
}
.la-input--lg { height: 46px; padding: 0 var(--la-s-4); }
.la-input--sm { height: 32px; padding: 0 var(--la-s-2); font-size: var(--la-fs-12); }

.la-input > input,
.la-input > select,
.la-input > textarea {
  flex: 1;
  min-width: 0;
  height: 100%;
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-primary);
  background: transparent;
  border: 0;
  outline: none;
}
.la-input > input::placeholder,
.la-input > textarea::placeholder {
  color: var(--la-text-faint);
  font-weight: var(--la-fw-regular);
}
.la-input > select {
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  padding-right: var(--la-s-5);
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,0.55)' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat: no-repeat;
  background-position: right 0 center;
  background-size: 12px 12px;
}
.la-input > select option {
  background: var(--la-surface-1);
  color: var(--la-text-primary);
}

/* Iconos prefix/suffix */
.la-input__prefix,
.la-input__suffix {
  display: grid;
  place-items: center;
  width: 18px;
  height: 18px;
  color: var(--la-text-muted);
  flex-shrink: 0;
}
.la-input__prefix { margin-right: var(--la-s-2); }
.la-input__suffix { margin-left: var(--la-s-2); }
.la-input__prefix svg,
.la-input__suffix svg { width: 16px; height: 16px; }

/* Search específico · pill ancho */
.la-search {
  position: relative;
  display: flex;
  align-items: center;
  height: 40px;
  padding: 0 var(--la-s-4);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-md);
  transition: border-color var(--la-dur-base) var(--la-ease-out),
              background var(--la-dur-base) var(--la-ease-out);
}
.la-search:hover { background: var(--la-glass-bg-hi); border-color: var(--la-glass-border-hi); }
.la-search:focus-within { border-color: var(--la-accent); box-shadow: 0 0 0 4px var(--la-accent-tint-08); }
.la-search__icon { width: 16px; height: 16px; color: var(--la-text-muted); margin-right: var(--la-s-2); }
.la-search > input {
  flex: 1; min-width: 0; height: 100%;
  font-size: var(--la-fs-14); color: var(--la-text-primary);
  background: transparent; border: 0; outline: none;
}
.la-search > input::placeholder { color: var(--la-text-faint); }
.la-kbd {
  font-family: var(--la-font-mono);
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-muted);
  padding: 3px 7px;
  background: var(--la-surface-2);
  border: 1px solid var(--la-glass-border);
  border-radius: 6px;
}

/* Textarea: altura libre */
.la-input--textarea {
  height: auto;
  padding: var(--la-s-3);
  align-items: flex-start;
}
.la-input--textarea > textarea {
  height: auto;
  min-height: 80px;
  resize: vertical;
  line-height: var(--la-lh-normal);
}

/* Checkbox / radio (mínimo · ya hay accent + dark theme handled by color-scheme) */
.la-check {
  display: inline-flex;
  align-items: center;
  gap: var(--la-s-2);
  font-size: var(--la-fs-13);
  color: var(--la-text-secondary);
  cursor: pointer;
}
.la-check input[type="checkbox"],
.la-check input[type="radio"] {
  width: 16px;
  height: 16px;
  accent-color: var(--la-accent);
  cursor: pointer;
}

/* ============================================================
   PILLS / BADGES
   ============================================================ */
.la-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 22px;
  padding: 0 10px;
  font-size: var(--la-fs-11);
  font-weight: var(--la-fw-semibold);
  letter-spacing: 0.02em;
  border-radius: var(--la-r-pill);
  background: var(--la-glass-bg-hi);
  color: var(--la-text-secondary);
  border: 1px solid var(--la-glass-border);
  white-space: nowrap;
}
.la-pill--sm { height: 18px; padding: 0 8px; font-size: 10px; }
.la-pill--lg { height: 26px; padding: 0 12px; font-size: var(--la-fs-12); }

/* Variantes semánticas (bajo contraste, tinted) */
.la-pill--success { color: var(--la-success); background: var(--la-success-tint); border-color: rgba(110, 210, 122, 0.28); }
.la-pill--danger  { color: var(--la-danger);  background: var(--la-danger-tint);  border-color: rgba(229, 86, 74, 0.28); }
.la-pill--warning { color: var(--la-warning); background: var(--la-warning-tint); border-color: rgba(232, 179, 65, 0.28); }
.la-pill--info    { color: var(--la-info);    background: var(--la-info-tint);    border-color: rgba(106, 169, 233, 0.28); }
.la-pill--accent  { color: var(--la-accent);  background: var(--la-accent-tint-12); border-color: rgba(255, 109, 41, 0.28); }

/* Variante solid accent (como "Pedido" en mock Ventas) */
.la-pill--solid {
  color: var(--la-white);
  background: var(--la-accent);
  border-color: transparent;
}

/* Dot interno */
.la-pill__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}

/* ============================================================
   TABS · subrayadas (estilo Reportes)
   ============================================================ */
.la-tabs {
  position: relative;
  display: flex;
  gap: var(--la-s-1);
  border-bottom: 1px solid var(--la-glass-divider);
  margin-bottom: var(--la-s-5);
}
.la-tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--la-s-2);
  height: 40px;
  padding: 0 var(--la-s-4);
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition: color var(--la-dur-base) var(--la-ease-out);
}
.la-tab:hover { color: var(--la-text-primary); }
.la-tab::after {
  content: "";
  position: absolute;
  left: var(--la-s-4);
  right: var(--la-s-4);
  bottom: -1px;
  height: 2px;
  background: var(--la-accent);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--la-dur-base) var(--la-ease-out);
  box-shadow: var(--la-glow-accent-sm);
}
.la-tab.is-active,
.la-tab[aria-selected="true"] {
  color: var(--la-accent);
  font-weight: var(--la-fw-semibold);
}
.la-tab.is-active::after,
.la-tab[aria-selected="true"]::after {
  transform: scaleX(1);
}

/* Tabs pill (alternativo, no por defecto) */
.la-tabs--pill {
  border-bottom: 0;
  gap: 4px;
  padding: 4px;
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-pill);
  width: max-content;
  margin-bottom: var(--la-s-5);
}
.la-tabs--pill .la-tab {
  height: 32px;
  padding: 0 var(--la-s-4);
  border-radius: var(--la-r-pill);
  font-size: var(--la-fs-13);
}
.la-tabs--pill .la-tab::after { display: none; }
.la-tabs--pill .la-tab.is-active,
.la-tabs--pill .la-tab[aria-selected="true"] {
  color: var(--la-white);
  background: linear-gradient(180deg, var(--la-accent-hi) 0%, var(--la-accent) 100%);
  box-shadow: var(--la-glow-accent-sm), inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

/* ============================================================
   PAGE HEADER · título + subtítulo + acciones
   ============================================================ */
.la-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--la-s-5);
  margin-bottom: var(--la-s-5);
}
.la-page-header__main {
  min-width: 0;
}
.la-page-header__title {
  font-size: var(--la-fs-32);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-tight);
  line-height: 1.08;
  color: var(--la-text-primary);
  margin: 0 0 6px;
}
.la-page-header__sub {
  font-size: var(--la-fs-14);
  color: var(--la-text-secondary);
  margin: 0;
  max-width: 64ch;
  line-height: var(--la-lh-normal);
}
.la-page-header__actions {
  display: flex;
  align-items: center;
  gap: var(--la-s-2);
  flex-shrink: 0;
}

/* Filter bar (línea de filtros tipo Reportes) */
.la-filter-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--la-s-3);
  margin-bottom: var(--la-s-5);
}
.la-filter-bar > .la-input { min-width: 220px; }
.la-filter-bar__spacer { flex: 1; }
.la-filter-bar__group {
  display: inline-flex;
  align-items: center;
  gap: var(--la-s-2);
  color: var(--la-text-muted);
  font-size: var(--la-fs-13);
}

/* ============================================================
   PASO 6 · TABLAS + WRAPPER DE CHARTS
   ============================================================ */

/* ============================================================
   TABLAS · estilo "liviana, rápida, premium"
   Sin bordes verticales · separadores horizontales sutiles
   ============================================================ */
.la-table-wrap {
  position: relative;
  overflow-x: auto;
  border-radius: var(--la-r-lg);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
}

.la-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--la-fs-13);
  color: var(--la-text-primary);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}

/* Cabecera */
.la-table thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: var(--la-s-3) var(--la-s-4);
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  letter-spacing: 0.04em;
  color: var(--la-text-muted);
  text-align: left;
  white-space: nowrap;
  background: rgba(22, 19, 22, 0.85);
  border-bottom: 1px solid var(--la-glass-divider);
  backdrop-filter: blur(var(--la-blur-sm));
  -webkit-backdrop-filter: blur(var(--la-blur-sm));
}
.la-table thead th:first-child { padding-left: var(--la-s-5); }
.la-table thead th:last-child  { padding-right: var(--la-s-5); }

/* Cuerpo */
.la-table tbody td {
  padding: var(--la-s-3) var(--la-s-4);
  border-bottom: 1px solid var(--la-glass-divider);
  color: var(--la-text-primary);
  vertical-align: middle;
}
.la-table tbody td:first-child { padding-left: var(--la-s-5); }
.la-table tbody td:last-child  { padding-right: var(--la-s-5); }

.la-table tbody tr {
  transition: background var(--la-dur-fast) var(--la-ease-out);
}
.la-table tbody tr:hover td {
  background: var(--la-glass-bg-hi);
}
.la-table tbody tr:last-child td {
  border-bottom: 0;
}

/* Última fila highlight (totales) */
.la-table tfoot td {
  padding: var(--la-s-3) var(--la-s-4);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-primary);
  background: var(--la-glass-bg-hi);
  border-top: 1px solid var(--la-glass-border);
}
.la-table tfoot td:first-child { padding-left: var(--la-s-5); }
.la-table tfoot td:last-child  { padding-right: var(--la-s-5); }

/* Alineaciones utilitarias */
.la-table .la-num,
.la-table .la-tabular,
.la-table td.is-num,
.la-table th.is-num {
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.la-table td.is-center, .la-table th.is-center { text-align: center; }
.la-table td.is-muted   { color: var(--la-text-muted); }
.la-table td.is-strong  { font-weight: var(--la-fw-semibold); }

/* Header con flecha de ordenamiento */
.la-table th.is-sortable {
  cursor: pointer;
  user-select: none;
}
.la-table th.is-sortable:hover { color: var(--la-text-secondary); }
.la-table th.is-sortable::after {
  content: "";
  display: inline-block;
  width: 0; height: 0;
  margin-left: 6px;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 4px solid currentColor;
  vertical-align: middle;
  opacity: 0.4;
  transition: opacity var(--la-dur-base) var(--la-ease-out),
              transform var(--la-dur-base) var(--la-ease-out);
}
.la-table th.is-sorted-asc::after  { opacity: 1; transform: rotate(180deg); color: var(--la-accent); }
.la-table th.is-sorted-desc::after { opacity: 1; color: var(--la-accent); }

/* Variante densa */
.la-table--dense thead th { padding: var(--la-s-2) var(--la-s-3); }
.la-table--dense tbody td { padding: var(--la-s-2) var(--la-s-3); }

/* Producto/cliente cell (avatar + nombre + sub) */
.la-cell-prod {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
}
.la-cell-prod__avatar {
  width: 32px;
  height: 32px;
  border-radius: var(--la-r-xs);
  background: var(--la-glass-bg-hi);
  border: 1px solid var(--la-glass-border);
  display: grid;
  place-items: center;
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-secondary);
  flex-shrink: 0;
  overflow: hidden;
}
.la-cell-prod__avatar img { width: 100%; height: 100%; object-fit: cover; }
.la-cell-prod__main { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.la-cell-prod__name { font-weight: var(--la-fw-medium); color: var(--la-text-primary); }
.la-cell-prod__sub  { font-size: var(--la-fs-11); color: var(--la-text-muted); font-family: var(--la-font-mono); letter-spacing: 0.04em; }

/* Acciones de fila (kebab/trash) */
.la-row-actions {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.la-row-actions .la-btn { --la-btn-h: 30px; }

/* Botón de acción inline (icon-only tinted) */
.la-icon-act {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: var(--la-r-xs);
  color: var(--la-text-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition:
    color var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out);
}
.la-icon-act:hover { color: var(--la-text-primary); background: var(--la-glass-bg-hi); }
.la-icon-act--danger:hover { color: var(--la-danger); background: var(--la-danger-tint); }
.la-icon-act--accent {
  color: var(--la-accent);
  background: var(--la-accent-tint-08);
}
.la-icon-act--accent:hover { background: var(--la-accent-tint-12); }
.la-icon-act svg { width: 16px; height: 16px; }

/* Pagination footer (placeholder mínimo) */
.la-table-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--la-s-3) var(--la-s-5);
  border-top: 1px solid var(--la-glass-divider);
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
}

/* Empty state dentro de tabla */
.la-table-empty {
  padding: var(--la-s-7) var(--la-s-5);
  text-align: center;
  color: var(--la-text-muted);
  font-size: var(--la-fs-13);
}

/* ============================================================
   CHARTS WRAPPER
   Card contenedor para Chart.js + zonas auxiliares (header, legend)
   ============================================================ */
.la-chart-card {
  position: relative;
  padding: var(--la-s-5);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-lg);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow: var(--la-shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--la-s-4);
}

.la-chart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
}
.la-chart-title {
  font-size: var(--la-fs-15);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-text-primary);
  margin: 0;
}
.la-chart-sub {
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
  margin: 2px 0 0;
}

/* Body del chart · alto fijo (Chart.js lo respeta) */
.la-chart-body {
  position: relative;
  width: 100%;
  height: 260px;
}
.la-chart-body--sm { height: 180px; }
.la-chart-body--md { height: 260px; }
.la-chart-body--lg { height: 340px; }

/* Layout dos columnas: chart + lista lateral (como Ventas por categoría) */
.la-chart-split {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--la-s-5);
  align-items: center;
}
@media (max-width: 720px) {
  .la-chart-split { grid-template-columns: 1fr; }
}

/* Donut con label central */
.la-donut-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-width: 240px;
  margin: 0 auto;
}
.la-donut-center {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-align: center;
  pointer-events: none;
}
.la-donut-center__value {
  font-size: var(--la-fs-20);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--la-tr-snug);
}
.la-donut-center__label {
  margin-top: 2px;
  font-size: var(--la-fs-11);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--la-text-muted);
}

/* Leyenda · lista con dot + label + value (+ %) */
.la-legend {
  display: flex;
  flex-direction: column;
  gap: var(--la-s-2);
  font-size: var(--la-fs-13);
}
.la-legend__row {
  display: grid;
  grid-template-columns: 14px 1fr auto auto;
  align-items: center;
  gap: var(--la-s-3);
  padding: 6px 0;
}
.la-legend__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--la-accent);
  box-shadow: 0 0 0 2px rgba(255, 109, 41, 0.18);
}
.la-legend__label { color: var(--la-text-secondary); }
.la-legend__value {
  font-variant-numeric: tabular-nums;
  font-weight: var(--la-fw-medium);
  color: var(--la-text-primary);
}
.la-legend__pct {
  font-variant-numeric: tabular-nums;
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
  min-width: 48px;
  text-align: right;
}

/* Series de colores predefinidas (uso en leyenda + dataset Chart.js) */
.la-series-1 .la-legend__dot { background: var(--la-accent); box-shadow: 0 0 0 2px rgba(255, 109, 41, 0.18); }
.la-series-2 .la-legend__dot { background: #ff9460; box-shadow: 0 0 0 2px rgba(255, 148, 96, 0.18); }
.la-series-3 .la-legend__dot { background: #f7b88d; box-shadow: 0 0 0 2px rgba(247, 184, 141, 0.18); }
.la-series-4 .la-legend__dot { background: var(--la-text-faint); box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.10); }
.la-series-5 .la-legend__dot { background: var(--la-success); box-shadow: 0 0 0 2px rgba(110, 210, 122, 0.18); }
.la-series-6 .la-legend__dot { background: var(--la-info); box-shadow: 0 0 0 2px rgba(106, 169, 233, 0.18); }

/* Selector de período en header de chart (compacto) */
.la-chart-period {
  display: inline-flex;
  align-items: center;
}
.la-chart-period .la-input {
  height: 32px;
  padding: 0 var(--la-s-3);
  font-size: var(--la-fs-12);
}

/* ============================================================
   PASO 7 · MODALES · OVERLAYS · STEPPER · TOASTS
   ============================================================ */

/* ============================================================
   OVERLAY (backdrop dim + blur)
   ============================================================ */
.la-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--la-z-overlay);
  display: grid;
  place-items: center;
  padding: var(--la-s-5);
  background: rgba(8, 6, 7, 0.62);
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
  animation: la-overlay-in var(--la-dur-base) var(--la-ease-out) both;
}
@keyframes la-overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ============================================================
   MODAL · panel central
   ============================================================ */
.la-modal {
  position: relative;
  width: min(720px, 100%);
  max-height: calc(100vh - 80px);
  display: flex;
  flex-direction: column;
  background:
    linear-gradient(180deg, rgba(34, 28, 30, 0.92) 0%, rgba(22, 19, 22, 0.94) 100%);
  border: 1px solid var(--la-glass-border-hi);
  border-radius: var(--la-r-xl);
  box-shadow:
    var(--la-shadow-xl),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(var(--la-blur-xl)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-xl)) saturate(140%);
  overflow: hidden;
  animation: la-modal-in var(--la-dur-slow) var(--la-ease-out) both;
}
@keyframes la-modal-in {
  from { opacity: 0; transform: translateY(12px) scale(0.985); }
  to   { opacity: 1; transform: none; }
}

/* Tamaños */
.la-modal--sm { width: min(440px, 100%); }
.la-modal--md { width: min(720px, 100%); }
.la-modal--lg { width: min(960px, 100%); }
.la-modal--xl { width: min(1200px, 100%); }

/* Header */
.la-modal__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--la-s-4);
  padding: var(--la-s-5) var(--la-s-6) var(--la-s-3);
}
.la-modal__title-wrap { min-width: 0; }
.la-modal__title {
  font-size: var(--la-fs-24);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: 1.15;
  color: var(--la-text-primary);
  margin: 0;
}
.la-modal__sub {
  font-size: var(--la-fs-13);
  color: var(--la-text-secondary);
  margin: 4px 0 0;
}

.la-modal__close {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: var(--la-r-xs);
  color: var(--la-text-muted);
  background: transparent;
  border: 0;
  cursor: pointer;
  transition:
    color var(--la-dur-base) var(--la-ease-out),
    background var(--la-dur-base) var(--la-ease-out);
}
.la-modal__close:hover {
  color: var(--la-text-primary);
  background: var(--la-glass-bg-hi);
}
.la-modal__close svg { width: 18px; height: 18px; }

/* Body con scroll si supera el alto */
.la-modal__body {
  padding: var(--la-s-5) var(--la-s-6);
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
.la-modal__body--flush { padding: 0; }

/* Footer */
.la-modal__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
  padding: var(--la-s-4) var(--la-s-6) var(--la-s-5);
  border-top: 1px solid var(--la-glass-divider);
  background: rgba(0, 0, 0, 0.18);
}
.la-modal__foot--end {
  justify-content: flex-end;
}
.la-modal__foot-hint {
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
}
.la-modal__foot-actions {
  display: inline-flex;
  align-items: center;
  gap: var(--la-s-2);
}

/* ============================================================
   STEPPER · numbered (modal "Nueva venta")
   Estructura:
     .la-stepper
       .la-step.is-active|is-done
         .la-step__num · .la-step__label
       .la-step__divider (entre steps)
   ============================================================ */
.la-stepper {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
  padding: 0 var(--la-s-6) var(--la-s-5);
}

.la-step {
  display: inline-flex;
  align-items: center;
  gap: var(--la-s-2);
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  transition: color var(--la-dur-base) var(--la-ease-out);
}
.la-step__num {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-muted);
  background: var(--la-glass-bg-hi);
  border: 1px solid var(--la-glass-border);
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    color var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out);
}
.la-step.is-active {
  color: var(--la-accent);
}
.la-step.is-active .la-step__num {
  color: var(--la-white);
  background: var(--la-accent);
  border-color: transparent;
  box-shadow: var(--la-glow-accent-sm);
}
.la-step.is-done {
  color: var(--la-text-secondary);
}
.la-step.is-done .la-step__num {
  color: var(--la-white);
  background: var(--la-accent-lo);
  border-color: transparent;
}
.la-step.is-done .la-step__num::before {
  content: "✓";
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-bold);
}
.la-step.is-done .la-step__num .la-step__num-digit {
  display: none;
}

.la-step__divider {
  flex: 1;
  height: 1px;
  background: var(--la-glass-divider);
  min-width: 24px;
}
.la-step.is-active + .la-step__divider,
.la-step.is-done + .la-step__divider {
  background: rgba(255, 109, 41, 0.32);
}

/* ============================================================
   FORM HELPERS para modales (grid de inputs)
   ============================================================ */
.la-form-grid {
  display: grid;
  gap: var(--la-s-4);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.la-form-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.la-form-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.la-form-grid > .la-field.is-span-2 { grid-column: span 2; }
.la-form-grid > .la-field.is-span-full { grid-column: 1 / -1; }
@media (max-width: 720px) {
  .la-form-grid,
  .la-form-grid--3,
  .la-form-grid--4 { grid-template-columns: 1fr; }
  .la-form-grid > .la-field.is-span-2 { grid-column: auto; }
}

/* Sección dentro de modal (separadores) */
.la-modal-section {
  margin-bottom: var(--la-s-5);
}
.la-modal-section:last-child { margin-bottom: 0; }
.la-modal-section__title {
  font-size: var(--la-fs-15);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-text-primary);
  margin: 0 0 var(--la-s-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
}
.la-modal-section__actions { display: inline-flex; gap: var(--la-s-2); }

/* Totales (panel del modal Nueva venta) */
.la-totals {
  padding: var(--la-s-4);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-md);
  display: flex;
  flex-direction: column;
  gap: var(--la-s-2);
}
.la-totals__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
  font-size: var(--la-fs-13);
  color: var(--la-text-secondary);
}
.la-totals__row .la-num,
.la-totals__row .la-totals__value {
  font-variant-numeric: tabular-nums;
  color: var(--la-text-primary);
  font-weight: var(--la-fw-medium);
}
.la-totals__row--final {
  margin-top: var(--la-s-2);
  padding-top: var(--la-s-3);
  border-top: 1px solid var(--la-glass-divider);
  font-size: var(--la-fs-15);
  color: var(--la-text-primary);
  font-weight: var(--la-fw-semibold);
}
.la-totals__row--final .la-totals__value {
  font-size: var(--la-fs-20);
  color: var(--la-accent);
  font-weight: var(--la-fw-semibold);
}

/* ============================================================
   DRAWER · panel lateral (variante)
   ============================================================ */
.la-drawer {
  position: fixed;
  top: 0;
  bottom: 0;
  right: 0;
  width: min(480px, 100%);
  z-index: var(--la-z-modal);
  display: flex;
  flex-direction: column;
  background: linear-gradient(180deg, rgba(34, 28, 30, 0.96) 0%, rgba(22, 19, 22, 0.98) 100%);
  border-left: 1px solid var(--la-glass-border-hi);
  box-shadow: var(--la-shadow-xl);
  backdrop-filter: blur(var(--la-blur-xl)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-xl)) saturate(140%);
  transform: translateX(100%);
  transition: transform var(--la-dur-slow) var(--la-ease-out);
}
.la-drawer.is-open { transform: translateX(0); }
.la-drawer--left {
  right: auto;
  left: 0;
  border-left: 0;
  border-right: 1px solid var(--la-glass-border-hi);
  transform: translateX(-100%);
}
.la-drawer--left.is-open { transform: translateX(0); }

.la-drawer__head { padding: var(--la-s-5) var(--la-s-5) var(--la-s-3); display: flex; justify-content: space-between; align-items: flex-start; gap: var(--la-s-3); }
.la-drawer__body { flex: 1; min-height: 0; overflow-y: auto; padding: var(--la-s-3) var(--la-s-5) var(--la-s-5); }
.la-drawer__foot { padding: var(--la-s-4) var(--la-s-5); border-top: 1px solid var(--la-glass-divider); }

/* ============================================================
   TOASTS
   Container: #toast-c (sub-rule global ya lo oculta hasta uso)
   ============================================================ */
#toast-c,
.la-toast-container {
  display: flex;
  position: fixed;
  bottom: var(--la-s-5);
  right: var(--la-s-5);
  z-index: var(--la-z-toast);
  flex-direction: column;
  gap: var(--la-s-2);
  pointer-events: none;
}
#toast-c:not(:has(.la-toast, > *:not(:empty))) { display: none; }

.la-toast {
  pointer-events: auto;
  min-width: 280px;
  max-width: 380px;
  display: flex;
  align-items: flex-start;
  gap: var(--la-s-3);
  padding: var(--la-s-3) var(--la-s-4);
  background: rgba(34, 28, 30, 0.96);
  border: 1px solid var(--la-glass-border-hi);
  border-radius: var(--la-r-md);
  box-shadow: var(--la-shadow-lg);
  backdrop-filter: blur(var(--la-blur-md)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-md)) saturate(140%);
  animation: la-toast-in var(--la-dur-slow) var(--la-ease-out) both;
}
@keyframes la-toast-in {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: none; }
}
.la-toast__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  color: var(--la-text-secondary);
}
.la-toast__icon svg { width: 18px; height: 18px; }
.la-toast__body { flex: 1; min-width: 0; font-size: var(--la-fs-13); color: var(--la-text-primary); line-height: var(--la-lh-snug); }
.la-toast__title { font-weight: var(--la-fw-semibold); margin: 0 0 2px; }
.la-toast__msg   { color: var(--la-text-secondary); margin: 0; }
.la-toast__close {
  width: 22px; height: 22px;
  border-radius: var(--la-r-xs);
  display: grid; place-items: center;
  color: var(--la-text-muted); background: transparent; border: 0; cursor: pointer;
  flex-shrink: 0;
}
.la-toast__close:hover { color: var(--la-text-primary); background: var(--la-glass-bg-hi); }

/* Variantes (borde + icon) */
.la-toast--success { border-color: rgba(110, 210, 122, 0.36); }
.la-toast--success .la-toast__icon { color: var(--la-success); }
.la-toast--danger  { border-color: rgba(229, 86, 74, 0.36); }
.la-toast--danger  .la-toast__icon { color: var(--la-danger); }
.la-toast--warning { border-color: rgba(232, 179, 65, 0.36); }
.la-toast--warning .la-toast__icon { color: var(--la-warning); }
.la-toast--info    { border-color: rgba(106, 169, 233, 0.36); }
.la-toast--info    .la-toast__icon { color: var(--la-info); }
.la-toast--accent  { border-color: rgba(255, 109, 41, 0.36); }
.la-toast--accent  .la-toast__icon { color: var(--la-accent); }

/* Cuando el container tiene contenido, anular el display:none global */
#toast-c.is-active,
#toast-c:has(.la-toast) { display: flex; }

/* ============================================================
   TOPBAR · search global + CTA split (v8)
   ============================================================ */
.tb-search {
  width: 100%;
  max-width: 560px;
  height: 42px;
  border-radius: var(--la-r-md);
}
.tb-search > input { font-size: var(--la-fs-14); }
.tb-nav-center {
  flex: 1;
  display: flex;
  justify-content: flex-start;
  min-width: 0;
}
.tb-cta {
  flex-shrink: 0;
}
.tb-cta .la-btn--primary {
  --la-btn-h: 42px;
  --la-btn-px: 18px;
  --la-btn-fs: var(--la-fs-14);
}
/* Cuando .tb-cta está en el topbar, anulamos el `.la-btn-split` extra hover (ya tiene su propio glow) */

/* ============================================================
   PASO 8 · PÁGINA DASHBOARD
   ============================================================ */

/* Header de página */
.dash-header {
  margin-bottom: var(--la-s-5);
}
.dash-greeting {
  font-size: var(--la-fs-32);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-tight);
  line-height: 1.05;
  color: var(--la-text-primary);
  margin: 0 0 6px;
}
.dash-wave {
  display: inline-block;
  transform-origin: 70% 70%;
  animation: dash-wave 2.4s ease-in-out infinite;
}
@keyframes dash-wave {
  0%, 60%, 100% { transform: rotate(0); }
  10% { transform: rotate(14deg); }
  20% { transform: rotate(-8deg); }
  30% { transform: rotate(14deg); }
  40% { transform: rotate(-4deg); }
  50% { transform: rotate(10deg); }
}
.dash-subhead {
  font-size: var(--la-fs-14);
  color: var(--la-text-secondary);
  margin: 0;
  line-height: var(--la-lh-normal);
}

/* ====== KPI ROW (5 columnas) ====== */
.dash-kpi-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: var(--la-content-gap);
  margin-bottom: var(--la-content-gap);
}
@media (max-width: 1280px) {
  .dash-kpi-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 880px) {
  .dash-kpi-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px) {
  .dash-kpi-row { grid-template-columns: 1fr; }
}

.dash-kpi {
  position: relative;
  padding: var(--la-s-5);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-xl);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow: var(--la-shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--la-s-2);
  overflow: hidden;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out),
    transform var(--la-dur-base) var(--la-ease-out);
}
.dash-kpi:hover {
  background: var(--la-glass-bg-hi);
  border-color: var(--la-glass-border-hi);
  box-shadow: var(--la-shadow-lg);
  transform: translateY(-2px);
}

.dash-kpi__head {
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
}
.dash-kpi__icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  border-radius: var(--la-r-sm);
  display: grid;
  place-items: center;
  color: var(--la-accent);
  background: var(--la-accent-tint-12);
  border: 1px solid rgba(255, 109, 41, 0.18);
}
.dash-kpi__icon svg { width: 18px; height: 18px; }
.dash-kpi__icon--accent  { color: var(--la-accent); background: var(--la-accent-tint-12); border-color: rgba(255, 109, 41, 0.18); }
.dash-kpi__icon--purple  { color: #b290ff; background: rgba(155, 108, 242, 0.14); border-color: rgba(155, 108, 242, 0.28); }
.dash-kpi__icon--success { color: var(--la-success); background: var(--la-success-tint); border-color: rgba(110, 210, 122, 0.28); }
.dash-kpi__icon--danger  { color: var(--la-danger); background: var(--la-danger-tint); border-color: rgba(229, 86, 74, 0.28); }

.dash-kpi__title {
  font-size: var(--la-fs-13);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-secondary);
}
.dash-kpi__value {
  font-size: var(--la-fs-28);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  line-height: 1.1;
  color: var(--la-text-primary);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
  margin: 2px 0 0;
}
.dash-kpi__trend {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
}
.dash-kpi__trend-value {
  font-weight: var(--la-fw-semibold);
  font-variant-numeric: tabular-nums;
}
.la-trend-up   .dash-kpi__trend-value { color: var(--la-success); }
.la-trend-down .dash-kpi__trend-value { color: var(--la-danger); }
.dash-kpi__trend-sub { color: var(--la-text-muted); }

/* Sparkline (line) y bars */
.dash-kpi__spark {
  margin-top: var(--la-s-2);
  height: 50px;
  width: 100%;
}
.dash-kpi__spark svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ====== ROW 2 · charts ====== */
.dash-charts-row {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--la-content-gap);
  margin-bottom: var(--la-content-gap);
}
@media (max-width: 1180px) {
  .dash-charts-row { grid-template-columns: 1fr; }
}

/* Card genérica del dashboard */
.dash-card {
  position: relative;
  padding: var(--la-s-5);
  background: var(--la-glass-bg);
  border: 1px solid var(--la-glass-border);
  border-radius: var(--la-r-xl);
  backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--la-blur-lg)) saturate(140%);
  box-shadow: var(--la-shadow-md);
}
.dash-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--la-s-3);
  margin-bottom: var(--la-s-4);
}
.dash-card__title {
  font-size: var(--la-fs-15);
  font-weight: var(--la-fw-semibold);
  letter-spacing: var(--la-tr-snug);
  color: var(--la-text-primary);
  margin: 0;
}
.dash-card__period {
  height: 32px;
  padding: 0 var(--la-s-3);
}
.dash-card__period > select {
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
}
.dash-card__link {
  background: transparent;
  border: 0;
  font-size: var(--la-fs-12);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-muted);
  padding: 4px 10px;
  border-radius: var(--la-r-pill);
  cursor: pointer;
  transition: color var(--la-dur-base) var(--la-ease-out),
              background var(--la-dur-base) var(--la-ease-out);
}
.dash-card__link:hover {
  color: var(--la-text-primary);
  background: var(--la-glass-bg-hi);
}

/* Chart body (línea grande) */
.dash-chart-body {
  position: relative;
  width: 100%;
  height: 280px;
}
.dash-chart-body canvas { width: 100% !important; height: 100% !important; display: block; }
.dash-chart-fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}
/* Si Chart.js no se inicializa, el fallback queda visible. Si se inicializa, se monta el canvas encima */
#nd-chart-tendencia + .dash-chart-fallback { /* hint */ }

.dash-chart-tooltip {
  position: absolute;
  top: 30px;
  left: 56%;
  transform: translateX(-50%);
  padding: var(--la-s-2) var(--la-s-3);
  background: rgba(22, 19, 22, 0.96);
  border: 1px solid var(--la-glass-border-hi);
  border-radius: var(--la-r-sm);
  box-shadow: var(--la-shadow-md);
  font-size: var(--la-fs-12);
  pointer-events: none;
  white-space: nowrap;
}
.dash-chart-tooltip__date {
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-primary);
  margin-bottom: 2px;
}
.dash-chart-tooltip__row {
  color: var(--la-text-secondary);
  display: flex;
  align-items: center;
  gap: 6px;
}
.dash-chart-tooltip__row strong {
  color: var(--la-text-primary);
  font-weight: var(--la-fw-semibold);
  font-variant-numeric: tabular-nums;
}
.dash-chart-tooltip__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--la-accent);
  box-shadow: 0 0 0 2px rgba(255, 109, 41, 0.22);
}
.dash-chart-axis {
  display: flex;
  justify-content: space-between;
  margin-top: var(--la-s-2);
  padding: 0 4px;
  font-size: var(--la-fs-11);
  color: var(--la-text-muted);
  font-variant-numeric: tabular-nums;
}

/* Donut split (chart + leyenda) — reusa primitivo .la-donut-wrap */
.dash-donut-split {
  display: grid;
  grid-template-columns: 200px 1fr;
  align-items: center;
  gap: var(--la-s-5);
}
@media (max-width: 720px) {
  .dash-donut-split { grid-template-columns: 1fr; justify-items: center; }
}

/* Lista de leyenda del donut grande (4 columnas dot/label/pct/value) */
.dash-card--donut .la-legend__row,
.dash-card--inventory .la-legend__row {
  grid-template-columns: 14px 1fr auto auto;
  padding: 4px 0;
}

/* ====== ROW 3 · 3 columnas (Productos · Inventario · Actividad) ====== */
.dash-bottom-row {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1.1fr;
  gap: var(--la-content-gap);
}
@media (max-width: 1180px) {
  .dash-bottom-row { grid-template-columns: 1fr 1fr; }
  .dash-bottom-row > .dash-card--activity { grid-column: 1 / -1; }
}
@media (max-width: 720px) {
  .dash-bottom-row { grid-template-columns: 1fr; }
  .dash-bottom-row > .dash-card--activity { grid-column: auto; }
}

/* Tabla compacta de productos · sin border global */
.dash-card--products .la-table-wrap { border: 0; background: transparent; backdrop-filter: none; }
.dash-card--products .la-table thead th { background: transparent; padding-top: 0; }
.dash-card--products .la-table thead th:first-child,
.dash-card--products .la-table tbody td:first-child { padding-left: 0; }
.dash-card--products .la-table thead th:last-child,
.dash-card--products .la-table tbody td:last-child { padding-right: 0; }
.dash-food {
  background: var(--la-glass-bg-hi) !important;
  font-size: 18px !important;
  border-color: var(--la-glass-divider) !important;
}

/* Banner de advertencia (124 productos sin stock) */
.dash-warn-banner {
  width: 100%;
  margin-top: var(--la-s-4);
  padding: var(--la-s-3) var(--la-s-4);
  display: flex;
  align-items: center;
  gap: var(--la-s-3);
  background: rgba(255, 109, 41, 0.06);
  border: 1px solid rgba(255, 109, 41, 0.22);
  border-radius: var(--la-r-md);
  text-align: left;
  color: var(--la-text-primary);
  cursor: pointer;
  transition:
    background var(--la-dur-base) var(--la-ease-out),
    border-color var(--la-dur-base) var(--la-ease-out),
    box-shadow var(--la-dur-base) var(--la-ease-out);
}
.dash-warn-banner:hover {
  background: rgba(255, 109, 41, 0.10);
  border-color: rgba(255, 109, 41, 0.38);
  box-shadow: var(--la-glow-accent-sm);
}
.dash-warn-banner__icon {
  width: 36px; height: 36px;
  display: grid; place-items: center;
  border-radius: var(--la-r-sm);
  color: var(--la-warning);
  background: rgba(232, 179, 65, 0.14);
  border: 1px solid rgba(232, 179, 65, 0.28);
  flex-shrink: 0;
}
.dash-warn-banner__icon svg { width: 18px; height: 18px; }
.dash-warn-banner__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}
.dash-warn-banner__title {
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-semibold);
  color: var(--la-text-primary);
}
.dash-warn-banner__msg {
  font-size: var(--la-fs-12);
  color: var(--la-text-secondary);
}
.dash-warn-banner__chev {
  width: 18px; height: 18px;
  color: var(--la-text-muted);
  flex-shrink: 0;
}

/* Actividad reciente · lista */
.dash-activity {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.dash-activity__row {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: var(--la-s-3);
  padding: var(--la-s-3) 0;
  border-bottom: 1px solid var(--la-glass-divider);
}
.dash-activity__row:last-child { border-bottom: 0; }
.dash-activity__icon {
  width: 36px;
  height: 36px;
  border-radius: var(--la-r-sm);
  display: grid;
  place-items: center;
  color: var(--la-text-secondary);
  background: var(--la-glass-bg-hi);
  border: 1px solid var(--la-glass-border);
}
.dash-activity__icon svg { width: 16px; height: 16px; }
.dash-activity__icon--accent {
  color: var(--la-accent);
  background: var(--la-accent-tint-12);
  border-color: rgba(255, 109, 41, 0.28);
}
.dash-activity__icon--danger {
  color: var(--la-danger);
  background: var(--la-danger-tint);
  border-color: rgba(229, 86, 74, 0.28);
}
.dash-activity__body { min-width: 0; }
.dash-activity__title {
  font-size: var(--la-fs-14);
  font-weight: var(--la-fw-medium);
  color: var(--la-text-primary);
  line-height: var(--la-lh-snug);
}
.dash-activity__sub {
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
  font-family: var(--la-font-mono);
  letter-spacing: 0.02em;
  margin-top: 2px;
}
.dash-activity__time {
  font-size: var(--la-fs-12);
  color: var(--la-text-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Ajuste de #pages cuando contiene dashboard (full-bleed visual) */
#page-dashboard {
  padding: 0;
}

/* ============================================================
   OVERRIDE GLOBAL · Sin sombras en cards
   ============================================================ */
.la-card,
.la-card.is-interactive:hover,
.la-card[data-interactive]:hover,
.la-kpi,
.la-kpi:hover,
.la-chart-card,
.dash-kpi,
.dash-kpi:hover,
.dash-card {
  box-shadow: none;
}

/* ────────────────────────────────────────────────────────────
   FIN PASO 8.1 · Dashboard
   ──────────────────────────────────────────────────────────── */
