    /* ============================================================
       FLUDE Design System — CSS Tokens & Base Styles
       Versión: 1.0 · Abril 2026
       ============================================================ */

    :root {
      color-scheme: dark;
      /* ── Brand ──────────────────────────────────────────────── */
      --brand:              #5B5CF6;
      --brand-light:        #7B7CF8;
      --brand-dim:          rgba(91, 92, 246, 0.15);

      /* ── Accent (CTA) ───────────────────────────────────────── */
      --accent:             #06CFC4;
      --accent-light:       #26EFE4;
      --accent-dim:         rgba(6, 207, 196, 0.15);

      /* ── Backgrounds (dark mode base) ──────────────────────── */
      --bg-base:            #080811;
      --bg-surface:         #0E0E1A;
      --bg-elevated:        #141424;
      --bg-card:            #191929;

      /* ── Borders ────────────────────────────────────────────── */
      --border:             #242438;
      --border-subtle:      #1B1B2E;

      /* ── Text ───────────────────────────────────────────────── */
      --text-primary:       #F0F0FA;
      --text-secondary:     #8A8AAA;
      --text-muted:         #7E7EA8;
      --text-disabled:      #35354F;

      /* ── Semantic ───────────────────────────────────────────── */
      --success:            #10B981;
      --success-dim:        rgba(16, 185, 129, 0.15);
      --success-tint:       rgba(16, 185, 129, 0.12);
      --success-ring:       rgba(16, 185, 129, 0.30);
      --warning:            #F59E0B;
      --warning-dim:        rgba(245, 158, 11, 0.15);
      --warning-tint:       rgba(245, 158, 11, 0.12);
      --warning-ring:       rgba(245, 158, 11, 0.30);
      --error:              #EF4444;
      --error-dim:          rgba(239, 68, 68, 0.15);
      --error-tint:         rgba(239, 68, 68, 0.12);
      --error-ring:         rgba(239, 68, 68, 0.30);
      --error-soft:         rgba(239, 68, 68, 0.38);
      --brand-tint:         rgba(91, 92, 246, 0.12);
      --brand-ring:         rgba(91, 92, 246, 0.30);

      /* ── Semantic aliases (FLU-1161: alinear con tokens/flude-tokens.css) ─── */
      --accent-success:     var(--success);
      --accent-warning:     var(--warning);
      --accent-danger:      var(--error);
      --accent-info:        var(--brand);

      /* ── Module colors ──────────────────────────────────────── */
      --module-gastos:          #5B5CF6;
      --module-flujos:          #9B6FF8;
      --module-ventas:          #06CFC4;
      --module-flota:           #F59E0B;
      --module-stock:           #10B981;
      --module-factura:         #EF4444;
      --module-compras:         #F97316;
      --module-compras-pagos:   #DC2626;
      --module-finanzas:        #8B5CF6;
      --module-proyectos:       #6366F1;
      --module-rrhh:            #EC4899;
      --module-finanzas-banco:  #0EA5E9;

      /* ── Typography ─────────────────────────────────────────── */
      --font-display:       'Plus Jakarta Sans', sans-serif;
      --font-body:          'Inter', sans-serif;

      --text-display:       72px;
      --text-h1:            48px;
      --text-h2:            36px;
      --text-h3:            24px;
      --text-h4-lg:         22px;
      --text-h4:            18px;
      --text-body-lg:       17px;
      --text-body:          15px;
      --text-sm:            14px;
      --text-caption:       13px;
      --text-label:         11px;

      --weight-extrabold:   800;
      --weight-bold:        700;
      --weight-semibold:    600;
      --weight-medium:      500;
      --weight-regular:     400;

      /* ── Spacing (base 4px) ─────────────────────────────────── */
      --space-1:            4px;
      --space-2:            8px;
      --space-3:            12px;
      --space-4:            16px;
      --space-5:            20px;
      --space-6:            24px;
      --space-8:            32px;
      --space-10:           40px;
      --space-12:           48px;
      --space-16:           64px;
      --space-20:           80px;
      --space-24:           96px;

      /* ── Border radius ──────────────────────────────────────── */
      --radius-xs:          4px;
      --radius-sm:          6px;
      --radius-md:          10px;
      --radius:             10px;
      --radius-lg:          16px;
      --radius-xl:          20px;
      --radius-full:        9999px;

      /* ── Shadows ────────────────────────────────────────────── */
      --shadow-sm:          0 1px 3px rgba(0,0,0,0.4), 0 1px 2px rgba(0,0,0,0.3);
      --shadow-md:          0 4px 12px rgba(0,0,0,0.4), 0 2px 4px rgba(0,0,0,0.2);
      --shadow-lg:          0 12px 32px rgba(0,0,0,0.5), 0 4px 8px rgba(0,0,0,0.2);
      --shadow-brand:       0 0 24px rgba(91,92,246,0.35);
      --shadow-xl:          0 40px 80px rgba(0,0,0,0.6);
      --shadow-2xl:         0 20px 50px rgba(0,0,0,0.5);

      /* ── Transitions ────────────────────────────────────────── */
      --transition-fast:    all 0.1s ease;
      --transition:         all 0.15s ease;
      --transition-slow:    all 0.25s ease;

      /* ── Z-index ────────────────────────────────────────────── */
      --z-sidebar:          50;
      --z-header:           100;
      --z-modal:            200;
      --z-toast:            300;
      --z-overlay:          400;
      --z-search:           500;

      /* ── Forms ──────────────────────────────────────────────── */
      --input-font-size:    16px;

      /* ── Layout mobile ──────────────────────────────────────── */
      --bottom-nav-clearance: 96px;
    }

    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    html, body {
      width: 100%;
      height: 100%;
      background-color: var(--bg-base);
      color: var(--text-primary);
      font-family: var(--font-body);
      font-size: var(--text-body);
      font-weight: var(--weight-regular);
      line-height: 1.6;
    }

    /* ============================================================
       LAYOUT PRINCIPAL
       ============================================================ */

    .app-container {
      display: flex;
      width: 100%;
      height: 100vh;
      overflow: hidden;
      flex-direction: column;
    }

    .home-header {
      height: 60px;
      background: rgba(8, 8, 17, 0.85);
      backdrop-filter: blur(20px);
      -webkit-backdrop-filter: blur(20px);
      border-bottom: 1px solid var(--border-subtle);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 var(--space-8);
      z-index: var(--z-header);
    }

    .header-logo {
      display: flex;
      align-items: center;
      gap: var(--space-3);
      cursor: pointer;
    }

    .header-logo svg {
      width: 28px;
      height: 28px;
    }

    .header-logo-text {
      font-family: var(--font-display);
      font-size: 18px;
      font-weight: var(--weight-extrabold);
      letter-spacing: -0.04em;
      background: linear-gradient(115deg, var(--brand) 0%, var(--accent) 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
    }

    .header-tenant {
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
      color: var(--text-primary);
      flex: 1;
      text-align: center;
    }

    .header-user {
      display: flex;
      align-items: center;
      gap: var(--space-3);
    }

    .home-content {
      flex: 1;
      background-color: var(--bg-base);
      overflow-y: auto;
      display: flex;
      flex-direction: column;
      align-items: center;
      padding: var(--space-12) var(--space-8);
      padding-bottom: var(--bottom-nav-clearance);
    }

    .home-welcome {
      text-align: left;
      margin-bottom: var(--space-4);
      display: flex;
      align-items: baseline;
      gap: var(--space-3);
      flex-wrap: wrap;
    }

    .home-title {
      font-family: var(--font-display);
      font-size: var(--text-h4-lg);
      font-weight: var(--weight-extrabold);
      color: var(--text-primary);
      margin-bottom: 0;
    }
    .home-subtitle { font-size: 13px; color: var(--text-secondary); }

    .modules-hub {
      display: grid;
      grid-template-columns: repeat(5, 1fr);
      gap: var(--space-8);
      width: 100%;
      max-width: 1100px;
    }

    .module-hub-card {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-top: 3px solid var(--brand);
      border-radius: var(--radius-lg);
      padding: var(--space-6);
      cursor: pointer;
      transition: all 0.2s ease;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      min-height: 180px;
      position: relative;
      text-align: center;
    }

    .module-hub-card:hover:not(.disabled) {
      transform: scale(1.03);
      border-color: var(--card-color, var(--brand));
      box-shadow: 0 8px 24px rgba(91, 92, 246, 0.2);
    }

    .module-hub-card.disabled {
      opacity: 0.55;
      cursor: pointer;
    }
    .module-hub-card.disabled:hover {
      transform: scale(1.03);
      opacity: 0.75;
    }

    .module-hub-card-upgrade {
      position: absolute;
      top: var(--space-3);
      right: var(--space-3);
      background-color: rgba(255,255,255,0.08);
      color: var(--text-secondary);
      font-size: 9px;
      font-weight: var(--weight-bold);
      padding: 2px 7px;
      border-radius: var(--radius-xs);
      text-transform: uppercase;
      letter-spacing: 0.04em;
    }

    .module-hub-icon {
      width: 32px;
      height: 32px;
      margin-bottom: var(--space-3);
    }

    /* Tile rico (Manual de Marca §08) — 56×56 con gradiente + border del color del módulo */
    .module-hub-icon-tile {
      width: 56px;
      height: 56px;
      border-radius: 14px;
      background: linear-gradient(135deg,
        color-mix(in srgb, var(--card-color, var(--brand)) 22%, transparent),
        color-mix(in srgb, var(--card-color, var(--brand)) 8%, transparent));
      border: 1px solid color-mix(in srgb, var(--card-color, var(--brand)) 28%, transparent);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      margin-bottom: var(--space-4);
    }
    .module-hub-icon-tile svg {
      width: 28px;
      height: 28px;
    }

    /* Eyebrow mono (Manual de Marca §07) — para títulos de sección dentro de módulos */
    .flude-eyebrow {
      font-family: 'JetBrains Mono', var(--font-mono, monospace);
      font-size: 11px;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.14em;
      color: var(--accent, #06CFC4);
      margin-bottom: 12px;
      display: inline-block;
    }

    .module-hub-name {
      font-size: 14px;
      font-weight: var(--weight-semibold);
      color: var(--text-primary);
      margin-bottom: var(--space-2);
    }

    .module-hub-metric {
      font-size: 12px;
      color: var(--text-muted);
    }

    /* ============================================================
       MODULE LAYER (OVERLAY)
       ============================================================ */

    .module-layer {
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-color: var(--bg-base);
      z-index: var(--z-modal);
      display: none;
      flex-direction: column;
      animation: moduleLayerEnter 0.2s ease forwards;
    }

    .module-layer.active {
      display: flex;
    }

    /* FLU-433: banner sat at the top historically; FLU-1602 moved it to
       bottom-fixed, so module-layer no longer needs a top offset for it. */

    @keyframes moduleLayerEnter {
      from {
        transform: translateY(20px);
        opacity: 0;
      }
      to {
        transform: translateY(0);
        opacity: 1;
      }
    }

    .module-layer.exiting {
      animation: moduleLayerExit 0.15s ease forwards;
    }

    @keyframes moduleLayerExit {
      from {
        transform: translateY(0);
        opacity: 1;
      }
      to {
        transform: translateY(20px);
        opacity: 0;
      }
    }

    .module-header {
      height: 52px;
      background-color: var(--bg-surface);
      border-bottom: 1px solid var(--border);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0 var(--space-8);
    }

    /* FLU-1654: hide the duplicate user-menu+settings chrome inside module-header.
       The DOM is kept (openModule() still writes to moduleHeaderUserAvatar /
       moduleHeaderUserName / iaCreditsPanelMod by id) but it's visually removed
       so we don't render a second avatar/gear stacked under the home-header copy. */
    .header-user-module-dup { display: none !important; }

    .module-header-left {
      display: flex;
      align-items: center;
      gap: var(--space-6);
    }

    .btn-back {
      background: transparent;
      border: 1px solid var(--border);
      color: var(--text-secondary);
      cursor: pointer;
      padding: var(--space-2) var(--space-3);
      border-radius: var(--radius-xs);
      font-size: var(--text-caption);
      transition: var(--transition);
      font-family: var(--font-body);
    }

    .btn-back:hover {
      border-color: var(--text-primary);
      color: var(--text-primary);
    }

    .module-header-title {
      display: flex;
      align-items: center;
      gap: var(--space-3);
    }

    .module-header-icon {
      width: 20px;
      height: 20px;
      stroke-width: 1.6;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .module-header-name {
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
    }

    /* ============================================================
       GLOSARIO TOOLTIP (FLU-1098)
       ============================================================ */
    .module-glosario-trigger {
      width: 18px;
      height: 18px;
      padding: 0;
      border-radius: 50%;
      border: 1px solid var(--border);
      background: transparent;
      color: var(--text-muted);
      font-family: var(--font-body);
      font-size: 11px;
      font-weight: 700;
      line-height: 1;
      cursor: pointer;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      transition: var(--transition);
      flex-shrink: 0;
    }
    .module-glosario-trigger:hover {
      color: var(--text-primary);
      border-color: var(--text-primary);
    }
    .module-glosario-trigger:focus-visible {
      color: var(--text-primary);
      border-color: var(--brand);
      outline: none;
      box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4);
    }
    .module-glosario-trigger[aria-expanded="true"] {
      color: var(--text-primary);
      border-color: var(--brand);
      background: color-mix(in srgb, var(--brand) 12%, transparent);
    }
    .module-glosario-trigger[hidden] { display: none; }

    .module-glosario-popover {
      position: fixed;
      z-index: 9000;
      width: 320px;
      max-width: calc(100vw - 24px);
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: 12px;
      box-shadow: 0 16px 48px rgba(0,0,0,0.45);
      padding: 14px 16px 12px;
      font-family: var(--font-body);
      color: var(--text-primary);
    }
    .module-glosario-popover[hidden] { display: none; }
    .module-glosario-title {
      margin: 0 0 10px;
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.06em;
      color: var(--text-muted);
    }
    .module-glosario-list {
      list-style: none;
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: column;
      gap: 9px;
    }
    .module-glosario-list li {
      font-size: 12px;
      line-height: 1.45;
      color: var(--text-secondary);
    }
    .module-glosario-list dt {
      color: var(--text-primary);
      font-weight: 600;
      font-variant: small-caps;
      letter-spacing: 0.01em;
      display: inline;
      margin-right: 4px;
    }
    .module-glosario-list dt::after { content: " · "; color: var(--text-muted); font-weight: 400; }
    .module-glosario-list dd { display: inline; margin: 0; }

    .module-glosario-sheet-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.5);
      z-index: 8999;
    }
    .module-glosario-sheet-backdrop[hidden] { display: none; }

    @media (max-width: 600px) {
      .module-glosario-popover {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        top: auto;
        width: 100%;
        max-width: 100%;
        max-height: 70vh;
        overflow-y: auto;
        border-radius: 16px 16px 0 0;
        padding: 18px 18px calc(18px + env(safe-area-inset-bottom, 0px));
        animation: glosarioSheetIn 180ms ease-out;
      }
      .module-glosario-popover::before {
        content: "";
        display: block;
        width: 36px;
        height: 4px;
        border-radius: 2px;
        background: var(--border);
        margin: 0 auto 12px;
      }
    }
    @keyframes glosarioSheetIn {
      from { transform: translateY(100%); }
      to { transform: translateY(0); }
    }

    .module-content {
      flex: 1;
      background-color: var(--bg-base);
      overflow-y: auto;
      padding: var(--space-8);
    }

    .module-content.internal-layout {
      overflow: hidden;
      padding: 0;
    }

    .module-content.landing-layout {
      overflow: auto;
      padding: 0;
    }


    /* ============================================================
       HEADER
       ============================================================ */

    .header-left {
      display: flex;
      align-items: center;
      gap: var(--space-4);
    }

    .header-module-icon {
      width: 20px;
      height: 20px;
      stroke-width: 1.6;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .header-module-name {
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
    }

    .header-right {
      display: flex;
      align-items: center;
      gap: var(--space-6);
    }

    .search-bar {
      background-color: var(--bg-elevated);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: var(--space-2) var(--space-4);
      color: var(--text-secondary);
      font-size: var(--text-body);
      width: 200px;
      transition: var(--transition);
    }

    .search-bar:focus {
      border-color: var(--brand);
      color: var(--text-primary);
      outline: none;
    }
    .search-bar:focus-visible {
      outline: 2px solid var(--accent, #06CFC4);
      outline-offset: 2px;
    }

    .search-bar::placeholder {
      color: var(--text-muted);
    }

    .header-icon-btn {
      width: 44px;
      height: 44px;
      border: 1px solid transparent;
      background: transparent;
      border-radius: var(--radius-sm);
      cursor: pointer;
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
      transition: var(--transition);
      color: var(--text-secondary);
    }

    .header-icon-btn:hover {
      border-color: var(--border);
      color: var(--text-primary);
    }

    .header-icon-btn svg {
      width: 18px;
      height: 18px;
      stroke-width: 1.6;
      stroke-linecap: round;
      stroke-linejoin: round;
    }

    .notification-dot {
      position: absolute;
      top: 4px;
      right: 4px;
      width: 6px;
      height: 6px;
      background-color: var(--error);
      border-radius: 50%;
    }

    /* ============================================================
       CONTENEDOR MODAL ONBOARDING
       ============================================================ */

    /* ─── Onboarding full-screen ─── */
    .onboarding-overlay {
      position: fixed;
      top: 0; left: 0; right: 0; bottom: 0;
      background: #07070F;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: flex-start;
      overflow-y: auto;
      overscroll-behavior: contain;
      -webkit-overflow-scrolling: touch;
      padding: max(20px, env(safe-area-inset-top, 0px)) 24px max(28px, env(safe-area-inset-bottom, 0px));
      z-index: var(--z-modal);
      /* Forzar paleta oscura dentro del onboarding, incluso si el tema activo es light.
         El fondo es hardcoded dark (#07070F) así que los textos deben contrastar en claro. */
      --bg-base:        #07070F;
      --bg-surface:     #0E0E1A;
      --bg-elevated:    #141424;
      --bg-card:        #191929;
      --border:         rgba(255,255,255,0.12);
      --border-subtle:  rgba(255,255,255,0.06);
      --text-primary:   #F0F0FA;
      --text-secondary: rgba(255,255,255,0.72);
      --text-muted:     rgba(255,255,255,0.45);
      --text-disabled:  rgba(255,255,255,0.25);
      color: #F0F0FA;
    }

    .onboarding-glow {
      position: absolute;
      top: 0; left: 50%;
      transform: translateX(-50%);
      width: 600px; height: 400px;
      background: radial-gradient(ellipse at center, rgba(91,92,246,0.13) 0%, transparent 70%);
      pointer-events: none;
      z-index: 0;
    }

    .onboarding-stepper {
      position: relative; z-index: 1;
      display: flex; align-items: flex-start; gap: 0;
      justify-content: center;
      width: 100%;
      max-width: 500px;
      padding: 16px 0 0; margin-bottom: 20px;
    }

    .onboarding-stepper-item { display: flex; align-items: center; }

    .onboarding-stepper-dot-wrap {
      display: flex; flex-direction: column; align-items: center; gap: 8px; cursor: default;
    }

    .onboarding-stepper-dot {
      width: 28px; height: 28px; border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 12px; font-weight: 700; transition: all 0.2s;
    }
    .onboarding-stepper-dot.s-done  { background: var(--success); color: #fff; }
    .onboarding-stepper-dot.s-active { background: var(--brand); color: #fff; border: 2px solid rgba(91,92,246,0.45); }
    .onboarding-stepper-dot.s-pending { background: rgba(255,255,255,0.08); color: var(--text-muted); }

    .onboarding-stepper-label {
      font-size: 11px; font-family: var(--font-body); white-space: nowrap;
    }
    .onboarding-stepper-label.s-active  { color: var(--text-primary); font-weight: 600; }
    .onboarding-stepper-label.s-done,
    .onboarding-stepper-label.s-pending { color: var(--text-muted); font-weight: 400; }

    .onboarding-stepper-line {
      width: 80px; height: 1px; margin: 0 8px; margin-bottom: 24px; flex-shrink: 0;
    }
    .onboarding-stepper-line.s-done    { background: rgba(16,185,129,0.5); }
    .onboarding-stepper-line.s-pending { background: rgba(255,255,255,0.08); }

    .onboarding-modal {
      position: relative; z-index: 1;
      width: 100%; max-width: 500px;
      padding: 0 24px 48px;
      transition: max-width 0.2s ease;
    }
    .onboarding-modal.wide { max-width: 820px; }

    .onboarding-step-card {
      background: rgba(255,255,255,0.03);
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: 16px; padding: 20px; margin-bottom: 16px;
    }
    .onboarding-step-card .form-group { margin-bottom: 14px; }

    .onboarding-step { display: none; animation: fadeInUp 0.3s ease; }
    .onboarding-step.active { display: block; }

    /* ── Wizard A/B/C route cards ── */
    .wizard-route-cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 24px; }
    .wizard-route-card {
      background: rgba(255,255,255,0.03);
      border: 1.5px solid rgba(255,255,255,0.08);
      border-radius: 12px; padding: 18px 14px;
      cursor: pointer; transition: all 0.15s ease;
      text-align: center; display: flex; flex-direction: column; align-items: center; gap: 10px;
    }
    .wizard-route-card:hover { border-color: var(--brand); background: rgba(91,92,246,0.06); }
    .wizard-route-card.selected { border-color: var(--brand); background: rgba(91,92,246,0.1); box-shadow: 0 0 0 3px rgba(91,92,246,0.15); }
    .wizard-route-icon { width: 44px; height: 44px; border-radius: 12px; display: flex; align-items: center; justify-content: center; }
    .wizard-route-label { font-size: 13px; font-weight: 600; color: var(--text-primary,#F0F0FA); line-height: 1.3; }
    .wizard-route-sub { font-size: 11px; color: rgba(240,240,250,0.38); line-height: 1.4; }
    /* ── Wizard entity grid ── */
    .wizard-entity-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 20px; }
    .wizard-entity-card {
      background: rgba(255,255,255,0.03); border: 1.5px solid rgba(255,255,255,0.08);
      border-radius: 12px; padding: 14px; cursor: pointer; transition: all 0.15s ease;
    }
    .wizard-entity-card:hover { border-color: rgba(255,255,255,0.14); }
    .wizard-entity-card.selected { border-color: var(--brand); background: rgba(91,92,246,0.08); }
    .wizard-entity-name { font-size: 13px; font-weight: 600; color: var(--text-primary,#F0F0FA); margin-bottom: 2px; }
    .wizard-entity-meta { font-size: 11px; color: rgba(240,240,250,0.38); display: flex; align-items: center; gap: 5px; }
    /* ── Wizard upload zone ── */
    .wizard-upload-zone {
      border: 1.5px dashed rgba(255,255,255,0.14); border-radius: 12px;
      padding: 28px; text-align: center; cursor: pointer; transition: all 0.15s ease; margin-top: 8px; position: relative;
    }
    .wizard-upload-zone:hover { border-color: var(--brand); background: rgba(91,92,246,0.04); }
    .wizard-upload-zone input[type=file] { position: absolute; inset: 0; opacity: 0; cursor: pointer; }
    /* ── Wizard progress ── */
    .wizard-progress-wrap { background: rgba(255,255,255,0.06); border-radius: 100px; height: 6px; overflow: hidden; margin-bottom: 6px; }
    .wizard-progress-bar { height: 100%; border-radius: 100px; transition: width 0.5s ease; }
    .wizard-progress-label { font-size: 11px; color: rgba(240,240,250,0.38); display: flex; justify-content: space-between; margin-bottom: 14px; }
    /* ── Wizard error table ── */
    .wizard-error-table { border: 1px solid rgba(239,68,68,0.25); border-radius: 12px; overflow: hidden; margin-bottom: 14px; }
    .wizard-error-header { display: grid; grid-template-columns: 48px 1fr 160px 72px; padding: 8px 12px; background: rgba(239,68,68,0.08); font-size: 11px; font-weight: 700; color: rgba(240,240,250,0.38); text-transform: uppercase; letter-spacing: 0.07em; }
    .wizard-error-row { display: grid; grid-template-columns: 48px 1fr 160px 72px; padding: 10px 12px; border-top: 1px solid rgba(255,255,255,0.04); font-size: 12px; align-items: center; }
    .wizard-error-fix { padding: 4px 8px; background: rgba(91,92,246,0.1); border: 1px solid rgba(91,92,246,0.25); border-radius: 6px; font-size: 11px; font-weight: 600; color: #8B8CF8; cursor: pointer; text-align: center; transition: all 0.15s ease; }
    .wizard-error-fix:hover { background: rgba(91,92,246,0.2); }
    /* ── Wizard permissive toggle ── */
    .wizard-permissive { background: rgba(245,158,11,0.06); border: 1px solid rgba(245,158,11,0.2); border-radius: 12px; padding: 12px 14px; display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 16px; }
    .wizard-toggle-sw { width: 36px; height: 20px; border-radius: 100px; background: rgba(255,255,255,0.1); position: relative; cursor: pointer; transition: all 0.15s ease; flex-shrink: 0; }
    .wizard-toggle-sw.on { background: #F59E0B; }
    .wizard-toggle-knob { position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%; background: white; transition: all 0.15s ease; }
    .wizard-toggle-sw.on .wizard-toggle-knob { left: 18px; }
    /* ── Wizard import stats ── */
    .wizard-import-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-bottom: 20px; }
    .wizard-import-stat { background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.08); border-radius: 12px; padding: 12px; text-align: center; }
    .wizard-import-stat-value { font-size: 22px; font-weight: 800; color: var(--text-primary,#F0F0FA); }
    .wizard-import-stat-label { font-size: 11px; color: rgba(240,240,250,0.38); margin-top: 2px; }
    /* ── Responsive wizard ── */
    @media (max-width: 600px) {
      .wizard-route-cards { grid-template-columns: 1fr; }
      .wizard-entity-grid { grid-template-columns: 1fr; }
      .wizard-error-header, .wizard-error-row { grid-template-columns: 40px 1fr 100px; }
      .wizard-error-row .wizard-error-fix-col { display: none; }
    }

    @keyframes fadeInUp {
      from { opacity: 0; transform: translateY(10px); }
      to   { opacity: 1; transform: translateY(0); }
    }

    /* ============================================================
       BOTONES
       ============================================================ */

    .btn {
      padding: 9px 18px;
      min-height: 44px;
      border-radius: var(--radius-sm);
      font-size: var(--text-label);
      font-weight: var(--weight-semibold);
      border: none;
      cursor: pointer;
      transition: var(--transition);
      font-family: var(--font-body);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      gap: var(--space-2);
      white-space: nowrap;
    }

    .btn-primary,
    .btn-brand {
      background-color: var(--brand);
      color: white;
    }

    .btn-primary:hover,
    .btn-brand:hover {
      background-color: var(--brand-light);
      transform: translateY(-1px);
      box-shadow: var(--shadow-brand, 0 0 24px rgba(91, 92, 246, 0.35));
    }

    .btn-primary.accent,
    .btn-accent {
      background-color: var(--accent);
      color: #07070F;
      box-shadow: 0 0 30px rgba(6, 207, 196, 0.4);
    }

    .btn-primary.accent:hover,
    .btn-accent:hover {
      background-color: var(--accent-light);
      transform: translateY(-1px);
    }

    .btn-outline {
      background-color: var(--bg-elevated);
      border: 1px solid var(--border);
      color: var(--text-secondary);
    }

    .btn-outline:hover {
      border-color: var(--text-primary);
      color: var(--text-primary);
    }

    .btn-ghost {
      background-color: transparent;
      border: 1px solid var(--border);
      color: var(--text-secondary);
    }

    .btn-ghost:hover {
      border-color: var(--text-primary);
      color: var(--text-primary);
    }

    .btn:disabled {
      opacity: 0.5;
      cursor: not-allowed;
    }

    /* ============================================================
       INPUTS Y FORMS
       ============================================================ */

    .form-group {
      margin-bottom: var(--space-6);
    }

    .form-label {
      display: block;
      font-size: var(--text-label);
      font-weight: var(--weight-semibold);
      color: var(--text-primary);
      margin-bottom: var(--space-2);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    .form-input, .form-select {
      width: 100%;
      background-color: var(--bg-elevated);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 9px 12px;
      font-size: var(--input-font-size);
      color: var(--text-primary);
      font-family: var(--font-body);
      transition: var(--transition);
    }

    .form-input:focus, .form-select:focus {
      border-color: var(--brand);
      outline: none;
    }
    .form-input:focus-visible, .form-select:focus-visible {
      outline: 2px solid var(--accent, #06CFC4);
      outline-offset: 2px;
    }

    .form-input::placeholder {
      color: var(--text-muted);
    }

    .form-select {
      cursor: pointer;
    }

    .form-select option {
      background-color: var(--bg-elevated);
      color: var(--text-primary);
    }

    /* ============================================================
       BADGE / STATUS
       ============================================================ */

    .badge {
      display: inline-block;
      border-radius: var(--radius);
      padding: 3px 8px;
      font-size: 10px;
      font-weight: var(--weight-semibold);
      text-transform: capitalize;
    }

    .badge-pendiente {
      background-color: var(--warning-dim);
      color: var(--warning);
    }

    .badge-aprobado, .badge-activo, .badge-cobrada, .badge-recibida {
      background-color: var(--success-dim);
      color: var(--success);
    }

    .badge-urgente, .badge-vencida, .badge-caliente {
      background-color: var(--error-dim);
      color: var(--error);
    }

    .badge-aprobada {
      background-color: var(--brand-dim);
      color: var(--brand-light);
    }

    .badge-tibia {
      background-color: var(--warning-dim);
      color: var(--warning);
    }

    .badge-taller {
      background-color: var(--warning-dim);
      color: var(--warning);
    }

    /* ============================================================
       CARD MÉTRICA
       ============================================================ */

    .metric-cards {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
      gap: var(--space-6);
      margin-bottom: var(--space-12);
    }

    .metric-card {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-top: 2px solid var(--module-color, var(--brand));
      border-radius: 12px;
      padding: 18px 20px;
    }

    .metric-label {
      font-size: 12px;
      color: var(--text-muted);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      font-weight: var(--weight-semibold);
      margin-bottom: var(--space-2);
    }

    .metric-value {
      font-family: var(--font-display);
      font-size: 22px;
      font-weight: var(--weight-extrabold);
      color: var(--text-primary);
      margin-bottom: var(--space-1);
    }

    .metric-unit {
      font-size: var(--text-caption);
      color: var(--text-secondary);
    }

    .metric-delta {
      display: flex;
      align-items: center;
      gap: var(--space-1);
      font-size: 12px;
      font-weight: var(--weight-semibold);
      margin-top: var(--space-2);
    }

    .metric-delta.positive {
      color: var(--success);
    }

    .metric-delta.negative {
      color: var(--error);
    }

    /* ============================================================
       TABLA
       ============================================================ */

    .data-table {
      width: 100%;
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      border-collapse: collapse;
    }

    .data-table thead {
      background-color: var(--bg-elevated);
    }

    .data-table thead th {
      padding: 13px 20px;
      text-align: left;
      font-size: var(--text-label);
      font-weight: var(--weight-semibold);
      color: var(--text-muted);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      border-bottom: 1px solid var(--border-subtle);
    }

    .data-table tbody tr {
      border-bottom: 1px solid var(--border-subtle);
      transition: var(--transition);
    }

    .data-table tbody tr:hover {
      background-color: rgba(255, 255, 255, 0.02);
    }

    .data-table tbody td {
      padding: 13px 20px;
      font-size: var(--text-body);
      color: var(--text-primary);
    }

    .data-table tbody tr:last-child {
      border-bottom: none;
    }

    /* ============================================================
       KANBAN
       ============================================================ */

    .kanban-container {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--space-4);
      margin-bottom: var(--space-8);
    }
    @media(max-width:480px) {
      .kanban-container { grid-template-columns: 1fr; }
      #fvKanban { flex-direction: column !important; overflow-x: visible !important; padding-left: 16px !important; padding-right: 16px !important; }
      #fvKanban > div { min-width: 0 !important; max-width: 100% !important; margin-right: 0 !important; margin-bottom: 10px; }
    }

    .kanban-column {
      background-color: var(--bg-elevated);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-3);
      min-height: 120px;
    }

    .kanban-column-title {
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
      color: var(--text-primary);
      margin-bottom: var(--space-3);
      padding-bottom: var(--space-2);
      border-bottom: 1px solid var(--border);
    }

    .kanban-column-count {
      font-size: var(--text-label);
      color: var(--text-muted);
      margin-left: var(--space-2);
    }

    .kanban-items {
      display: flex;
      flex-direction: column;
      gap: var(--space-2);
      min-height: 0;
    }

    .kanban-card {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: 8px 10px;
      cursor: grab;
      transition: var(--transition);
    }

    .kanban-card:hover {
      border-color: var(--brand);
    }

    .kanban-card.dragging {
      opacity: 0.5;
    }

    .kanban-card-title {
      font-size: var(--text-caption);
      font-weight: var(--weight-semibold);
      color: var(--text-primary);
      margin-bottom: var(--space-2);
    }

    .kanban-card-meta {
      display: flex;
      justify-content: space-between;
      align-items: center;
      font-size: 12px;
      color: var(--text-muted);
      margin-bottom: var(--space-2);
    }

    .kanban-card-badge {
      align-self: flex-start;
    }

    .probability-bar {
      height: 3px;
      background-color: var(--bg-elevated);
      border-radius: 2px;
      overflow: hidden;
      margin-top: var(--space-2);
    }

    .probability-fill {
      height: 100%;
      background-color: var(--brand);
    }

    /* ============================================================
       CHART MINIGRÁFICO LÍNEA
       ============================================================ */

    .chart-container {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-6);
      margin-bottom: var(--space-12);
    }

    .chart-title {
      font-size: var(--text-h4);
      font-weight: var(--weight-bold);
      color: var(--text-primary);
      margin-bottom: var(--space-4);
    }

    /* ============================================================
       MÓDULO LAYOUT INTERNO (Flujos y otros)
       ============================================================ */

    .module-layout {
      display: flex;
      height: 100%;
      gap: 0;
    }

    .module-sidebar {
      width: 220px;
      background-color: var(--bg-surface);
      border-right: 1px solid var(--border);
      padding: var(--space-6) var(--space-4);
      overflow-y: auto;
      display: flex;
      flex-direction: column;
    }

    .module-sidebar-header {
      display: flex;
      align-items: center;
      gap: var(--space-3);
      margin-bottom: var(--space-8);
      padding-bottom: var(--space-4);
      border-bottom: 1px solid var(--border);
    }

    .module-sidebar-icon {
      width: 24px;
      height: 24px;
      flex-shrink: 0;
    }

    .module-sidebar-title {
      font-size: var(--text-body);
      font-weight: var(--weight-bold);
      color: var(--text-primary);
    }

    .module-sidebar-nav {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: var(--space-2);
      margin-bottom: var(--space-8);
    }

    .module-nav-item {
      display: flex;
      align-items: center;
      gap: var(--space-3);
      padding: var(--space-3) var(--space-3);
      border-radius: var(--radius-sm);
      cursor: pointer;
      transition: var(--transition);
      color: var(--text-secondary);
      user-select: none;
      background: transparent;
      border: 0;
      border-left: 2px solid transparent;
      font-family: inherit;
      position: relative;
    }

    .module-nav-item:hover:not(.disabled) {
      color: var(--text-primary);
      background-color: rgba(255, 255, 255, 0.03);
    }

    .module-nav-item.active {
      color: var(--module-color, var(--brand));
      background-color: color-mix(in srgb, var(--module-color, var(--brand)) 10%, transparent);
      border-left-color: var(--module-color, var(--brand));
    }

    .module-nav-item.disabled {
      opacity: 0.4;
      cursor: not-allowed;
    }

    .module-nav-item svg {
      width: 18px;
      height: 18px;
      stroke-width: 1.6;
      stroke-linecap: round;
      stroke-linejoin: round;
      flex-shrink: 0;
    }

    .module-nav-label {
      font-size: var(--text-body);
      font-weight: var(--weight-medium);
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .module-sidebar-badge {
      margin-top: auto;
      padding-top: var(--space-4);
      border-top: 1px solid var(--border);
    }

    .module-role-badge {
      display: inline-block;
      background-color: var(--bg-elevated);
      border: 1px solid var(--border);
      border-radius: var(--radius-sm);
      padding: var(--space-2) var(--space-3);
      font-size: var(--text-label);
      color: var(--text-secondary);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      font-weight: var(--weight-semibold);
    }

    .module-content-area {
      flex: 1;
      min-height: 0;
      min-width: 0;
      overflow-y: auto;
      overflow-x: hidden;
      padding: var(--space-8);
      background-color: var(--bg-base);
    }

    .module-content-section {
      display: none;
    }

    .module-content-section.active {
      display: block;
      animation: fadeIn 0.2s ease;
    }

    /* ── Heading principal dentro de módulos (FLU-573 UI-06) ── */
    .module-section-title {
      font-family: var(--font-display);
      font-size: 20px;
      font-weight: 800;
      color: var(--text-primary);
      letter-spacing: -0.02em;
      line-height: 1.1;
    }

    /* ============================================================
       FORMULARIOS EN MÓDULOS
       ============================================================ */

    .form-card {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-8);
      max-width: 560px;
      margin: 0 auto;
    }

    .form-row {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: var(--space-6);
    }

    .form-row.full {
      grid-template-columns: 1fr;
    }

    .form-section-title {
      font-size: var(--text-h4);
      font-weight: var(--weight-bold);
      color: var(--text-primary);
      margin-bottom: var(--space-6);
      margin-top: var(--space-8);
    }

    .form-section-title:first-child {
      margin-top: 0;
    }

    .pill-selector {
      display: flex;
      gap: var(--space-3);
    }

    .pill-btn {
      padding: var(--space-3) var(--space-6);
      border-radius: var(--radius-full);
      border: 1px solid var(--border);
      background-color: var(--bg-elevated);
      color: var(--text-secondary);
      cursor: pointer;
      transition: var(--transition);
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
      user-select: none;
    }

    .pill-btn:hover {
      border-color: var(--text-primary);
      color: var(--text-primary);
    }

    .pill-btn.active {
      background-color: var(--module-color, var(--brand));
      border-color: var(--module-color, var(--brand));
      color: white;
    }

    .file-input-wrapper {
      position: relative;
      border: 2px dashed var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-8);
      text-align: center;
      cursor: pointer;
      transition: var(--transition);
      background-color: rgba(255, 255, 255, 0.02);
    }

    .file-input-wrapper:hover {
      border-color: var(--module-color, var(--brand));
      background-color: color-mix(in srgb, var(--module-color, var(--brand)) 5%, transparent);
    }

    .file-input-wrapper input {
      display: none;
    }

    .file-input-label {
      font-size: var(--text-body);
      color: var(--text-secondary);
      margin-bottom: var(--space-2);
    }

    /* ============================================================
       TABS / PILLS FILTROS
       ============================================================ */

    .filter-pills {
      display: flex;
      gap: var(--space-3);
      margin-bottom: var(--space-6);
      flex-wrap: wrap;
    }

    .filter-pill {
      padding: var(--space-2) var(--space-4);
      min-height: 44px;
      border-radius: var(--radius-full);
      border: 1px solid var(--border);
      background-color: transparent;
      color: var(--text-secondary);
      cursor: pointer;
      transition: var(--transition);
      font-size: var(--text-body);
      font-weight: var(--weight-medium);
      user-select: none;
    }

    .filter-pill:hover {
      border-color: var(--text-primary);
      color: var(--text-primary);
    }

    .filter-pill.active {
      background-color: var(--module-color, var(--brand));
      border-color: var(--module-color, var(--brand));
      color: white;
    }

    /* ============================================================
       MODAL / DIALOG
       ============================================================ */

    .modal-overlay {
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      bottom: 0;
      background-color: rgba(0, 0, 0, 0.6);
      display: none;
      align-items: flex-start;
      justify-content: center;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      padding: max(16px, env(safe-area-inset-top, 0px)) 16px max(16px, env(safe-area-inset-bottom, 0px));
      z-index: var(--z-modal);
    }

    .modal-overlay.active {
      display: flex;
    }

    .modal-content {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: var(--space-8);
      max-width: 600px;
      width: min(600px, 100%);
      max-height: min(90vh, calc(100dvh - 32px));
      overflow-y: auto;
      margin: auto 0;
      flex-shrink: 0;
      animation: modalSlideIn 0.2s ease;
    }

    @keyframes modalSlideIn {
      from {
        transform: translateY(20px);
        opacity: 0;
      }
      to {
        transform: translateY(0);
        opacity: 1;
      }
    }

    /* ============================================================
       TOAST NOTIFICATIONS
       ============================================================ */

    .toast-container {
      position: fixed;
      bottom: max(var(--space-6), env(safe-area-inset-bottom, 0px));
      right: var(--space-6);
      z-index: var(--z-toast);
      display: flex;
      flex-direction: column;
      gap: var(--space-3);
    }

    /* Banner global offline/online (TANDA 2) */
    .flude-net-banner {
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      z-index: 10000;
      display: none;
      align-items: center;
      justify-content: center;
      gap: var(--space-2);
      padding: 10px var(--space-4);
      font-family: var(--font-body);
      font-size: 13px;
      font-weight: 600;
      text-align: center;
      text-wrap: pretty;
      transform: translateY(100%);
      transition: transform 0.25s ease;
    }
    .flude-net-banner.show { display: flex; transform: translateY(0); }
    .flude-net-banner.offline { background: var(--warning, #F59E0B); color: #1a1205; }
    .flude-net-banner.online { background: var(--success, #10B981); color: #04140c; }
    @media (prefers-reduced-motion: reduce) { .flude-net-banner { transition: none; } }

    .toast {
      background-color: var(--bg-card);
      border: 1px solid var(--border);
      border-left: 3px solid var(--module-color, var(--brand));
      border-radius: var(--radius-lg);
      padding: var(--space-4) var(--space-6);
      min-width: 300px;
      animation: slideInUp 0.3s ease;
    }

    .toast.success {
      border-left-color: var(--success);
    }

    .toast.error {
      border-left-color: var(--error);
    }

    .toast.warning {
      border-left-color: var(--warning);
    }

    /* FLU-1067: persistent error toast with detail + retry action */
    .toast.persistent {
      min-width: 340px;
      max-width: 420px;
      padding: var(--space-4) var(--space-5);
      display: flex;
      flex-direction: column;
      gap: 8px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.32);
    }
    .toast.persistent .toast-message {
      font-size: 13px;
      line-height: 1.45;
      color: var(--text-primary);
    }
    .toast.persistent .toast-detail {
      font-size: 11px;
      color: var(--text-muted);
      max-height: 96px;
      overflow-y: auto;
      white-space: pre-wrap;
      font-family: var(--font-mono, monospace);
      padding: 6px 8px;
      background: var(--bg-elevated);
      border-radius: 6px;
      border: 1px solid var(--border);
    }
    .toast.persistent .toast-actions {
      display: flex;
      gap: 8px;
      justify-content: flex-end;
    }
    .toast.persistent .toast-btn {
      padding: 6px 12px;
      border-radius: 6px;
      border: 1px solid var(--border);
      background: transparent;
      color: var(--text-secondary);
      font-family: var(--font-body);
      font-size: 12px;
      font-weight: 600;
      cursor: pointer;
    }
    .toast.persistent .toast-btn.primary {
      border-color: var(--error);
      background: rgba(239,68,68,0.12);
      color: var(--error);
    }
    .toast.persistent .toast-btn:hover { filter: brightness(1.15); }

    @keyframes slideInUp {
      from {
        transform: translateY(20px);
        opacity: 0;
      }
      to {
        transform: translateY(0);
        opacity: 1;
      }
    }

    @keyframes fluidProgress {
      0%   { left: -50%; width: 50%; }
      50%  { left: 25%; width: 60%; }
      100% { left: 110%; width: 50%; }
    }

    /* ============================================================
       GRID DE MÓDULOS (ONBOARDING)
       ============================================================ */

    .modules-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 8px;
      margin-bottom: var(--space-6);
    }
    .modules-grid .module-card-detail { display: none; }

    .module-card {
      display: flex; flex-direction: column; align-items: stretch; gap: 8px;
      padding: 11px;
      background: rgba(255,255,255,0.02);
      border: 1px solid rgba(255,255,255,0.08);
      border-radius: 12px;
      cursor: pointer;
      transition: all 0.2s;
      text-align: left;
      min-height: 100%;
    }

    .module-card:hover:not(.unavailable) {
      transform: none;
    }

    .module-card.selected {
      border-color: var(--card-sel-color, var(--brand));
      background: var(--card-sel-bg, rgba(91,92,246,0.12));
    }

    .module-card.unavailable {
      opacity: 0.45;
      cursor: not-allowed;
    }

    .module-card-icon-box {
      width: 38px; height: 38px; border-radius: 10px;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; transition: all 0.2s;
    }
    .module-card-head {
      display: flex;
      align-items: flex-start;
      gap: 12px;
    }
    .module-card-icon-box svg {
      width: 20px; height: 20px;
      stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
    }
    .module-hub-icon svg {
      width: 32px; height: 32px;
      stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round;
    }
    /* Íconos en el resumen del step 4 */
    #onboardingModulesList svg {
      width: 14px; height: 14px;
      stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round;
    }

    .module-card-info { flex: 1; min-width: 0; }

    .module-name {
      font-family: var(--font-display);
      font-size: 14px;
      font-weight: var(--weight-semibold);
      color: var(--text-secondary);
      line-height: 1.25;
    }
    .module-card.selected .module-name { color: var(--text-primary); }

    .module-badge {
      font-size: 11px;
      color: var(--text-muted);
      margin-top: 2px;
      line-height: 1.4;
      font-style: normal;
    }
    .module-card-detail {
      font-size: 11px;
      color: var(--text-muted);
      line-height: 1.4;
      margin-top: 4px;
    }
    .module-card-tags {
      display: flex;
      flex-wrap: wrap;
      gap: 6px;
      margin-top: 8px;
    }
    .module-card-tag {
      font-size: 9px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.05em;
      padding: 2px 7px;
      border-radius: 100px;
      display: inline-flex;
      align-items: center;
    }

    .module-card-toggle {
      width: 20px; height: 20px; border-radius: 50%;
      border: 2px solid rgba(255,255,255,0.15);
      background: transparent;
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0; transition: all 0.2s;
      font-size: 11px; font-weight: 700; color: #fff;
    }
    .module-card.selected .module-card-toggle {
      background: var(--card-sel-color, var(--brand));
      border-color: var(--card-sel-color, var(--brand));
    }

    /* ─── Module Landing ─── */
    .mod-landing-hero {
      position: relative; padding: 56px 72px 48px;
      border-bottom: 1px solid rgba(255,255,255,0.06);
      overflow: hidden;
    }
    .mod-landing-section {
      padding: 44px 72px;
      border-bottom: 1px solid rgba(255,255,255,0.06);
    }
    .mod-landing-section-label {
      font-size: 11px; font-weight: 600; color: var(--text-muted);
      letter-spacing: 0.07em; text-transform: uppercase;
      font-family: var(--font-body); margin-bottom: 24px;
    }

    /* ============================================================
       EMPTY STATE
       ============================================================ */

    .empty-state {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: var(--space-16);
      text-align: center;
      min-height: 500px;
    }

    .empty-state-icon {
      width: 96px;
      height: 96px;
      margin-bottom: var(--space-6);
      border-radius: var(--radius-xl);
      display: flex;
      align-items: center;
      justify-content: center;
      box-shadow: 0 0 0 1px rgba(255,255,255,0.04) inset;
    }

    .empty-state-title {
      font-size: var(--text-h3);
      font-family: var(--font-display);
      font-weight: var(--weight-bold);
      color: var(--text-primary);
      margin-bottom: var(--space-2);
    }

    .empty-state-subtitle {
      font-size: var(--text-body);
      color: var(--text-secondary);
      margin-bottom: var(--space-8);
    }

    .empty-state-hint {
      font-size: 13px;
      color: var(--text-secondary);
      margin: 0 0 var(--space-6) 0;
      max-width: 420px;
      text-align: center;
      line-height: 1.5;
    }

    .empty-state-actions {
      display: flex;
      gap: var(--space-4);
      flex-wrap: wrap;
      justify-content: center;
      max-width: 560px;
      width: 100%;
    }

    .empty-state-features {
      display: flex;
      flex-direction: column;
      gap: var(--space-2);
      margin-bottom: var(--space-8);
      text-align: left;
      width: 100%;
      max-width: 340px;
    }
    .empty-state-feature {
      font-size: var(--text-sm);
      color: var(--text-primary);
      opacity: 0.88;
      display: flex;
      align-items: center;
      gap: var(--space-2);
      line-height: 1.4;
    }
    .empty-state-feature-dot {
      flex-shrink: 0;
      width: 8px;
      height: 8px;
      border-radius: 50%;
    }
    .empty-state-cta {
      padding: var(--space-3) var(--space-5);
      border: none;
      border-radius: var(--radius-md);
      font-size: var(--text-body);
      font-weight: var(--weight-semibold);
      cursor: pointer;
      font-family: inherit;
      color: #fff;
      flex: 0 1 auto;
      min-width: 220px;
      white-space: nowrap;
      transition: opacity 0.15s, transform 0.15s;
    }
    .empty-state-cta:hover { opacity: 0.88; }
    .empty-state-cta:active { transform: translateY(1px); }
    .empty-state-cta-secondary {
      padding: var(--space-3) var(--space-5);
      background: transparent;
      color: var(--text-secondary);
      border: 1px solid var(--border);
      border-radius: var(--radius-md);
      font-size: var(--text-body);
      font-weight: var(--weight-medium);
      cursor: pointer;
      font-family: inherit;
      flex: 0 1 auto;
      min-width: 200px;
      white-space: nowrap;
      transition: color 0.15s, border-color 0.15s, background 0.15s;
    }
    .empty-state-cta-secondary:hover { color: var(--text-primary); border-color: var(--text-muted); background: rgba(255,255,255,0.025); }
    .empty-state--compact {
      min-height: 200px;
      padding: var(--space-8);
    }
    .empty-state--compact .empty-state-icon {
      width: 48px;
      height: 48px;
      margin-bottom: var(--space-4);
    }
    .empty-state--compact .empty-state-title {
      font-size: var(--text-body);
    }

    /* ============================================================
       RESPONSIVE
       ============================================================ */

    @media (max-width: 900px) {
      .modules-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .modules-hub {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-6);
        max-width: 100%;
      }

      .module-hub-card {
        min-height: 160px;
      }

      .home-content {
        padding: var(--space-8) var(--space-4);
      }

      .home-title {
        font-size: 24px;
      }
    }

    @media (max-width: 600px) {
      .modules-hub {
        grid-template-columns: 1fr;
        max-width: 100%;
      }

      .module-hub-card {
        min-height: 140px;
      }

      /* ── Compact header on small screens ── */
      /* Hide keyboard cheatsheet button */
      .home-header [data-tooltip="Atajos (?)"] { display: none !important; }
      /* Hide search button text and kbd badge — keep only the icon */
      .home-header [data-tooltip="Buscar (⌘K)"] span { display: none !important; }
      .home-header [data-tooltip="Buscar (⌘K)"] { padding: 0 12px !important; margin-right: 6px !important; min-width: 44px; min-height: 44px; box-sizing: border-box; }
      /* Hide name inside header-user on mobile, keep avatar visible via trigger */
      #headerUserName { display: none !important; }
      /* Larger touch target for settings gear on mobile */
      .btn-settings { min-width: 44px; min-height: 44px; }
      /* FRENTE 2: hit-targets ≥44px (iOS/WCAG) — tema (36px) y logo (28px) quedaban chicos. */
      #headerThemeToggle { min-width: 44px !important; min-height: 44px !important; }
      .home-header .header-logo { min-height: 44px; align-items: center; }
      /* FLU-162: boot-lock — gear is physically non-interactive until _bootApp() lifts it */
      body.no-boot .btn-settings { pointer-events: none !important; }
      /* Settings drawer: never wider than screen (transform handles hide/show) */
      .settings-drawer { width: 100% !important; max-width: 100vw !important; }

      /* FRENTE 2 (mobile 2026-06-14): el header tenía ~13 ítems y los de la derecha
         (sucursal, usuario, settings) quedaban cortados fuera de pantalla a 390px.
         Ocultamos lo secundario o redundante en pantalla chica — todo sigue accesible:
         nombre del tenant (aparece en el cuerpo del hub), texto "FLUDE" (queda el ícono),
         actividad (sección "Actividad reciente" en el hub), sucursal (multi-sucursal poco
         común en móvil), pill de demo (el banner ya tiene "Salir del demo"). Quedan:
         logo-ícono, notificaciones, soporte, tema, buscar, usuario, settings. */
      .header-tenant,
      .home-header .header-logo-text,
      .home-header [data-tooltip="Actividad (a)"],
      .home-header #sucursalSelectorWrap,
      .home-header .header-demo-pill,
      .home-header .header-ver-demo { display: none !important; }

      .home-title {
        font-size: 20px;
      }

      .module-header {
        flex-wrap: wrap;
        height: auto;
        gap: var(--space-4);
        padding: var(--space-4);
      }

      .module-header-left {
        width: 100%;
      }

      .module-content {
        padding: var(--space-4);
      }

      .metric-cards {
        grid-template-columns: 1fr;
      }

      .modules-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }

      .onboarding-stepper { display: none !important; }
      .onboarding-modal { max-width: 100% !important; padding: 0 16px 40px !important; width: 100% !important; }
      .onboarding-overlay { padding: max(16px, env(safe-area-inset-top, 0px)) 16px max(24px, env(safe-area-inset-bottom, 0px)) !important; }
      .onboarding-content { padding: 20px 16px !important; }
      .onboarding-form-grid, [class*="onboarding"][class*="grid"] { grid-template-columns: 1fr !important; }
      .module-card { gap: 10px; padding: 12px; }
      .module-card-head { gap: 10px; }
      .module-card-icon-box { width: 34px; height: 34px; border-radius: 9px; }
      .module-name { font-size: 13px; }
      .module-badge, .module-card-detail { font-size: 10px; }
      /* FLU-162: plan/industry grids tienen inline style — requieren ID selector + !important */
      #planGrid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
      #planGrid > div { padding: 14px 10px !important; }
      #industriaGrid { grid-template-columns: repeat(3, 1fr) !important; gap: 6px !important; }
      #industriaGrid > div { padding: 6px 4px !important; min-height: 40px; border-radius: 8px !important; }
      #industriaGrid > div > div:first-child { font-size: 14px !important; margin-bottom: 0 !important; }
      #industriaGrid > div > div:last-child { font-size: 8px !important; line-height: 1.05 !important; }
      .mod-landing-hero { padding: 32px 20px 28px; }
      .mod-landing-section { padding: 28px 20px; }
    }

    @media (max-width: 414px) {
      .empty-state {
        padding: 24px 16px 20px;
        min-height: unset;
      }
      .empty-state-icon {
        width: 72px;
        height: 72px;
        max-height: 72px;
        margin-bottom: var(--space-4);
        border-radius: var(--radius-lg);
      }
      .empty-state-actions {
        flex-direction: column;
        width: 100%;
        gap: var(--space-2);
      }
      .empty-state-cta,
      .empty-state-cta-secondary {
        width: 100%;
        min-width: 0;
        white-space: normal;
      }
    }

    /* ============================================================
       UTILIDADES
       ============================================================ */

    .hidden {
      display: none !important;
    }

    .text-center {
      text-align: center;
    }

    .mb-4 {
      margin-bottom: var(--space-4);
    }

    .mb-6 {
      margin-bottom: var(--space-6);
    }

    .mb-8 {
      margin-bottom: var(--space-8);
    }

    .mt-6 {
      margin-top: var(--space-6);
    }

    .flex {
      display: flex;
    }

    .flex-center {
      display: flex;
      align-items: center;
      justify-content: center;
    }

    .gap-2 {
      gap: var(--space-2);
    }

    .gap-4 {
      gap: var(--space-4);
    }

    .text-h1 {
      font-family: var(--font-display);
      font-size: var(--text-h1);
      font-weight: var(--weight-extrabold);
      letter-spacing: -0.03em;
    }

    .text-h2 {
      font-family: var(--font-display);
      font-size: var(--text-h2);
      font-weight: var(--weight-bold);
      letter-spacing: -0.02em;
    }

    .text-h3 {
      font-family: var(--font-display);
      font-size: var(--text-h3);
      font-weight: var(--weight-bold);
      letter-spacing: -0.01em;
    }

    .text-secondary {
      color: var(--text-secondary);
    }

    .text-muted {
      color: var(--text-muted);
    }

    .text-success {
      color: var(--success);
    }

    .text-warning {
      color: var(--warning);
    }

    .text-error {
      color: var(--error);
    }

    /* ============================================================
       THEME TRANSITION — 200ms across all colour-bearing props
       ============================================================ */
    html { transition: none; }
    html.theme-transitioning,
    html.theme-transitioning *,
    html.theme-transitioning *::before,
    html.theme-transitioning *::after {
      transition:
        background-color 200ms ease,
        color 200ms ease,
        border-color 200ms ease,
        box-shadow 200ms ease !important;
    }

    /* ============================================================
       LIGHT THEME
       ============================================================ */
    [data-theme="light"] {
      color-scheme: light;
      --bg-base:        #F2F2F8;
      --bg-surface:     #FFFFFF;
      --bg-elevated:    #EAEAF4;
      --bg-card:        #FFFFFF;
      --border:         #D0D0E4;
      --border-subtle:  #E0E0F0;
      --text-primary:   #1A1A2E;
      --text-secondary: #4A4A6A;
      --text-muted:     #7878A0;
      --text-disabled:  #AAAAC4;
      /* Semánticos: las versiones dark (#10B981/#F59E0B) fallan WCAG AA como
         texto fino sobre blanco. Oscurecer en light sin tocar el matiz; los
         fondos-tinte de badges siguen usando el hex de marca por separado. */
      --success:        #0F9A6E;
      --warning:        #B4730B;
      --error:          #D93838;
    }
    [data-theme="light"] body,
    [data-theme="light"] .home-header,
    [data-theme="light"] .module-header { background: var(--bg-surface); }
    [data-theme="light"] .home-content  { background: var(--bg-base); }
    [data-theme="light"] .module-layer  { background: var(--bg-base); }
  [data-theme="light"] .fk-modal,
  [data-theme="light"] .fn-panel,
  [data-theme="light"] .settings-drawer {
    background: #FFFFFF;
    border-color: #E8E8EF;
    box-shadow: 0 20px 50px rgba(0,0,0,0.12);
  }
  [data-theme="light"] .fk-input { color: #0A0A15; }
  [data-theme="light"] .fk-overlay { background: rgba(0,0,0,0.4); }
  [data-theme="light"] .fk-item:hover,
  [data-theme="light"] .fk-item.fk-active { background: rgba(91,92,246,0.08); }
  [data-theme="light"] .fn-item.unread { background: rgba(91,92,246,0.05); }
  [data-theme="light"] .fn-item:hover { background: rgba(91,92,246,0.04); }
  [data-theme="light"] .fk-kbd {
    background: rgba(0,0,0,0.05);
    border-color: rgba(0,0,0,0.1);
  }

  /* ── Light mode: wizard + onboarding ─── */
  [data-theme="light"] .onboarding-step-card,
  [data-theme="light"] .wizard-route-card,
  [data-theme="light"] .wizard-entity-card,
  [data-theme="light"] .wizard-import-stat {
    background: var(--bg-surface);
    border-color: var(--border);
  }
  [data-theme="light"] .wizard-route-card:hover,
  [data-theme="light"] .wizard-entity-card:hover { border-color: var(--brand); }
  [data-theme="light"] .wizard-upload-zone { border-color: var(--border); }
  [data-theme="light"] .wizard-upload-zone:hover { border-color: var(--brand); }
  [data-theme="light"] .wizard-progress-wrap { background: rgba(0,0,0,0.08); }
  [data-theme="light"] .wizard-error-row { border-top-color: var(--border-subtle); }
  [data-theme="light"] .wizard-toggle-sw { background: rgba(0,0,0,0.15); }
  [data-theme="light"] .wizard-route-sub,
  [data-theme="light"] .wizard-entity-meta,
  [data-theme="light"] .wizard-progress-label,
  [data-theme="light"] .wizard-import-stat-label,
  [data-theme="light"] .wizard-error-header { color: var(--text-muted); }
  [data-theme="light"] .onboarding-stepper-line.s-pending { background: var(--border); }
  [data-theme="light"] .onboarding-stepper-dot.s-pending { background: var(--bg-elevated); }

  /* ── Light mode: exec dashboard bars ─── */
  [data-theme="light"] .exec-cf-bar,
  [data-theme="light"] .exec-top5-bar-wrap,
  [data-theme="light"] .exec-aging-bar-wrap { background: rgba(0,0,0,0.08); }
  [data-theme="light"] .exec-toggle,
  [data-theme="light"] .exec-wide-toggle { background: var(--bg-elevated); border-color: var(--border); }
  [data-theme="light"] .exec-wide-toggle-btn.active { background: var(--bg-surface); color: var(--text-primary); }
  [data-theme="light"] .exec-alert-item,
  [data-theme="light"] .exec-hero-badge.neutral { background: var(--bg-elevated); border-color: var(--border); }
  [data-theme="light"] .exec-section-count { background: rgba(0,0,0,0.06); color: var(--text-muted); }

  /* ── Light mode: module cards ─── */
  [data-theme="light"] .module-card {
    background: var(--bg-surface);
    border-color: var(--border);
  }
  [data-theme="light"] .module-nav-item:hover:not(.disabled) {
    background: var(--bg-elevated);
  }
  [data-theme="light"] .data-table tbody tr:hover { background: var(--bg-elevated); }
  [data-theme="light"] .fn-bell-btn:hover { background: rgba(0,0,0,0.05); }
  [data-theme="light"] .sucursal-btn:hover { background: rgba(0,0,0,0.05); color: var(--text-primary); }
  [data-theme="light"] .sucursal-opt:hover { background: rgba(0,0,0,0.04); color: var(--text-primary); }
  [data-theme="light"] .module-hub-card-upgrade { background: rgba(0,0,0,0.06); }
  [data-theme="light"] .file-input-wrapper { background: var(--bg-elevated); }
  [data-theme="light"] .kanban-card { background: var(--bg-surface); border-color: var(--border); }

    /* ============================================================
       FONT SIZE SCALING — sólo text de contenido, no layout
       ============================================================ */
    :root { --ui-fs-xs:11px; --ui-fs-sm:12px; --ui-fs-md:13px; --ui-fs-body:15px; }
    [data-text-size="large"] { --ui-fs-xs:12px; --ui-fs-sm:13px; --ui-fs-md:14px; --ui-fs-body:16px; }
    [data-text-size="xl"]    { --ui-fs-xs:13px; --ui-fs-sm:14px; --ui-fs-md:15px; --ui-fs-body:17px; }

    /* Aplicar escala a celdas de tabla y labels en todos los módulos */
    [data-text-size] .stk-table td,
    [data-text-size] .cmp-table td,
    [data-text-size] .module-layout table td { font-size: var(--ui-fs-md) !important; }
    [data-text-size] .stk-table th,
    [data-text-size] .cmp-table th,
    [data-text-size] .module-layout table th { font-size: var(--ui-fs-xs) !important; }
    [data-text-size] .module-nav-item { font-size: var(--ui-fs-md) !important; }
    [data-text-size] .stk-prod-name,
    [data-text-size] .cmp-prov-card [style*="font-size:14px"] { font-size: var(--ui-fs-md) !important; }
    [data-text-size] .stk-metric-sub,
    [data-text-size] .cmp-metric-sub { font-size: var(--ui-fs-sm) !important; }
    [data-text-size] .module-hub-metric { font-size: var(--ui-fs-sm) !important; }
    [data-text-size] .module-hub-name   { font-size: var(--ui-fs-md) !important; }

    /* ============================================================
       NORMALIZACIÓN TIPOGRÁFICA GLOBAL
       Estandariza text en todos los módulos (sidebar items idénticos)
       ============================================================ */
    .module-nav-item { font-size: 13px; }
    .module-sidebar-title { font-size: 14px; font-weight: 800; }

    /* ============================================================
       SETTINGS PANEL
       ============================================================ */
    .settings-overlay {
      position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 10000;
      opacity: 0; pointer-events: none; transition: opacity .2s;
      cursor: pointer; touch-action: manipulation; /* iOS Safari: needs cursor:pointer + touch-action to fire click */
      backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
    }
    .settings-overlay.open { opacity: 1; pointer-events: all; }
    .settings-drawer {
      position: fixed; top: 0; right: 0; width: 420px; height: 100%; max-height: 100dvh;
      background: var(--bg-elevated, #141424); border-left: 1px solid var(--border, #242438);
      z-index: 10001; display: flex; flex-direction: column; /* FLU-190: above FX banner (9000) */
      transform: translateX(100%);
      transition: transform .25s cubic-bezier(.4,0,.2,1); box-shadow: var(--shadow-xl);
    }
    .settings-drawer.open { transform: translateX(0); }
    .settings-header {
      display: flex; align-items: center; justify-content: space-between;
      padding: max(18px, env(safe-area-inset-top, 0px)) 22px 18px; border-bottom: 1px solid var(--border, #242438); flex-shrink: 0;
    }
    .settings-title { font-family: var(--font-display); font-size: 16px; font-weight: 800; color: var(--text-primary); }
    .settings-close { background: none; border: none; color: var(--text-muted); cursor: pointer; font-size: 22px; line-height: 1; padding: 0; min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; touch-action: manipulation; -webkit-tap-highlight-color: transparent; }
    .settings-close:hover { color: var(--text-primary); }
    .settings-body { flex: 1; overflow-y: auto; overscroll-behavior: contain; -webkit-overflow-scrolling: touch; padding: 22px 22px calc(22px + env(safe-area-inset-bottom, 0px)); }
    /* FLU-198: drawer footer with always-visible logout (mobile has no header logout) */
    .settings-footer { flex-shrink: 0; padding: 14px 22px calc(14px + env(safe-area-inset-bottom, 0px)); border-top: 1px solid var(--border, #242438); background: var(--bg-elevated, #141424); }
    .settings-footer .btn-cerrar-sesion { width: 100%; min-height: 44px; padding: 12px 16px; background: rgba(239, 68, 68, 0.10); border: 1px solid rgba(239, 68, 68, 0.45); color: #EF4444; border-radius: 10px; font-family: inherit; font-size: 14px; font-weight: 700; cursor: pointer; touch-action: manipulation; -webkit-tap-highlight-color: transparent; display: flex; align-items: center; justify-content: center; gap: 8px; }
    .settings-footer .btn-cerrar-sesion:hover { background: rgba(239, 68, 68, 0.18); }
    .settings-footer .btn-cerrar-sesion:active { background: rgba(239, 68, 68, 0.25); }
    .settings-section { margin-bottom: 28px; }
    .settings-section-title {
      font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
      color: var(--text-muted); margin-bottom: 14px; padding-bottom: 8px;
      border-bottom: 1px solid var(--border);
    }
    .settings-field { margin-bottom: 14px; }
    .settings-field label { display: block; font-size: 12px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
    .settings-field input {
      width: 100%; background: var(--bg-base, #080811); border: 1px solid var(--border);
      border-radius: 8px; color: var(--text-primary); padding: 9px 12px; font-size: var(--input-font-size);
      box-sizing: border-box; outline: none; font-family: inherit;
    }
    .settings-field input:focus { border-color: var(--brand); box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4); }
    .settings-avatar-row {
      display: flex; align-items: center; gap: 16px; margin-bottom: 18px;
    }
    .settings-avatar-img {
      width: 56px; height: 56px; border-radius: 50%; object-fit: cover;
      border: 2px solid var(--border); flex-shrink: 0;
    }
    .settings-avatar-placeholder {
      width: 56px; height: 56px; border-radius: 50%; background: var(--brand-dim);
      border: 2px solid var(--brand); display: flex; align-items: center; justify-content:center;
      font-size: 20px; font-weight: 800; color: var(--brand); font-family: var(--font-display); flex-shrink:0;
    }
    .settings-avatar-upload {
      display: flex; flex-direction: column; gap: 6px;
    }
    .settings-upload-btn {
      display: inline-flex; align-items: center; gap: 6px; padding: 7px 14px;
      background: var(--bg-card, #191929); border: 1px solid var(--border);
      border-radius: 8px; color: var(--text-secondary); font-size: 12px; font-weight: 600;
      cursor: pointer; transition: all .15s; font-family: inherit;
    }
    .settings-upload-btn:hover { border-color: var(--brand); color: var(--text-primary); }
    .settings-logo-preview {
      width: 90px; height: 54px; border-radius: 8px; object-fit: contain;
      background: var(--bg-base); border: 1px solid var(--border); flex-shrink: 0;
    }
    .settings-logo-placeholder {
      width: 90px; height: 54px; border-radius: 8px; background: var(--bg-base);
      border: 2px dashed var(--border); display: flex; align-items: center; justify-content: center;
      font-size: 11px; color: var(--text-muted); flex-shrink: 0; text-align: center;
    }
    .settings-theme-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
    .settings-theme-opt {
      display: flex; align-items: center; gap: 10px; padding: 12px 14px;
      background: var(--bg-card, #191929); border: 2px solid var(--border);
      border-radius: 10px; cursor: pointer; transition: all .15s; font-size: 13px;
      font-weight: 600; color: var(--text-secondary);
    }
    .settings-theme-opt.active { border-color: var(--brand); color: var(--text-primary); background: var(--brand-dim); }
    .settings-size-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
    .settings-size-opt {
      display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 12px 8px;
      background: var(--bg-card, #191929); border: 2px solid var(--border);
      border-radius: 10px; cursor: pointer; transition: all .15s;
    }
    .settings-size-opt.active { border-color: var(--brand); background: var(--brand-dim); }
    .settings-size-opt span:first-child { font-size: 11px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: .05em; }
    .settings-size-preview { font-weight: 600; color: var(--text-primary); }
    .settings-btn-save {
      width: 100%; padding: 11px; background: var(--brand); color: #fff;
      border: none; border-radius: 10px; font-size: 14px; font-weight: 700;
      cursor: pointer; font-family: inherit; transition: all .15s; margin-top: 8px;
    }
    .settings-btn-save:hover { filter: brightness(1.1); }
    .btn-settings {
      background: none; border: 1px solid var(--border, #242438); border-radius: 8px;
      color: var(--text-muted); cursor: pointer; padding: 6px 8px; display: flex;
      align-items: center; transition: all .15s;
      touch-action: manipulation; -webkit-tap-highlight-color: transparent;
    }
    .btn-settings:hover { color: var(--text-primary); border-color: var(--brand); }
    .btn-settings svg { width: 15px; height: 15px; stroke: currentColor; stroke-width: 2; }

/* FLU-820: focus-visible global a11y (app shell) */
.app-shell a:focus-visible,
.app-shell button:focus-visible,
.module-content a:focus-visible,
.module-content button:focus-visible,
.module-content [role="button"]:focus-visible,
.module-nav-item:focus-visible,
.app-hamburger:focus-visible,
.btn:focus-visible {
  outline: 2px solid var(--accent, #06CFC4);
  outline-offset: 2px;
  border-radius: var(--radius-sm, 6px);
}
.module-content input:focus-visible,
.module-content textarea:focus-visible,
.module-content select:focus-visible,
.settings-drawer input:focus-visible,
.settings-drawer textarea:focus-visible,
.settings-drawer select:focus-visible {
  outline: 2px solid var(--brand, #5B5CF6);
  outline-offset: 1px;
}
/* FLU-820: body scroll lock when mobile sidebar drawer is open */
body.app-drawer-open { overflow: hidden; touch-action: none; }

/* ── Mobile sidebar ─────────────────────────────────── */
.app-hamburger{display:none;background:transparent;border:none;cursor:pointer;padding:0;min-width:44px;min-height:44px;justify-content:center;color:var(--text-primary,#F0F0FA);align-items:center;line-height:0;}
@media(max-width:375px){
  .app-hamburger{background:rgba(139,92,246,.12);border-radius:8px;border:1px solid rgba(139,92,246,.25);}
}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199;}

/* FLU-1347: Override inline width:0 on #fvPanel — the .fv-panel-w-372/420 classes
   set width but inline style wins over class without !important, so + Nueva /
   + Nuevo presupuesto rendered into an invisible 0-width panel. */
#fvPanel.fv-panel-w-372 { width: 372px !important; min-width: 0 !important; max-width: min(420px, 100vw) !important; }
#fvPanel.fv-panel-w-420 { width: 420px !important; min-width: 0 !important; max-width: min(480px, 100vw) !important; }
@media(max-width:768px){
  .app-hamburger{display:flex;}
  /* FLU-1654: home-header hamburger has no sidebar to open on the home view
     (module-sidebar only exists inside an open module). Hide it to avoid the
     overlay-without-drawer trap; the module-header hamburger handles in-module
     drawer toggling (FLU-1623). */
  #appHamburger{display:none;}
  .module-sidebar{position:fixed;left:-220px;transition:left .25s ease;z-index:200;box-shadow:4px 0 24px rgba(0,0,0,.5);}
  .module-sidebar.sidebar-open{left:0;}
  .sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .25s;}
  .sidebar-overlay.sidebar-open{opacity:1;pointer-events:auto;}
  .module-content{margin-left:0!important;}
}

/* ═══ Mobile responsive global — fallback para todos los módulos ═══ */
@media (max-width: 768px) {
  /* Tablas con min-width → forzar contenedor padre a scroll-x */
  .module-content table[style*="min-width"],
  .module-content .table-wrapper { overflow-x: auto; max-width: 100%; display: block; }

  /* Quick panel global */
  .quick-panel { width: 100% !important; max-width: 100vw !important; }

  /* Reducir padding general del módulo */
  .module-content { padding: 12px !important; }
  .module-header { padding: 10px 12px !important; }

  /* Touch targets mínimos 40px */
  .module-content button,
  .module-content .btn { min-height: 40px; }
  .module-content button.btn-sm,
  .module-content .btn-sm { min-height: 32px; }

  /* FLU-1654: forzar drawers laterales abiertos a fullscreen.
     Antes esto aplicaba a `.fl-panel` (cerrado o abierto), lo que pisaba el
     `right:-100%` propio del módulo Flota y dejaba el panel cubriendo todo
     el viewport en mobile portrait → Flota se veía "en blanco" (audit FLU-1637).
     Restringimos a las variantes `.open` / `[aria-hidden="false"]` para no
     romper el estado cerrado. */
  .fl-panel.open, .cmp-panel.open, .stk-panel.open, .fv-panel.open,
  [class*="drawer"].open, [class$="-panel"][class*="side"].open,
  [class*="panel-lateral"].open, [class*="panel-right"].open,
  [class*="drawer"][aria-hidden="false"], [class*="-panel"][aria-hidden="false"][class*="side"] {
    width: 100% !important;
    max-width: 100vw !important;
    left: 0 !important;
    right: 0 !important;
  }

  /* Grids con repeat(4,1fr) inline → 2 cols (fallback sin tocar cada módulo) */
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  /* A 1 col en pantallas realmente chicas */
  [style*="grid-template-columns: repeat(4, 1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns: repeat(3, 1fr)"],
  [style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* Font sizes muy chicos leves bump */
  .module-content { font-size: 14px; }

  /* safe-area handled on .toast-container bottom directly */
}

  /* ── Búsqueda global (Cmd+K) ─────────────────────────────── */
  .fk-overlay {
    position: fixed; inset: 0; z-index: var(--z-search);
    background: rgba(8,8,17,0.7); backdrop-filter: blur(6px);
    display: none; align-items: flex-start; justify-content: center;
    padding: 80px 16px 24px; animation: fkFadeIn .15s ease;
  }
  .fk-overlay.open { display: flex; }
  @keyframes fkFadeIn { from{opacity:0} to{opacity:1} }
  .fk-modal {
    width: 100%; max-width: 640px;
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 14px;
    box-shadow: var(--shadow-xl);
    overflow: hidden; display: flex; flex-direction: column;
    max-height: calc(100vh - 120px);
  }
  .fk-search {
    display: flex; align-items: center; gap: 12px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border, #242438);
  }
  .fk-search svg { color: var(--text-muted, #52526E); flex-shrink: 0; }
  .fk-input {
    flex: 1; background: transparent; border: none; outline: none;
    font-family: var(--font-body, 'Inter', sans-serif);
    font-size: var(--input-font-size); color: var(--text-primary, #F0F0FA);
  }
  .fk-input:focus-visible { box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4); border-radius: 6px; }
  .fk-input::placeholder { color: var(--text-muted, #52526E); }
  .fk-kbd {
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-size: 10px; padding: 3px 7px; border-radius: 5px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-muted, #52526E); font-weight: 600;
  }
  .fk-results { overflow-y: auto; max-height: 440px; padding: 8px; }
  .fk-group-title {
    font-size: 10px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.08em; color: var(--text-muted, #52526E);
    padding: 10px 12px 6px;
  }
  .fk-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px; border-radius: 8px; cursor: pointer;
    transition: background 0.1s;
  }
  .fk-item:hover, .fk-item.fk-active { background: rgba(91,92,246,0.1); }
  .fk-item-icon {
    width: 28px; height: 28px; border-radius: 7px;
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .fk-item-text { flex: 1; min-width: 0; }
  .fk-item-title {
    font-size: 13px; font-weight: 600; color: var(--text-primary, #F0F0FA);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .fk-item-sub {
    font-size: 11px; color: var(--text-muted, #52526E); margin-top: 2px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }
  .fk-item-badge {
    font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 4px;
    background: rgba(255,255,255,0.06); color: var(--text-secondary, #8A8AAA); flex-shrink: 0;
  }
  .fk-empty { padding: 40px 20px; text-align: center; color: var(--text-muted, #52526E); font-size: 13px; }
  .fk-footer {
    display: flex; gap: 16px; align-items: center; padding: 10px 16px;
    border-top: 1px solid var(--border, #242438);
    font-size: 11px; color: var(--text-muted, #52526E);
  }
  .fk-footer-hint { display: flex; align-items: center; gap: 6px; }

  /* ── Soporte drawer top-bar (FLU-1390) ──────────────────────── */
  .fsp-wrap { position: relative; margin-right: 4px; }
  .fsp-btn {
    background: transparent; border: none; cursor: pointer;
    color: var(--text-secondary, #8A8AAA);
    width: 44px; height: 44px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    position: relative; transition: all 0.15s;
  }
  .fsp-btn:hover { background: rgba(255,255,255,0.05); color: var(--text-primary, #F0F0FA); }
  .fsp-badge {
    position: absolute; top: 8px; right: 8px;
    width: 7px; height: 7px; border-radius: 50%;
    background: #EF4444; border: 2px solid var(--bg-surface, #0E0E1A);
    display: block;
  }
  .soporte-overlay {
    position: fixed; inset: 0; background: rgba(0,0,0,0.55); z-index: 10000;
    opacity: 0; pointer-events: none; transition: opacity .2s;
    backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  }
  .soporte-overlay.open { opacity: 1; pointer-events: all; }
  .soporte-drawer {
    position: fixed; top: 0; right: 0; width: 320px; height: 100%; max-height: 100dvh;
    background: var(--bg-card, #191929); border-left: 1px solid var(--border, #242438);
    z-index: 10001; display: flex; flex-direction: column;
    transform: translateX(100%);
    transition: transform .25s cubic-bezier(.4,0,.2,1);
    box-shadow: -4px 0 32px rgba(0,0,0,0.4);
  }
  .soporte-drawer.open { transform: translateX(0); }
  .soporte-drawer-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: max(18px, env(safe-area-inset-top, 0px)) 20px 18px;
    border-bottom: 1px solid var(--border, #242438); flex-shrink: 0;
  }
  .soporte-drawer-title {
    display: flex; align-items: center; gap: 10px;
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-size: 15px; font-weight: 800; color: var(--text-primary, #F0F0FA);
  }
  .soporte-drawer-close {
    background: none; border: none; color: var(--text-muted, #52526E);
    cursor: pointer; font-size: 22px; min-width: 44px; min-height: 44px;
    display: flex; align-items: center; justify-content: center; border-radius: 8px;
    transition: all 0.15s;
  }
  .soporte-drawer-close:hover { color: var(--text-primary, #F0F0FA); background: rgba(255,255,255,0.05); }
  .soporte-drawer-body {
    flex: 1; overflow-y: auto; overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch;
    padding: 20px 20px calc(20px + env(safe-area-inset-bottom, 0px));
  }
  .soporte-section-title {
    font-size: 10px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--text-muted, #52526E); margin-bottom: 10px;
  }
  .soporte-link-list { display: flex; flex-direction: column; gap: 4px; margin-bottom: 28px; }
  .soporte-link {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 12px; border-radius: 8px; border: 1px solid var(--border, #242438);
    background: rgba(255,255,255,0.03); color: var(--text-primary, #F0F0FA);
    font-size: 13px; font-weight: 500; text-decoration: none; cursor: pointer;
    transition: all 0.15s;
  }
  .soporte-link:hover { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.12); }
  .soporte-link svg { flex-shrink: 0; color: var(--text-muted, #52526E); }
  .soporte-ticket-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
  .soporte-ticket {
    padding: 12px; border-radius: 10px; border: 1px solid var(--border, #242438);
    background: rgba(255,255,255,0.03);
  }
  .soporte-ticket-id { font-size: 10px; color: var(--text-muted, #52526E); font-weight: 600; margin-bottom: 4px; }
  .soporte-ticket-title { font-size: 13px; color: var(--text-primary, #F0F0FA); font-weight: 500; margin-bottom: 8px; }
  .soporte-ticket-status {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 10px; font-weight: 700; padding: 3px 8px; border-radius: 6px;
  }
  .soporte-ticket-status.abierto { background: rgba(239,68,68,0.12); color: #EF4444; }
  .soporte-ticket-status.revision { background: rgba(245,158,11,0.12); color: #F59E0B; }
  .soporte-ticket-status.cerrado { background: rgba(16,185,129,0.12); color: #10B981; }
  .soporte-btn-crear {
    width: 100%; padding: 12px; border-radius: 10px;
    background: var(--accent, #06CFC4); color: #080811;
    font-family: inherit; font-size: 13px; font-weight: 700;
    border: none; cursor: pointer; transition: all 0.15s;
    display: flex; align-items: center; justify-content: center; gap: 8px;
  }
  .soporte-btn-crear:hover { background: #05b8ae; }

  /* ── Centro de notificaciones ─────────────────────────────── */
  .fn-bell-wrap { position: relative; margin-right: 12px; }
  .fn-bell-btn {
    background: transparent; border: none; cursor: pointer;
    color: var(--text-secondary, #8A8AAA);
    width: 44px; height: 44px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    transition: all 0.15s;
  }
  .fn-bell-btn:hover { background: rgba(255,255,255,0.05); color: var(--text-primary, #F0F0FA); }
  .fn-bell-badge {
    position: absolute; top: 2px; right: 2px;
    background: #EF4444; color: #fff;
    font-size: 9px; font-weight: 800;
    min-width: 16px; height: 16px; border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    padding: 0 4px; line-height: 1;
    border: 2px solid var(--bg-surface, #0E0E1A);
  }
  .fn-panel {
    position: absolute; top: calc(100% + 8px); right: 0;
    width: 360px; max-height: 480px;
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 12px;
    box-shadow: var(--shadow-2xl);
    display: none; flex-direction: column; z-index: 200;
    animation: fnSlide 0.15s ease;
  }
  .fn-panel.open { display: flex; }
  @keyframes fnSlide { from{opacity:0;transform:translateY(-4px)} to{opacity:1;transform:translateY(0)} }
  .fn-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 14px 16px; border-bottom: 1px solid var(--border);
  }
  .fn-title { font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif); font-size: 14px; font-weight: 700; color: var(--text-primary, #F0F0FA); }
  .fn-clear { font-size: 11px; background: none; border: none; color: var(--accent, #06CFC4); cursor: pointer; font-family: inherit; }
  .fn-list { overflow-y: auto; flex: 1; }
  .fn-item {
    display: flex; gap: 10px; padding: 12px 16px;
    border-bottom: 1px solid var(--border-subtle, #1B1B2E);
    cursor: pointer; transition: background 0.1s;
  }
  .fn-item:hover { background: rgba(91,92,246,0.05); }
  .fn-item.unread { background: rgba(91,92,246,0.07); }
  .fn-item-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; margin-top: 6px; }
  .fn-item-content { flex: 1; min-width: 0; }
  .fn-item-title { font-size: 13px; font-weight: 600; color: var(--text-primary, #F0F0FA); margin-bottom: 2px; }
  .fn-item-msg { font-size: 12px; color: var(--text-secondary, #8A8AAA); line-height: 1.4; margin-bottom: 4px; }
  .fn-item-time { font-size: 10px; color: var(--text-muted, #52526E); font-family: var(--font-mono, 'JetBrains Mono', monospace); }
  .fn-empty { padding: 40px 20px; text-align: center; color: var(--text-muted); font-size: 13px; }

  /* ── Dashboard ejecutivo ──────────────────────────────────── */
  .exec-dash { padding: 0 var(--space-8, 32px) var(--space-8, 32px); display: none; }
  .exec-dash.active { display: block; }

  /* Hero card */
  .exec-hero { display: flex; align-items: center; justify-content: space-between; background: linear-gradient(135deg, rgba(91,92,246,0.1) 0%, rgba(6,207,196,0.05) 100%); border: 1px solid rgba(91,92,246,0.18); border-radius: 12px; padding: 20px 24px; margin-bottom: 14px; gap: 16px; }
  .exec-hero-left { flex: 1; min-width: 0; }
  .exec-hero-right { flex-shrink: 0; }
  .exec-hero-eyebrow { font-family: 'JetBrains Mono', var(--font-mono, monospace); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent,#06CFC4); margin-bottom: 4px; }
  .exec-hero-label { font-size: 11px; font-weight: 700; color: var(--text-muted,#52526E); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 6px; }
  .exec-hero-val { font-family: var(--font-display,'Plus Jakarta Sans',sans-serif); font-size: 42px; font-weight: 800; letter-spacing: -0.04em; color: var(--text-primary,#F0F0FA); line-height: 1; margin-bottom: 10px; }
  .exec-hero-val.negative { color: #EF4444; }
  .exec-hero-badge { display: inline-flex; align-items: center; font-size: 12px; font-weight: 700; padding: 4px 10px; border-radius: 100px; }
  .exec-hero-badge.up { background: rgba(16,185,129,0.14); color: #10B981; border: 1px solid rgba(16,185,129,0.25); }
  .exec-hero-badge.down { background: rgba(239,68,68,0.12); color: #EF4444; border: 1px solid rgba(239,68,68,0.2); }
  .exec-hero-badge.neutral { background: rgba(255,255,255,0.05); color: var(--text-secondary,#8A8AAA); border: 1px solid var(--border,#242438); }
  .exec-sparkline { display: block; }
  @media (max-width: 640px) { .exec-hero-right { display: none; } .exec-hero-val { font-size: 30px; } }

  /* Demo banner */
  .exec-demo-banner { background: rgba(6,207,196,0.07); border: 1px solid rgba(6,207,196,0.18); border-radius: 8px; padding: 8px 14px; font-size: 12px; color: var(--accent,#06CFC4); margin-bottom: 14px; text-align: center; }
  .exec-demo-banner a { color: #26EFE4; font-weight: 600; text-decoration: underline; cursor: pointer; }
  .exec-first-login { background: rgba(91,92,246,0.05); border: 1px solid rgba(91,92,246,0.12); border-radius: 8px; padding: 9px 14px; font-size: 12px; color: var(--text-muted,#52526E); margin-bottom: 14px; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
  .exec-first-login a { color: var(--brand-light,#7B7CF8); font-weight: 600; text-decoration: none; cursor: pointer; white-space: nowrap; }

  /* Alertas */
  .exec-alerts { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
  .exec-alert-item { display: flex; align-items: center; gap: 10px; padding: 9px 14px; border-radius: 8px; font-size: 13px; font-weight: 500; transition: opacity 0.15s; }
  .exec-alert-item:hover { opacity: 0.85; }
  .exec-alert-item.alert { background: rgba(239,68,68,0.09); border: 1px solid rgba(239,68,68,0.18); color: #FCA5A5; }
  .exec-alert-item.warn  { background: rgba(245,158,11,0.09); border: 1px solid rgba(245,158,11,0.18); color: #FDE68A; }
  .exec-alert-item.info  { background: rgba(91,92,246,0.07); border: 1px solid rgba(91,92,246,0.14); color: var(--brand-light,#7B7CF8); }

  /* KPI grid */
  .exec-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 10px; margin-bottom: 16px; }
  .exec-card { background: var(--bg-card, #191929); border: 1px solid var(--border, #242438); border-radius: 10px; padding: 12px 14px; }
  .exec-card.alert-card { border-color: rgba(239,68,68,0.38); background: rgba(239,68,68,0.04); }
  .exec-card.warn-card  { border-color: rgba(245,158,11,0.32); background: rgba(245,158,11,0.03); }
  .exec-card.ok-card    { border-color: rgba(16,185,129,0.28); background: rgba(16,185,129,0.03); }
  .exec-card-label { display: flex; align-items: center; gap: 6px; font-family: 'JetBrains Mono', var(--font-mono, monospace); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.14em; color: var(--accent, #06CFC4); margin-bottom: 6px; }
  .exec-card-label-dot { width: 5px; height: 5px; border-radius: 50%; flex-shrink: 0; }
  .exec-card-val { font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif); font-size: 22px; font-weight: 800; letter-spacing: -0.02em; color: var(--text-primary, #F0F0FA); margin-bottom: 2px; line-height: 1.1; }
  .exec-card-sub { font-size: 11px; color: var(--text-secondary, #8A8AAA); }
  .exec-bottom { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr); gap: 16px; align-items: start; }
  .exec-bottom > * { min-width: 0; }
  @media (max-width: 900px) { .exec-bottom { grid-template-columns: 1fr; } }
  .exec-activity-card { background: var(--bg-card, #191929); border: 1px solid var(--border-subtle, #1B1B2E); border-radius: 12px; padding: 14px 16px; }
  .exec-bottom .cotiz-wrap { margin: 0; }
  .exec-card-delta { font-size: 12px; font-weight: 700; }
  .exec-card-delta.up { color: #10B981; }
  .exec-card-delta.down { color: #EF4444; }
  .exec-section-title { display: flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 14px; font-weight: 700; color: var(--text-primary); margin: 20px 0 12px; }
  .exec-section-count { font-size: 10px; font-weight: 700; padding: 1px 7px; border-radius: 100px; background: rgba(255,255,255,0.05); color: var(--text-muted); }
  .exec-activity-item { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-subtle, #1B1B2E); }
  .exec-activity-item:last-child { border-bottom: none; }
  .exec-activity-dot { width: 8px; height: 8px; border-radius: 50%; margin-top: 6px; flex-shrink: 0; }
  .exec-toggle { display: inline-flex; gap: 4px; background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: 8px; padding: 3px; margin-bottom: 20px; }
  .exec-toggle-btn { padding: 6px 14px; font-size: 12px; font-weight: 600; background: transparent; border: none; cursor: pointer; color: var(--text-secondary); border-radius: 6px; font-family: inherit; }
  .exec-toggle-btn.active { background: var(--brand, #5B5CF6); color: #fff; }
  .exec-period-toggle { margin: 0 0 14px; }
  .exec-controls { display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; padding:14px 0 2px; margin-bottom:14px; border-bottom:1px solid var(--border-subtle); }
  .exec-controls-left { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
  .exec-controls-label { font-size:11px; font-weight:500; font-family:var(--font-mono); color:var(--text-muted); text-transform:uppercase; letter-spacing:0.1em; margin-right:2px; }
  .period-chip { font-family:var(--font-mono); font-size:10px; font-weight:500; color:var(--accent); background:rgba(6,207,196,0.08); border:1px solid rgba(6,207,196,0.2); border-radius:100px; padding:2px 9px; letter-spacing:0.06em; text-transform:uppercase; }
  .role-toggle { display:inline-flex; gap:3px; background:rgba(6,207,196,0.06); border:1px solid rgba(6,207,196,0.18); border-radius:8px; padding:3px; }
  .role-btn { padding:5px 12px; font-size:11px; font-weight:600; background:transparent; border:none; cursor:pointer; color:var(--text-secondary); border-radius:5px; font-family:inherit; transition:all 0.15s; letter-spacing:0.02em; }
  .role-btn.active { background:var(--accent); color:#0A0A1A; }
  .role-btn:hover:not(.active) { color:var(--accent); }
  .role-badge { font-size:10px; font-weight:700; padding:2px 8px; border-radius:100px; letter-spacing:0.04em; }
  .role-badge.ceo { background:rgba(91,92,246,0.15); color:var(--brand-light); border:1px solid rgba(91,92,246,0.25); }
  .role-badge.ventas { background:rgba(6,207,196,0.12); color:var(--accent); border:1px solid rgba(6,207,196,0.25); }
  .role-badge.ops { background:rgba(245,158,11,0.12); color:#F59E0B; border:1px solid rgba(245,158,11,0.25); }
  .role-badge.finanzas { background:rgba(139,92,246,0.12); color:#9B6FF8; border:1px solid rgba(139,92,246,0.25); }
  .role-kpi-tag { font-size:9px; font-weight:700; padding:1px 6px; border-radius:100px; letter-spacing:0.05em; text-transform:uppercase; float:right; margin-left:8px; margin-top:1px; }
  .role-kpi-tag.ventas { background:rgba(6,207,196,0.12); color:var(--accent); }
  .role-kpi-tag.ops { background:rgba(245,158,11,0.12); color:#F59E0B; }
  .role-kpi-tag.finanzas { background:rgba(139,92,246,0.12); color:#9B6FF8; }
  .exec-analytics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 10px; margin-bottom: 16px; }
  .exec-wide-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 16px; }
  @media (max-width: 700px) { .exec-wide-grid { grid-template-columns: 1fr; } }
  @media (max-width: 640px) { .exec-analytics-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 400px) { .exec-analytics-grid { grid-template-columns: 1fr; } }
  .exec-cf-bar { height: 6px; border-radius: 3px; background: rgba(255,255,255,0.06); margin: 8px 0; overflow: hidden; }
  .exec-cf-bar-fill { height: 100%; border-radius: 3px; background: #10B981; transition: width 0.4s ease; }
  .exec-top5-row { display: flex; align-items: center; gap: 8px; padding: 6px 0; border-bottom: 1px solid var(--border-subtle,#1B1B2E); }
  .exec-top5-row:last-child { border-bottom: none; }
  .exec-top5-bar-wrap { flex: 1; height: 5px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; }
  .exec-top5-bar { height: 100%; border-radius: 3px; background: linear-gradient(90deg, #5B5CF6, #06CFC4); transition: width 0.4s; }
  .exec-top5-name { font-size: 12px; color: var(--text-secondary); flex: 0 0 130px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .exec-top5-val { font-size: 11px; font-weight: 700; color: var(--text-primary); font-family: var(--font-mono,monospace); white-space: nowrap; }
  @media (max-width: 640px) { .exec-top5-bar-wrap { display: none; } .exec-top5-name { flex: 1; } }
  .exec-aging-row { display: flex; align-items: center; gap: 8px; padding: 7px 0; border-bottom: 1px solid var(--border-subtle,#1B1B2E); }
  .exec-aging-row:last-child { border-bottom: none; }
  .exec-aging-label { font-size: 10px; font-weight: 700; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.06em; flex: 0 0 60px; }
  .exec-aging-bar-wrap { flex: 1; height: 5px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; }
  .exec-aging-bar { height: 100%; border-radius: 3px; transition: width 0.4s; }
  .exec-aging-val { font-size: 11px; font-weight: 700; color: var(--text-primary); font-family: var(--font-mono,monospace); white-space: nowrap; flex: 0 0 65px; text-align: right; }
  .exec-aging-pct { font-size: 10px; color: var(--text-muted); flex: 0 0 30px; text-align: right; }
  @media (max-width: 640px) { .exec-aging-pct { display: none; } }
  .exec-wide-card { background: var(--bg-card,#191929); border: 1px solid var(--border,#242438); border-radius: 10px; padding: 14px 16px; }
  .exec-wide-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
  .exec-wide-toggle { display: inline-flex; gap: 2px; background: rgba(255,255,255,0.04); border: 1px solid var(--border); border-radius: 6px; padding: 2px; }
  .exec-wide-toggle-btn { padding: 3px 10px; font-size: 10px; font-weight: 700; background: transparent; border: none; cursor: pointer; color: var(--text-muted); border-radius: 4px; font-family: inherit; letter-spacing: 0.04em; }
  .exec-wide-toggle-btn.active { background: rgba(255,255,255,0.1); color: var(--text-primary); }

  /* FLU-1130: Aging stacked bars (CFO) — buckets canónicos */
  .cfo-aging-card { background: var(--bg-card,#191929); border: 1px solid var(--border,#242438); border-radius: 10px; padding: 14px 16px; margin-bottom: 16px; }
  .cfo-aging-row { margin-bottom: 14px; }
  .cfo-aging-row:last-child { margin-bottom: 0; }
  .cfo-aging-header { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 8px; gap: 8px; flex-wrap: wrap; }
  .cfo-aging-title { font-family: 'JetBrains Mono', var(--font-mono, monospace); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-secondary); }
  .cfo-aging-total { font-family: var(--font-mono, monospace); font-size: 12px; font-weight: 700; color: var(--text-primary); }
  .cfo-aging-bar { display: flex; height: 10px; width: 100%; border-radius: 4px; background: rgba(255,255,255,0.04); overflow: hidden; }
  .cfo-aging-bar-seg { height: 100%; transition: width 0.4s ease; }
  .cfo-aging-bar-seg:first-child { border-radius: 4px 0 0 4px; }
  .cfo-aging-bar-seg:last-child  { border-radius: 0 4px 4px 0; }
  .cfo-aging-legend { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 8px; }
  .cfo-aging-leg-item { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-secondary); }
  .cfo-aging-leg-dot { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
  .cfo-aging-leg-label { font-family: var(--font-mono, monospace); font-size: 10px; letter-spacing: 0.04em; color: var(--text-muted); }
  .cfo-aging-leg-val { font-family: var(--font-mono, monospace); font-weight: 700; color: var(--text-primary); }
  .cfo-aging-empty { font-size: 12px; color: var(--text-muted); padding: 8px 0; }
  .cfo-aging-bar-empty { background: rgba(255,255,255,0.04); }

  /* ── Settings tabs ────────────────────────────────────────── */
  .settings-tabs { display: flex; flex-wrap: wrap; gap: 4px; padding: 6px 0 0; border-bottom: 1px solid var(--border); margin-bottom: 16px; position: sticky; top: 0; z-index: 1; background: var(--bg-elevated, #141424); }
  .settings-tab { padding: 10px 8px; font-size: 12px; font-weight: 600; background: none; border: none; cursor: pointer; color: var(--text-muted); border-bottom: 2px solid transparent; font-family: inherit; white-space: nowrap; transition: all 0.15s; }
  .settings-tab:hover { color: var(--text-secondary); }
  .settings-tab.active { color: var(--brand); border-bottom-color: var(--brand); }

  /* FLU-375: MFA panel */
  .mfa-status-badge { display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.03em; }
  .mfa-status-badge.on  { background:rgba(16,185,129,0.12);color:#10B981;border:1px solid rgba(16,185,129,0.3); }
  .mfa-status-badge.off { background:rgba(255,255,255,0.05);color:var(--text-muted);border:1px solid var(--border); }
  .mfa-qr-box { background:white;border-radius:12px;padding:12px;display:inline-flex;align-items:center;justify-content:center;margin:12px 0; }
  .mfa-qr-box img { width:160px;height:160px;display:block; }
  .mfa-secret-box { font-family:monospace;font-size:13px;letter-spacing:.08em;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:8px;padding:8px 12px;word-break:break-all;color:var(--text-secondary);margin-bottom:10px; }
  .mfa-recovery-grid { display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:10px 0; }
  .mfa-recovery-code { font-family:monospace;font-size:12px;font-weight:700;background:rgba(255,255,255,0.06);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text-primary);letter-spacing:.06em; }
  .mfa-setup-step { background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px; }
  .mfa-setup-step-num { width:22px;height:22px;border-radius:50%;background:var(--brand);color:white;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;margin-right:8px;flex-shrink:0; }

  /* FLU-375: TOTP challenge in login overlay */
  #mfaForm .mfa-totp-icon { font-size:32px;text-align:center;margin-bottom:8px; }
  #mfaCodeInput { letter-spacing:.2em;font-size:22px;font-weight:700;text-align:center;font-family:monospace; }
  .settings-pane { display: none; }
  .settings-pane.active { display: block; }

  /* ── Comentarios en entidades ────────────────────────────── */
  .fc-thread { background: var(--bg-card, #191929); border: 1px solid var(--border, #242438); border-radius: 12px; padding: 16px; }
  .fc-thread-title { display: flex; align-items: center; gap: 8px; font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif); font-size: 13px; font-weight: 700; color: var(--text-primary, #F0F0FA); margin-bottom: 14px; }
  .fc-thread-count { font-size: 10px; padding: 2px 7px; border-radius: 10px; background: rgba(91,92,246,0.15); color: var(--brand, #5B5CF6); font-weight: 700; }
  .fc-list { margin-bottom: 14px; }
  .fc-item { display: flex; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--border-subtle, #1B1B2E); }
  .fc-item:last-child { border-bottom: none; }
  .fc-avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--brand, #5B5CF6); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; flex-shrink: 0; }
  .fc-body { flex: 1; min-width: 0; }
  .fc-meta { display: flex; gap: 8px; align-items: baseline; margin-bottom: 4px; }
  .fc-author { font-size: 12px; font-weight: 700; color: var(--text-primary, #F0F0FA); }
  .fc-time { font-size: 10px; color: var(--text-muted, #52526E); font-family: var(--font-mono, 'JetBrains Mono', monospace); }
  .fc-edited { font-size: 10px; color: var(--text-muted, #52526E); font-style: italic; }
  .fc-text { font-size: 13px; color: var(--text-secondary, #8A8AAA); line-height: 1.5; word-wrap: break-word; }
  .fc-text .fc-mention { color: var(--brand, #5B5CF6); background: rgba(91,92,246,0.1); padding: 1px 5px; border-radius: 4px; font-weight: 600; }
  .fc-actions { display: flex; gap: 10px; margin-top: 5px; font-size: 10px; }
  .fc-action-btn { background: none; border: none; cursor: pointer; color: var(--text-muted, #52526E); font-family: inherit; font-size: 10px; padding: 0; transition: color 0.15s; }
  .fc-action-btn:hover { color: var(--text-secondary, #8A8AAA); }
  .fc-action-btn.danger:hover { color: #EF4444; }
  .fc-input-wrap { position: relative; display: flex; gap: 8px; align-items: flex-start; background: var(--bg-elevated, #141424); border: 1px solid var(--border, #242438); border-radius: 10px; padding: 10px; }
  .fc-input { flex: 1; background: transparent; border: none; outline: none; color: var(--text-primary, #F0F0FA); font-family: var(--font-body, 'Inter', sans-serif); font-size: var(--input-font-size); resize: none; min-height: 36px; max-height: 120px; line-height: 1.4; }
  .fc-input:focus-visible { box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4); border-radius: 6px; }
  .fc-input::placeholder { color: var(--text-muted, #52526E); }
  .fc-send-btn { background: var(--brand, #5B5CF6); border: none; cursor: pointer; color: #fff; padding: 8px 14px; border-radius: 7px; font-family: inherit; font-size: 12px; font-weight: 600; transition: opacity 0.15s; flex-shrink: 0; }
  .fc-send-btn:disabled { opacity: 0.4; cursor: not-allowed; }
  .fc-mention-dropdown { position: absolute; bottom: calc(100% + 4px); left: 10px; background: var(--bg-elevated, #141424); border: 1px solid var(--border, #242438); border-radius: 8px; box-shadow: 0 10px 30px rgba(0,0,0,0.4); overflow: hidden; min-width: 200px; max-width: 260px; z-index: 100; display: none; }
  .fc-mention-dropdown.open { display: block; }
  .fc-mention-item { display: flex; align-items: center; gap: 8px; padding: 8px 12px; cursor: pointer; transition: background 0.1s; }
  .fc-mention-item:hover, .fc-mention-item.fc-mention-active { background: rgba(91,92,246,0.1); }
  .fc-mention-avatar { width: 22px; height: 22px; border-radius: 50%; background: var(--brand, #5B5CF6); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 9px; font-weight: 700; flex-shrink: 0; }
  .fc-mention-text { font-size: 12px; color: var(--text-primary, #F0F0FA); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .fc-empty { padding: 16px 0; text-align: center; color: var(--text-muted, #52526E); font-size: 12px; }
  [data-theme="light"] .fc-thread, [data-theme="light"] .fc-input-wrap, [data-theme="light"] .fc-mention-dropdown { background: #FFFFFF; border-color: #E8E8EF; }
  [data-theme="light"] .fc-input { color: #0A0A15; }
  [data-theme="light"] .fc-text .fc-mention { background: rgba(91,92,246,0.08); }

  /* ── Audit log ────────────────────────────────────────────── */
  .fa-list { margin-top: 12px; }
  .fa-item { display: flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--border-subtle, #1B1B2E); }
  .fa-item:last-child { border-bottom: none; }
  .fa-time-block { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 10px; color: var(--text-muted, #52526E); flex-shrink: 0; width: 80px; }
  .fa-content { flex: 1; min-width: 0; }
  .fa-action { font-size: 12px; font-weight: 600; color: var(--text-primary, #F0F0FA); margin-bottom: 2px; }
  .fa-target { font-size: 11px; color: var(--text-secondary, #8A8AAA); }
  .fa-user { font-size: 10px; color: var(--brand, #5B5CF6); margin-top: 2px; font-weight: 600; }
  .fa-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
  .fa-filter { background: rgba(255,255,255,0.04); border: 1px solid var(--border, #242438); color: var(--text-secondary, #8A8AAA); padding: 5px 12px; border-radius: 6px; cursor: pointer; font-family: inherit; font-size: 11px; font-weight: 600; transition: all 0.15s; }
  .fa-filter:hover { color: var(--text-primary); }
  .fa-filter.active { background: var(--brand, #5B5CF6); color: #fff; border-color: var(--brand); }
  .fa-empty { padding: 30px 0; text-align: center; color: var(--text-muted); font-size: 12px; }

  /* ── Papelera ─────────────────────────────────────────────── */
  .ft-list { margin-top: 12px; }
  .ft-item { display: flex; gap: 12px; align-items: center; padding: 12px; margin-bottom: 6px; background: rgba(255,255,255,0.02); border: 1px solid var(--border-subtle, #1B1B2E); border-radius: 8px; }
  .ft-icon { width: 32px; height: 32px; border-radius: 8px; background: rgba(239,68,68,0.1); color: #EF4444; display: flex; align-items: center; justify-content: center; font-size: 14px; flex-shrink: 0; }
  .ft-info { flex: 1; min-width: 0; }
  .ft-title { font-size: 13px; font-weight: 600; color: var(--text-primary, #F0F0FA); margin-bottom: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .ft-meta { font-size: 11px; color: var(--text-muted, #52526E); }
  .ft-ttl { font-size: 10px; color: var(--text-muted, #52526E); font-family: var(--font-mono, 'JetBrains Mono', monospace); }
  .ft-ttl.urgent { color: #F59E0B; }
  .ft-actions { display: flex; gap: 6px; flex-shrink: 0; }
  .ft-btn { background: rgba(255,255,255,0.04); border: 1px solid var(--border, #242438); color: var(--text-secondary, #8A8AAA); padding: 6px 10px; border-radius: 6px; cursor: pointer; font-family: inherit; font-size: 11px; font-weight: 600; transition: all 0.15s; }
  .ft-btn:hover { color: var(--text-primary); }
  .ft-btn.restore { color: #10B981; border-color: rgba(16,185,129,0.3); }
  .ft-btn.purge   { color: #EF4444; border-color: rgba(239,68,68,0.3); }
  .ft-empty { padding: 40px 0; text-align: center; color: var(--text-muted); font-size: 12px; }

  /* ── Tour de producto ────────────────────────────────────── */
  .ftour-overlay {
    position: fixed; inset: 0; z-index: 9990;
    background: rgba(8,8,17,0.65); backdrop-filter: blur(2px);
    display: none; pointer-events: auto;
    animation: ftourFade .15s ease;
  }
  .ftour-overlay.open { display: block; }
  @keyframes ftourFade { from{opacity:0} to{opacity:1} }

  .ftour-spotlight {
    position: absolute; border-radius: 10px;
    box-shadow: 0 0 0 9999px rgba(8,8,17,0.65),
                0 0 0 4px rgba(91,92,246,0.6);
    transition: all 0.25s ease; pointer-events: none;
  }

  .ftour-card {
    position: absolute; z-index: 9991;
    width: 320px; max-width: calc(100vw - 32px);
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 14px;
    box-shadow: var(--shadow-2xl);
    padding: 18px; pointer-events: auto;
    animation: ftourSlide .2s ease;
  }
  @keyframes ftourSlide { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

  .ftour-step {
    font-family: var(--font-mono, monospace); font-size: 10px;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--accent, #06CFC4); margin-bottom: 6px; font-weight: 700;
  }
  .ftour-title {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-size: 16px; font-weight: 800; letter-spacing: -0.01em;
    color: var(--text-primary, #F0F0FA); margin-bottom: 8px;
    line-height: 1.3;
  }
  .ftour-desc {
    font-size: 13px; color: var(--text-secondary, #8A8AAA);
    line-height: 1.5; margin-bottom: 14px;
  }
  .ftour-actions {
    display: flex; gap: 8px; align-items: center;
    justify-content: space-between;
  }
  .ftour-skip {
    background: none; border: none; cursor: pointer;
    color: var(--text-muted, #52526E); font-size: 12px;
    font-family: inherit; padding: 0;
  }
  .ftour-skip:hover { color: var(--text-secondary); }
  .ftour-nav { display: flex; gap: 8px; }
  .ftour-btn {
    background: rgba(255,255,255,0.05);
    border: 1px solid var(--border, #242438);
    color: var(--text-secondary, #8A8AAA);
    padding: 7px 14px; border-radius: 8px; cursor: pointer;
    font-family: inherit; font-size: 12px; font-weight: 600;
  }
  .ftour-btn:hover { color: var(--text-primary); }
  .ftour-btn.primary {
    background: var(--brand, #5B5CF6); border-color: var(--brand);
    color: #fff;
  }
  .ftour-progress {
    display: flex; gap: 4px; margin-top: 12px;
    padding-top: 12px; border-top: 1px solid var(--border-subtle, #1B1B2E);
  }
  .ftour-dot {
    flex: 1; height: 3px; border-radius: 2px;
    background: rgba(255,255,255,0.08);
  }
  .ftour-dot.done    { background: var(--accent, #06CFC4); }
  .ftour-dot.current { background: var(--brand, #5B5CF6); }

  [data-theme="light"] .ftour-card {
    background: #FFFFFF; border-color: #E8E8EF;
  }

  /* ── Flude Copilot ────────────────────────────────────────── */
  .fcp-fab {
    position: fixed; bottom: 24px; right: 24px; z-index: 100;
    width: 56px; height: 56px; border-radius: 50%;
    background: linear-gradient(135deg, var(--brand, #5B5CF6), var(--accent, #06CFC4));
    border: none; cursor: pointer;
    box-shadow: 0 10px 30px rgba(91,92,246,0.4);
    display: flex; align-items: center; justify-content: center;
    color: #fff; transition: transform 0.15s;
  }
  .fcp-fab:hover { transform: scale(1.05); }
  .fcp-fab svg { width: 22px; height: 22px; }
  .fcp-fab-pulse {
    position: absolute; inset: 0; border-radius: 50%;
    background: var(--brand);
    animation: fcpPulse 2s infinite;
  }
  @keyframes fcpPulse {
    0%   { transform: scale(1); opacity: 0.5; }
    100% { transform: scale(1.4); opacity: 0; }
  }

  .fcp-panel {
    position: fixed; bottom: 24px; right: 24px; z-index: 9995;
    width: 400px; max-width: calc(100vw - 32px);
    height: 580px; max-height: calc(100vh - 48px);
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 16px;
    box-shadow: var(--shadow-2xl);
    display: none; flex-direction: column; overflow: hidden;
    animation: fcpOpen .2s ease;
  }
  .fcp-panel.open { display: flex; }
  @keyframes fcpOpen { from{opacity:0;transform:translateY(10px)} to{opacity:1;transform:translateY(0)} }

  .fcp-header {
    display: flex; align-items: center; gap: 10px;
    padding: 14px 16px; border-bottom: 1px solid var(--border);
  }
  .fcp-avatar {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(135deg, var(--brand), var(--accent));
    display: flex; align-items: center; justify-content: center;
    color: #fff; flex-shrink: 0;
  }
  .fcp-title { flex: 1; }
  .fcp-name {
    font-family: var(--font-display); font-size: 14px; font-weight: 800;
    color: var(--text-primary);
  }
  .fcp-status {
    font-size: 10px; color: var(--success, #10B981);
    display: flex; align-items: center; gap: 4px;
  }
  .fcp-status::before {
    content: ''; width: 6px; height: 6px; border-radius: 50%;
    background: var(--success);
  }
  .fcp-close {
    background: none; border: none; cursor: pointer;
    color: var(--text-muted); font-size: 22px; line-height: 1;
  }

  .fcp-messages {
    flex: 1; overflow-y: auto; padding: 16px;
    display: flex; flex-direction: column; gap: 12px;
  }
  .fcp-msg { max-width: 85%; }
  .fcp-msg-bot {
    align-self: flex-start;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    padding: 10px 14px; border-radius: 14px 14px 14px 4px;
  }
  .fcp-msg-user {
    align-self: flex-end;
    background: var(--brand, #5B5CF6); color: #fff;
    padding: 10px 14px; border-radius: 14px 14px 4px 14px;
  }
  .fcp-msg-text {
    font-size: 13px; line-height: 1.5;
    color: var(--text-primary, #F0F0FA);
    white-space: pre-wrap; word-wrap: break-word;
  }
  .fcp-msg-user .fcp-msg-text { color: #fff; }
  .fcp-suggestions {
    display: flex; flex-wrap: wrap; gap: 6px; padding: 0 16px 12px;
  }
  .fcp-suggestion {
    background: rgba(91,92,246,0.08);
    border: 1px solid rgba(91,92,246,0.25);
    color: var(--brand, #5B5CF6);
    padding: 6px 10px; border-radius: 100px; cursor: pointer;
    font-family: inherit; font-size: 11px; font-weight: 600;
    transition: all 0.15s;
  }
  .fcp-suggestion:hover { background: rgba(91,92,246,0.15); }
  .fcp-input-wrap {
    display: flex; gap: 8px; padding: 12px 16px;
    border-top: 1px solid var(--border);
  }
  .fcp-input {
    flex: 1; background: var(--bg-base, #080811);
    border: 1px solid var(--border); border-radius: 10px;
    padding: 10px 14px; color: var(--text-primary);
    font-family: inherit; font-size: 13px; outline: none;
  }
  .fcp-input:focus { border-color: var(--brand); box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4); }
  .fcp-send {
    background: var(--brand); border: none; cursor: pointer;
    color: #fff; padding: 0 16px; border-radius: 10px;
    font-family: inherit; font-size: 13px; font-weight: 600;
  }
  .fcp-send:disabled { opacity: 0.4; cursor: not-allowed; }
  .fcp-thinking {
    display: flex; gap: 4px; padding: 14px;
    align-self: flex-start;
  }
  .fcp-thinking-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--text-muted);
    animation: fcpDot 1.4s infinite;
  }
  .fcp-thinking-dot:nth-child(2) { animation-delay: 0.2s; }
  .fcp-thinking-dot:nth-child(3) { animation-delay: 0.4s; }
  @keyframes fcpDot {
    0%, 60%, 100% { opacity: 0.3; transform: translateY(0); }
    30%           { opacity: 1;   transform: translateY(-4px); }
  }

  [data-theme="light"] .fcp-panel { background: #FFF; border-color: #E8E8EF; }
  [data-theme="light"] .fcp-input { background: #F8F8FA; }
  [data-theme="light"] .fcp-msg-bot { background: #F8F8FA; border-color: #E8E8EF; }

  @media (max-width: 480px) {
    .fcp-panel { width: 100%; height: 100vh; max-height: 100vh;
      bottom: 0; right: 0; border-radius: 0; }
    .fcp-fab { bottom: 16px; right: 16px; }
  }

  /* ── Vista de actividad ──────────────────────────────────── */
  .fact-overlay {
    position: fixed; inset: 0; z-index: 9994;
    background: rgba(8,8,17,0.85); backdrop-filter: blur(6px);
    display: none; align-items: flex-start; justify-content: center;
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    padding: max(16px, env(safe-area-inset-top, 0px)) 16px max(16px, env(safe-area-inset-bottom, 0px));
  }
  .fact-overlay.open { display: flex; }
  .fact-modal {
    width: 100%; max-width: 640px;
    max-height: calc(100dvh - 32px);
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 16px;
    display: flex; flex-direction: column; overflow: hidden;
    margin: auto 0;
    flex-shrink: 0;
  }
  .fact-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 18px 20px; border-bottom: 1px solid var(--border);
  }
  .fact-title {
    font-family: var(--font-display); font-size: 18px;
    font-weight: 800; color: var(--text-primary);
  }
  .fact-tabs {
    display: flex; gap: 2px; padding: 0 20px;
    border-bottom: 1px solid var(--border);
  }
  .fact-tab {
    background: none; border: none; padding: 10px 14px;
    color: var(--text-muted); font-family: inherit;
    font-size: 12px; font-weight: 600;
    border-bottom: 2px solid transparent; cursor: pointer;
  }
  .fact-tab.active { color: var(--brand); border-bottom-color: var(--brand); }
  .fact-body {
    flex: 1; overflow-y: auto; padding: 16px 20px;
  }
  .fact-day-group { margin-bottom: 20px; }
  .fact-day-title {
    font-family: var(--font-mono); font-size: 10px;
    text-transform: uppercase; letter-spacing: 0.08em;
    color: var(--text-muted); margin-bottom: 10px;
    padding-bottom: 6px; border-bottom: 1px solid var(--border-subtle);
  }
  .fact-entry { display: flex; gap: 12px; padding: 10px 0; }
  .fact-avatar {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--brand); color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; font-weight: 700; flex-shrink: 0;
  }
  .fact-content { flex: 1; min-width: 0; }
  .fact-row { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
  .fact-user { font-weight: 700; color: var(--text-primary); }
  .fact-action { color: var(--brand); font-weight: 600; }
  .fact-target { color: var(--text-secondary); }
  .fact-time {
    font-family: var(--font-mono); font-size: 10px;
    color: var(--text-muted); margin-top: 2px;
  }

  /* ── Empty states ─────────────────────────────────────────── */
  .fes {
    padding: 48px 32px; text-align: center;
    max-width: 380px; margin: 0 auto;
  }
  .fes-illu {
    width: 80px; height: 80px; border-radius: 20px;
    background: linear-gradient(135deg, rgba(91,92,246,0.12), rgba(6,207,196,0.12));
    border: 1px solid rgba(91,92,246,0.2);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 20px;
    color: var(--brand, #5B5CF6);
  }
  .fes-illu svg { width: 36px; height: 36px; }
  .fes-title {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-size: 18px; font-weight: 800; letter-spacing: -0.01em;
    color: var(--text-primary, #F0F0FA); margin-bottom: 8px;
  }
  .fes-desc {
    font-size: 13px; color: var(--text-secondary, #8A8AAA);
    line-height: 1.6; margin-bottom: 20px;
  }
  .fes-cta {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px;
    background: var(--brand, #5B5CF6); color: #fff;
    border: none; border-radius: 10px; cursor: pointer;
    font-family: inherit; font-size: 13px; font-weight: 600;
    text-decoration: none;
  }
  .fes-cta:hover { opacity: 0.9; }
  .fes-cta-secondary {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px; margin-left: 8px;
    background: transparent; color: var(--text-secondary);
    border: 1px solid var(--border); border-radius: 10px; cursor: pointer;
    font-family: inherit; font-size: 13px; font-weight: 600;
  }
  .fes-tips {
    margin-top: 24px; padding: 14px;
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--border-subtle, #1B1B2E);
    border-radius: 10px;
    text-align: left;
  }
  .fes-tip {
    display: flex; gap: 8px; font-size: 12px;
    color: var(--text-secondary); margin-bottom: 6px;
  }
  .fes-tip:last-child { margin-bottom: 0; }
  .fes-tip-icon {
    color: var(--accent, #06CFC4); flex-shrink: 0; font-weight: 700;
  }
  [data-theme="light"] .fes-illu {
    background: linear-gradient(135deg, rgba(91,92,246,0.08), rgba(6,207,196,0.08));
  }

  /* Per-module empty state icon colours — R7 */
  .fes-illu--gastos   { background: linear-gradient(135deg,rgba(91,92,246,0.16),rgba(91,92,246,0.06)); border-color: rgba(91,92,246,0.28); color:#5B5CF6; }
  .fes-illu--flujos   { background: linear-gradient(135deg,rgba(155,111,248,0.16),rgba(155,111,248,0.06)); border-color: rgba(155,111,248,0.28); color:#9B6FF8; }
  .fes-illu--ventas   { background: linear-gradient(135deg,rgba(6,207,196,0.16),rgba(6,207,196,0.06)); border-color: rgba(6,207,196,0.28); color:#06CFC4; }
  .fes-illu--flota    { background: linear-gradient(135deg,rgba(245,158,11,0.16),rgba(245,158,11,0.06)); border-color: rgba(245,158,11,0.28); color:#F59E0B; }
  .fes-illu--stock    { background: linear-gradient(135deg,rgba(16,185,129,0.16),rgba(16,185,129,0.06)); border-color: rgba(16,185,129,0.28); color:#10B981; }
  .fes-illu--factura  { background: linear-gradient(135deg,rgba(239,68,68,0.16),rgba(239,68,68,0.06)); border-color: rgba(239,68,68,0.28); color:#EF4444; }
  .fes-illu--compras  { background: linear-gradient(135deg,rgba(249,115,22,0.16),rgba(249,115,22,0.06)); border-color: rgba(249,115,22,0.28); color:#F97316; }
  .fes-illu--compras-pagos { background: linear-gradient(135deg,rgba(220,38,38,0.16),rgba(220,38,38,0.06)); border-color: rgba(220,38,38,0.28); color:#DC2626; }
  .fes-illu--finanzas { background: linear-gradient(135deg,rgba(139,92,246,0.16),rgba(139,92,246,0.06)); border-color: rgba(139,92,246,0.28); color:#8B5CF6; }
  .fes-illu--proyectos{ background: linear-gradient(135deg,rgba(99,102,241,0.16),rgba(99,102,241,0.06)); border-color: rgba(99,102,241,0.28); color:#6366F1; }
  .fes-illu--rrhh     { background: linear-gradient(135deg,rgba(236,72,153,0.16),rgba(236,72,153,0.06)); border-color: rgba(236,72,153,0.28); color:#EC4899; }

  /* ── Loading skeletons ────────────────────────────────────── */
  @keyframes fskShimmer {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
  }
  .fsk {
    background: linear-gradient(
      90deg,
      rgba(255,255,255,0.04) 0%,
      rgba(255,255,255,0.08) 50%,
      rgba(255,255,255,0.04) 100%
    );
    background-size: 200% 100%;
    animation: fskShimmer 1.4s ease-in-out infinite;
    border-radius: 6px;
  }
  [data-theme="light"] .fsk {
    background: linear-gradient(
      90deg,
      rgba(0,0,0,0.04) 0%,
      rgba(0,0,0,0.08) 50%,
      rgba(0,0,0,0.04) 100%
    );
    background-size: 200% 100%;
  }
  .fsk-card {
    background: var(--bg-card, #191929);
    border: 1px solid var(--border-subtle, #1B1B2E);
    border-radius: 12px; padding: 18px;
  }
  .fsk-row {
    display: flex; align-items: center; gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border-subtle, #1B1B2E);
  }
  .fsk-row:last-child { border-bottom: none; }
  .fsk-circle { border-radius: 50%; }
  .fsk-grid {
    display: grid; gap: 14px;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  }
  .fsk-stack > * + * { margin-top: 10px; }
  @media (prefers-reduced-motion: reduce) {
    .fsk { animation: none; }
  }

  /* ── Validación en vivo ───────────────────────────────────── */
  .fv-field { position: relative; margin-bottom: 14px; }
  .fv-input, input[data-fv], textarea[data-fv], select[data-fv] {
    transition: border-color 0.15s, box-shadow 0.15s;
  }
  .fv-input.fv-error, [data-fv].fv-error {
    border-color: #EF4444 !important;
    box-shadow: 0 0 0 3px rgba(239,68,68,0.1);
  }
  .fv-input.fv-success, [data-fv].fv-success {
    border-color: #10B981 !important;
    box-shadow: 0 0 0 3px rgba(16,185,129,0.08);
  }
  .fv-input.fv-warning, [data-fv].fv-warning {
    border-color: #F59E0B !important;
    box-shadow: 0 0 0 3px rgba(245,158,11,0.1);
  }
  .fv-input.fv-info, [data-fv].fv-info {
    border-color: #06CFC4 !important;
    box-shadow: 0 0 0 3px rgba(6,207,196,0.08);
  }
  input[data-fv]:disabled, textarea[data-fv]:disabled, select[data-fv]:disabled {
    opacity: 0.45; cursor: not-allowed; pointer-events: none;
  }
  label.fv-req::after { content: " *"; color: #EF4444; }
  .fv-msg {
    display: none; margin-top: 5px; font-size: 11px;
    line-height: 1.4; color: #EF4444;
  }
  .fv-msg.fv-warning { color: #F59E0B; }
  .fv-msg.fv-info { color: #06CFC4; }
  .fv-msg.fv-show { display: block; animation: fvSlide .12s ease; }
  @keyframes fvSlide {
    from { opacity: 0; transform: translateY(-2px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  .fv-hint { display: block; margin-top: 5px; font-size: 11px; color: var(--text-muted, #52526E); line-height: 1.4; }

  /* ── Cheatsheet de atajos ────────────────────────────────── */
  .fkbd-overlay {
    position: fixed; inset: 0; z-index: 9996;
    background: rgba(8,8,17,0.85); backdrop-filter: blur(6px);
    display: none; align-items: flex-start; justify-content: center;
    overflow-y: auto; -webkit-overflow-scrolling: touch;
    padding: max(16px, env(safe-area-inset-top, 0px)) 16px max(16px, env(safe-area-inset-bottom, 0px));
  }
  .fkbd-overlay.open { display: flex; }
  .fkbd-modal {
    width: 100%; max-width: 540px;
    max-height: calc(100dvh - 32px);
    background: var(--bg-elevated, #141424);
    border: 1px solid var(--border, #242438);
    border-radius: 14px;
    overflow: hidden; display: flex; flex-direction: column;
    margin: auto 0;
    flex-shrink: 0;
  }
  .fkbd-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 16px 20px; border-bottom: 1px solid var(--border);
  }
  .fkbd-title {
    font-family: var(--font-display); font-size: 16px;
    font-weight: 800; color: var(--text-primary);
  }
  .fkbd-body { overflow-y: auto; padding: 16px 20px; }
  .fkbd-section-title {
    font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em;
    font-weight: 700; color: var(--text-muted);
    margin: 16px 0 8px;
  }
  .fkbd-section-title:first-child { margin-top: 0; }
  .fkbd-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 8px 0; gap: 12px;
  }
  .fkbd-desc { font-size: 13px; color: var(--text-secondary); }
  .fkbd-keys { display: flex; gap: 4px; flex-shrink: 0; }
  .fkbd-key {
    font-family: var(--font-mono); font-size: 11px; font-weight: 600;
    padding: 3px 7px; border-radius: 5px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-primary); min-width: 20px; text-align: center;
  }
  .fkbd-plus { color: var(--text-muted); font-size: 11px; align-self: center; margin: 0 2px; }
  [data-theme="light"] .fkbd-modal { background: #FFF; }
  [data-theme="light"] .fkbd-key { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.1); }

  /* ── Indicadores de atajos ────────────────────────────────── */
  .fkbd-hint { display: inline-flex; align-items: center; gap: 4px; margin-left: 8px; opacity: 0.7; }
  .fkbd-hint-key {
    font-family: var(--font-mono); font-size: 9px; font-weight: 700;
    padding: 1px 4px; border-radius: 3px;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-muted); line-height: 1.2;
  }
  [data-tooltip] { position: relative; }
  [data-tooltip]:hover::after {
    content: attr(data-tooltip);
    position: absolute; bottom: calc(100% + 6px); left: 50%;
    transform: translateX(-50%);
    background: var(--bg-elevated, #141424);
    color: var(--text-primary);
    border: 1px solid var(--border);
    padding: 5px 9px; border-radius: 6px;
    font-size: 11px; white-space: nowrap;
    pointer-events: none; z-index: 10000;
    animation: fvSlide 0.12s ease;
  }

  /* ── Widget de cotizaciones ───────────────────────────────── */
  .cotiz-wrap {
    margin: 0 0 24px;
    background: var(--bg-card, #191929);
    border: 1px solid var(--border-subtle, #1B1B2E);
    border-radius: 14px;
    padding: 16px 18px;
  }
  .cotiz-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 14px;
  }
  .cotiz-title {
    font-family: var(--font-display); font-size: 13px;
    font-weight: 800; letter-spacing: 0.02em;
    color: var(--text-primary); text-transform: uppercase;
  }
  .cotiz-actions { display: flex; align-items: center; gap: 12px; }
  .cotiz-info { font-size: 10px; color: var(--text-muted); font-family: var(--font-mono); }
  .cotiz-refresh {
    background: rgba(255,255,255,0.05); border: 1px solid var(--border);
    color: var(--text-secondary); width: 26px; height: 26px;
    border-radius: 6px; cursor: pointer; font-size: 14px; line-height: 1;
    transition: transform 0.3s;
  }
  .cotiz-refresh:hover { color: var(--brand); transform: rotate(180deg); }
  .cotiz-refresh.cotiz-spinning { animation: cotizSpin 0.8s linear infinite; pointer-events: none; opacity: 0.7; }
  @keyframes cotizSpin { to { transform: rotate(360deg); } }
  .cotiz-grid {
    display: grid; gap: 10px;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  }
  .cotiz-card {
    background: rgba(255,255,255,0.02);
    border: 1px solid var(--border-subtle);
    border-radius: 10px;
    padding: 10px 12px;
    transition: border-color 0.15s, transform 0.15s;
  }
  .cotiz-card:hover {
    border-color: var(--brand);
    transform: translateY(-1px);
  }
  .cotiz-head {
    display: flex; align-items: center; gap: 6px;
    margin-bottom: 6px;
  }
  .cotiz-icon { font-size: 14px; }
  .cotiz-symbol {
    font-family: var(--font-mono); font-size: 10px; font-weight: 700;
    color: var(--text-muted); flex: 1;
    text-transform: uppercase; letter-spacing: 0.04em;
  }
  .cotiz-edit {
    cursor: pointer; color: var(--text-muted);
    font-size: 11px; padding: 2px 4px; border-radius: 4px;
    transition: color 0.15s, background 0.15s;
  }
  .cotiz-edit:hover { color: var(--brand); background: rgba(91,92,246,0.1); }
  .cotiz-val {
    font-family: var(--font-display);
    font-size: 18px; font-weight: 800; letter-spacing: -0.01em;
    color: var(--text-primary); line-height: 1.1;
    margin-bottom: 4px;
  }
  .cotiz-meta {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 10px; color: var(--text-muted);
    font-family: var(--font-mono);
  }
  .cotiz-ts { opacity: 0.7; }

  [data-theme="light"] .cotiz-card { background: #FAFAFC; }

  /* ── Mobile responsive ────────────────────────────────────── */
  @media (max-width: 720px) {
    .settings-drawer { width: 100% !important; max-width: 100%; height: 100dvh !important; max-height: 100dvh !important; }
    .fk-modal { max-width: calc(100vw - 24px) !important; }
    .fcp-panel { width: 100% !important; height: 100vh !important; max-height: 100vh !important; bottom: 0 !important; right: 0 !important; border-radius: 0 !important; }
    .fn-panel { position: fixed !important; top: 60px !important; left: 16px !important; right: 16px !important; width: auto !important; max-width: none !important; }
    .fkbd-modal { max-width: 100% !important; }
    .fact-modal { max-width: 100% !important; max-height: 100dvh !important; border-radius: 0; height: 100%; }
    .module-content table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; white-space: nowrap; max-width: 100%; }
    .module-content table::-webkit-scrollbar { height: 6px; }
    .module-content table::-webkit-scrollbar-thumb { background: var(--brand, #5B5CF6); border-radius: 3px; }
    /* Indicador visual de scroll horizontal (sombra a derecha) */
    .module-content { position: relative; }
    .module-content::after {
      content: ''; position: sticky; top: 0; right: 0;
      width: 12px; height: 100%; pointer-events: none;
      background: linear-gradient(to left, var(--bg-base, #080811), transparent);
    }
    /* FLU-1512: internal-layout makes module-content a flex column; the ::after
       becomes a flex item that consumes the full track (height:100%), starving
       the real content of space. Stock wrapper went black on mobile dark mode. */
    .module-content.internal-layout::after { display: none; }
    /* FLU-1623: drop the horizontal bottom-nav transform on portrait. Restore the
       vertical sidebar drawer (already styled by the ≤768px breakpoint) so the
       hamburger button stays as the single, discoverable nav affordance. The
       bottom-strip wasn't read as a "menú lateral" by users testing in portrait. */
    .exec-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 8px !important; }
    .exec-card { padding: 12px !important; }
    .exec-card-val { font-size: 20px !important; }
    .onboarding-step { padding: 24px 12px !important; }
    .exec-toggle { width: calc(100% - 32px) !important; margin: 0 16px 16px !important; }
    .exec-toggle-btn { flex: 1; }
    .exec-controls { flex-direction:column; align-items:flex-start; gap:10px; }
    .exec-controls > div:last-child { display:flex; align-items:center; gap:6px; overflow-x:auto; width:100%; padding-bottom:2px; }
    /* FRENTE 2: hit-targets táctiles — el toggle Módulos/Resumen quedaba en 25px y
       los pills de rol (CEO/Ventas/…) en ~22px. Subidos a ≥38-40px. */
    .exec-toggle-btn { padding:9px 10px; min-height:40px; }
    .role-btn { padding:9px 12px; min-height:38px; font-size:12px; white-space:nowrap; }
    .role-btn { padding:4px 10px; font-size:10px; }
    .ftour-card { width: calc(100vw - 32px) !important; max-width: 320px; }
    #modFab {
      position: fixed; bottom: 16px; right: 16px; z-index: 55;
      width: 56px; height: 56px; border-radius: 50%;
      border: none; cursor: pointer;
      align-items: center; justify-content: center;
      color: #fff; transition: transform 0.15s, opacity 0.2s;
      box-shadow: 0 8px 24px rgba(0,0,0,0.3);
    }
    #modFab:active { transform: scale(0.92); }
    #modFab svg { width: 24px; height: 24px; pointer-events: none; }
    /* FLU-848: 10 tabs no caben en 375px (wrap dejaba "Seguridad" huérfana en 3ª fila).
       Cambiamos a scroll horizontal con fade-mask en los bordes para indicar que hay más. */
    .settings-tabs {
      flex-wrap: nowrap; overflow-x: auto; overflow-y: hidden;
      gap: 0; padding: 6px 12px 0; scrollbar-width: none;
      -webkit-overflow-scrolling: touch;
      mask-image: linear-gradient(to right, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
      -webkit-mask-image: linear-gradient(to right, transparent 0, #000 16px, #000 calc(100% - 16px), transparent 100%);
    }
    .settings-tabs::-webkit-scrollbar { display: none; }
    .settings-tab { flex: 0 0 auto; padding: 10px 12px; font-size: 12px; min-height: 40px; text-align: center; white-space: nowrap; }
    /* FLU-848: pin "Guardar cambios" para que no quede fuera del fold en mobile */
    .settings-body .settings-btn-save {
      position: sticky; bottom: 8px; z-index: 2;
      box-shadow: 0 8px 20px rgba(0,0,0,0.35);
    }
  }
  /* FLU-848 P0-07: el botón flotante rojo "× CERRAR" (FLU-190) es un escape sólo para mobile.
     En desktop duplica el × interno del drawer y deja un artefacto visual encima del header. */
  @media (min-width: 768px) {
    #flu190-floating-close { display: none !important; }
  }
  @media (max-width: 380px) {
    .exec-grid { grid-template-columns: 1fr !important; }
    .home-welcome h1 { font-size: 22px !important; }
  }

  /* ── LOGIN SCREEN ─────────────────────────────────────────── */
  .login-overlay {
    position: fixed; inset: 0; z-index: 9999;
    background: var(--bg-base, #080811);
    display: flex; align-items: center; justify-content: center;
  }
  .login-card {
    width: 100%; max-width: 380px; padding: 40px 36px 32px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: 0 24px 64px rgba(0,0,0,0.18);
    margin: 16px;
  }
  .login-logo {
    display: flex; align-items: center; gap: 10px;
    justify-content: center; margin-bottom: 28px;
  }
  .login-tabs {
    display: flex; gap: 0; margin-bottom: 24px;
    border-radius: 8px; overflow: hidden;
    border: 1px solid var(--border);
  }
  .login-tab {
    flex: 1; padding: 9px 0; font-size: 13px; font-weight: 600;
    background: transparent; border: none; cursor: pointer;
    color: var(--text-secondary); transition: all 0.15s;
  }
  .login-tab.active {
    background: var(--accent); color: #fff;
  }
  .login-field { margin-bottom: 16px; }
  .login-field label {
    display: block; font-size: 12px; font-weight: 600;
    color: var(--text-secondary); margin-bottom: 6px;
  }
  .login-field input {
    width: 100%; padding: 10px 12px; font-size: var(--input-font-size);
    background: var(--bg-input, var(--bg-secondary));
    border: 1px solid var(--border); border-radius: 8px;
    color: var(--text-primary); outline: none; box-sizing: border-box;
    transition: border-color 0.15s;
  }
  .login-field input:focus { border-color: var(--brand); box-shadow: 0 0 0 2px rgba(91, 92, 246, 0.4); }
  .login-error {
    font-size: 12px; color: #EF4444; margin-bottom: 12px;
    padding: 8px 10px; background: rgba(239,68,68,0.08);
    border-radius: 6px;
  }
  .login-btn {
    width: 100%; padding: 11px; font-size: 14px; font-weight: 600;
    background: var(--brand); color: #fff; border: none;
    border-radius: 8px; cursor: pointer; transition: opacity 0.15s;
    margin-top: 4px;
  }
  .login-btn:hover { opacity: 0.88; }
  .login-btn:disabled { opacity: 0.5; cursor: not-allowed; }
  .login-demo-link {
    text-align: center; font-size: 12px; color: var(--text-muted);
    margin-top: 20px; margin-bottom: 0;
  }
  .login-demo-link a { color: var(--accent); text-decoration: none; font-weight: 600; }
  /* FLU-455: dual login */
  .login-dual {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0;
    width: 100%;
    max-width: 760px;
    margin: 16px;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    box-shadow: 0 24px 64px rgba(0,0,0,0.18);
    overflow: hidden;
  }
  .login-col-real {
    padding: 40px 36px 32px;
  }
  .login-col-demo {
    padding: 40px 32px;
    background: var(--bg-secondary, rgba(255,255,255,0.03));
    border-left: 1px dashed var(--border);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 16px;
  }
  .login-demo-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    color: #3B5BDB;
    background: #EEF4FF;
    border-radius: 6px;
    padding: 3px 8px;
    text-transform: uppercase;
  }
  .login-demo-headline {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0;
  }
  .login-demo-sub {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin: 0;
  }
  .login-demo-cta {
    width: 100%;
    padding: 11px;
    font-size: 14px;
    font-weight: 600;
    background: transparent;
    color: var(--accent);
    border: 1.5px solid var(--accent);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.15s;
    font-family: inherit;
  }
  .login-demo-cta:hover { background: rgba(91,92,246,0.08); }
  .login-signup-footer {
    grid-column: 1 / -1;
    text-align: center;
    padding: 16px;
    border-top: 1px solid var(--border);
    font-size: 12px;
    color: var(--text-muted);
  }
  .login-signup-footer a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 600;
  }
  .login-consent {
    display: flex; align-items: flex-start; gap: 9px;
    font-size: 12px; line-height: 1.45; color: var(--text-secondary);
    margin: 4px 0 14px;
  }
  .login-consent input[type="checkbox"] {
    flex: 0 0 auto; width: 15px; height: 15px;
    margin-top: 2px; cursor: pointer; accent-color: var(--accent);
  }
  .login-consent label { cursor: pointer; }
  .login-consent a { color: var(--accent); text-decoration: none; font-weight: 600; }
  .login-consent a:hover { text-decoration: underline; }
  .login-consent.invalid { color: #EF4444; }
  .login-consent.invalid input[type="checkbox"] { outline: 2px solid #EF4444; outline-offset: 2px; border-radius: 3px; }

  /* ── Login mobile (iPhone SE 375px) ─────────────────────────── */
  @media (max-width: 430px) {
    .login-overlay {
      align-items: flex-start;
      overflow-y: auto;
      padding: max(16px, 8vh) 0 24px;
    }
    .login-card {
      padding: 28px 24px 24px;
      margin: 0 12px;
    }
  }
  @media (max-width: 680px) {
    .login-dual {
      grid-template-columns: 1fr;
      max-width: 420px;
    }
    .login-col-real {
      padding: 28px 24px 24px;
    }
    .login-col-demo {
      border-left: none;
      border-top: 1px solid var(--border);
      padding: 28px 24px;
    }
    .login-col-demo::before {
      content: "── ó explorar ──";
      display: block;
      font-size: 11px;
      color: var(--text-muted);
      margin-bottom: 8px;
    }
    .login-signup-footer { grid-column: 1; }
  }

  /* ── FLU-123: Mobile action bar ─────────────────────────────── */
  .mobile-action-bar { display: none; }

  @media (max-width: 719px) {
    #fac-drawer .mobile-action-bar,
    #fvPanel.fv-panel-open .mobile-action-bar,
    #gastosDetailModal.active .mobile-action-bar,
    #flujosDetailModal.active .mobile-action-bar,
    #cmp-panel.open .mobile-action-bar {
      display: flex;
      position: fixed;
      bottom: 0;
      left: 0;
      right: 0;
      height: 56px;
      background: var(--bg-elevated);
      border-top: 1px solid var(--border);
      align-items: center;
      padding: 0 16px;
      gap: 10px;
      z-index: 9500;
      box-sizing: border-box;
    }
    .mob-btn-primary {
      flex: 1;
      height: 40px;
      background: var(--accent);
      color: #fff;
      border: none;
      border-radius: 10px;
      font-family: var(--font-body);
      font-size: 14px;
      font-weight: 700;
      cursor: pointer;
      padding: 0 12px;
    }
    .mob-btn-more {
      width: 40px;
      height: 40px;
      flex-shrink: 0;
      background: var(--bg-card);
      border: 1px solid var(--border);
      border-radius: 10px;
      font-size: 18px;
      font-weight: 700;
      cursor: pointer;
      color: var(--text-secondary);
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0;
      letter-spacing: 0.05em;
    }
    .mob-more-menu {
      position: fixed;
      bottom: 62px;
      left: 16px;
      right: 16px;
      background: var(--bg-elevated);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 8px;
      display: none;
      flex-direction: column;
      gap: 2px;
      z-index: 9501;
    }
    .mob-more-menu.open { display: flex; }
    .mob-more-menu-btn {
      padding: 12px 16px;
      background: transparent;
      border: none;
      border-radius: 8px;
      font-family: var(--font-body);
      font-size: 14px;
      font-weight: 600;
      cursor: pointer;
      color: var(--text-primary);
      text-align: left;
      width: 100%;
    }
    .mob-more-menu-btn.danger { color: #EF4444; }
    .mob-more-menu-btn:active { background: var(--bg-card); }

    /* Content padding so last items aren't hidden behind fixed bar */
    #fac-drawer { padding-bottom: 72px !important; }
    #fvPanel.fv-panel-open > div { padding-bottom: 72px !important; }
    #gastosDetailModal.active .modal-content { padding-bottom: 72px !important; }
    #flujosDetailModal.active .modal-content { padding-bottom: 72px !important; }
    #cmp-panel.open .cmp-panel-body { padding-bottom: 72px !important; }

    /* Hide original bottom action buttons duplicated into bar */
    .fac-detail-btns { display: none !important; }
    .vts-detail-btns { display: none !important; }
    .cmp-mob-hide-btns .cmp-btn { display: none !important; }
  }

  /* ── FLU-222: Demo Banner ──────────────────────────────────── */
  .demo-banner {
    position: sticky;
    top: 0;
    z-index: 201; /* FLU-433: must be > --z-modal (200) to appear above .module-layer */
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    height: 40px;
    background: #EEF4FF;
    border-left: 4px solid #3B5BDB;
    font-size: 12px;
    font-weight: 600;
    color: #3B5BDB;
    padding: 0 16px;
    flex-shrink: 0;
  }
  @media (max-width: 600px) {
    .demo-banner { height: 36px; font-size: 11px; }
  }
  .demo-banner-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #3B5BDB;
    flex-shrink: 0;
    animation: demoPulse 2s ease-in-out infinite;
  }
  @keyframes demoPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: 0.5; transform: scale(0.75); }
  }
  .demo-banner-cta {
    background: none;
    border: 1px solid #3B5BDB;
    border-radius: 6px;
    color: #3B5BDB;
    font-size: 11px;
    font-weight: 700;
    font-family: inherit;
    padding: 3px 10px;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
    margin-left: 6px;
  }
  .demo-banner-cta:hover { background: rgba(59, 91, 219, 0.12); }
  @media (max-width: 600px) { .demo-banner-text-full { display: none; } }
  .chip--demo {
    display: inline-block;
    background: #EEF4FF;
    color: #3B5BDB;
    font-size: 11px;
    font-weight: 700;
    border-radius: 4px;
    padding: 1px 6px;
    margin-left: 6px;
    vertical-align: middle;
    letter-spacing: 0.04em;
  }
  .demo-action-overlay {
    position: fixed;
    inset: 0;
    z-index: 10010;
    background: rgba(0,0,0,0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
  }
  .demo-action-modal {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 32px 28px;
    max-width: 380px;
    width: 100%;
    text-align: center;
  }
  .demo-action-modal h3 {
    font-size: 18px;
    font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 10px;
  }
  .demo-action-modal p {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.6;
    margin: 0 0 24px;
  }
  .demo-action-modal-btns {
    display: flex;
    gap: 10px;
    flex-direction: column;
  }

  /* ── FLU-222: Demo Select Modal ────────────────────────────── */
  .demo-select-overlay {
    position: fixed;
    inset: 0;
    z-index: 3000;
    background: rgba(5, 5, 13, 0.92);
    backdrop-filter: blur(6px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
  }
  .demo-select-box {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: 20px;
    padding: 40px 36px 36px;
    max-width: 560px;
    width: 100%;
    box-shadow: var(--shadow-xl);
    text-align: center;
  }
  .demo-select-eyebrow {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 10px;
  }
  .demo-select-title {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-size: 26px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 6px;
  }
  .demo-select-sub {
    font-size: 14px;
    color: var(--text-secondary);
    margin-bottom: 32px;
  }
  .demo-select-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 24px;
  }
  @media (max-width: 480px) { .demo-select-cards { grid-template-columns: 1fr; } }
  .demo-card {
    background: var(--bg-card);
    border: 2px solid var(--border);
    border-radius: 14px;
    padding: 24px 20px;
    cursor: pointer;
    transition: border-color 0.15s, background 0.15s, transform 0.15s;
    text-align: left;
    position: relative;
  }
  .demo-card:hover { border-color: var(--brand); background: var(--bg-surface); transform: translateY(-2px); }
  .demo-card.demo-card-empresa:hover { border-color: var(--accent); }
  .demo-card-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 14px;
    font-size: 20px;
  }
  .demo-card-demo .demo-card-icon { background: var(--brand-dim); }
  .demo-card-empresa .demo-card-icon { background: var(--accent-dim); }
  .demo-card-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 4px;
  }
  .demo-card-title {
    font-size: 17px;
    font-weight: 800;
    color: var(--text-primary);
    margin-bottom: 6px;
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
  }
  .demo-card-desc {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 18px;
  }
  .demo-card-btn {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 700; font-family: inherit;
    padding: 8px 16px; border-radius: 8px; border: none;
    cursor: pointer; transition: all 0.15s;
  }
  .demo-card-demo .demo-card-btn { background: var(--brand); color: #fff; }
  .demo-card-demo .demo-card-btn:hover { background: var(--brand-light); }
  .demo-card-empresa .demo-card-btn { background: var(--accent); color: var(--bg-base); }
  .demo-card-empresa .demo-card-btn:hover { background: var(--accent-light); }
  .demo-select-note {
    font-size: 12px;
    color: var(--text-muted);
    line-height: 1.5;
  }

  /* FLU-1357: Demo industry picker */
  .demo-industry-cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 20px;
  }
  @media (max-width: 700px) { .demo-industry-cards { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 420px) { .demo-industry-cards { grid-template-columns: 1fr; } }
  .demo-card-constructora .demo-card-icon { background: rgba(249,115,22,0.15); }
  .demo-card-constructora .demo-card-btn { background: #F97316; color: #fff; }
  .demo-card-constructora:hover { border-color: #F97316 !important; }
  .demo-card-distribucion .demo-card-icon { background: rgba(16,185,129,0.15); }
  .demo-card-distribucion .demo-card-btn { background: #10B981; color: #fff; }
  .demo-card-distribucion:hover { border-color: #10B981 !important; }
  .demo-card-servicios .demo-card-icon { background: rgba(91,92,246,0.15); }
  .demo-card-servicios .demo-card-btn { background: var(--brand); color: #fff; }
  .demo-card-servicios:hover { border-color: var(--brand) !important; }
  .demo-card-retail .demo-card-icon { background: rgba(6,207,196,0.15); }
  .demo-card-retail .demo-card-btn { background: var(--accent); color: var(--bg-base); }
  .demo-card-retail:hover { border-color: var(--accent) !important; }

  /* ══════════════════════════════════════════════════════════════
     FLU-1603 · Demo flow v2 (per Pablo's UX spec FLU-1602)
     - Banner two-state (amber A → brand→accent B at >=5 actions)
     - 6-vertical picker (cards 3×2 → 2×3 → 1col)
     - Action modal refined copy + bullets + price footer
     - Sticky mobile CTA pill (state B only)
     ══════════════════════════════════════════════════════════════ */

  /* Banner v2 — fixed to the bottom of the viewport so it never covers the
     navbar / module headers / "volver" controls at the top (FLU-1602 founder
     feedback 2026-06-03). z-index sits below modals (which are 1000+) but
     above floating help/chat widgets. */
  .demo-banner-v2 {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 90;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 10px 20px;
    font-size: 13px;
    border-top: 1px solid rgba(245,158,11,0.25);
    background:
      linear-gradient(90deg, rgba(10,10,20,0.92) 0%, rgba(10,10,20,0.96) 100%),
      linear-gradient(90deg, rgba(245,158,11,0.12) 0%, rgba(245,158,11,0.06) 60%, rgba(245,158,11,0.12) 100%);
    background-blend-mode: normal, screen;
    backdrop-filter: blur(14px);
    flex-shrink: 0;
    color: var(--text-primary);
    box-shadow: 0 -8px 24px rgba(0,0,0,0.4);
  }
  /* Reserve scroll space at the bottom so the banner doesn't cover the last
     row of module content. Only kicks in while the banner is visible. */
  body.demo-active { padding-bottom: 56px; }
  @media (max-width: 720px) {
    body.demo-active { padding-bottom: 88px; }
  }
  .demo-banner-v2.state-b {
    background: linear-gradient(90deg, rgba(91,92,246,0.10) 0%, rgba(6,207,196,0.08) 100%);
    border-top: 1px solid rgba(91,92,246,0.25);
    border-bottom: 1px solid rgba(6,207,196,0.20);
  }
  .demo-banner-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 4px 10px;
    border-radius: 100px;
    background: rgba(245,158,11,0.18);
    color: #FFC555;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    flex-shrink: 0;
  }
  .demo-banner-pill::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #F59E0B;
    box-shadow: 0 0 0 3px rgba(245,158,11,0.25);
    animation: dpulseA 2.4s ease-in-out infinite;
  }
  .demo-banner-v2.state-b .demo-banner-pill {
    background: rgba(91,92,246,0.20);
    color: #9AA0FF;
  }
  .demo-banner-v2.state-b .demo-banner-pill::before {
    background: var(--brand, #5B5CF6);
    box-shadow: 0 0 0 3px rgba(91,92,246,0.25);
    animation-name: dpulseB;
  }
  @keyframes dpulseA {
    0%, 100% { box-shadow: 0 0 0 3px rgba(245,158,11,0.25); }
    50%      { box-shadow: 0 0 0 7px rgba(245,158,11,0.05); }
  }
  @keyframes dpulseB {
    0%, 100% { box-shadow: 0 0 0 3px rgba(91,92,246,0.25); }
    50%      { box-shadow: 0 0 0 7px rgba(91,92,246,0.05); }
  }
  @media (prefers-reduced-motion: reduce) {
    .demo-banner-pill::before { animation: none; }
  }
  .demo-banner-msg {
    color: var(--text-primary);
    font-weight: 500;
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .demo-banner-msg strong { font-weight: 700; color: #FFC555; }
  .demo-banner-v2.state-b .demo-banner-msg strong { color: var(--accent, #06CFC4); }
  .demo-banner-actions {
    display: flex;
    gap: 8px;
    align-items: center;
    flex-shrink: 0;
  }
  .demo-banner-link {
    background: none;
    border: none;
    font-family: inherit;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-secondary);
    cursor: pointer;
    padding: 6px 10px;
    border-radius: 6px;
    transition: all 0.15s;
  }
  .demo-banner-link:hover { color: var(--text-primary); background: rgba(255,255,255,0.05); }
  .demo-banner-v2 .demo-banner-cta {
    font-family: inherit;
    font-size: 12px;
    font-weight: 700;
    padding: 8px 14px;
    border-radius: 8px;
    background: linear-gradient(115deg, var(--brand, #5B5CF6) 0%, var(--accent, #06CFC4) 100%);
    color: #fff;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    white-space: nowrap;
    box-shadow: 0 6px 16px rgba(91,92,246,0.25);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    margin-left: 0;
  }
  .demo-banner-v2 .demo-banner-cta:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 22px rgba(91,92,246,0.35);
  }
  .demo-banner-close {
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: grid;
    place-items: center;
  }
  .demo-banner-close:hover { color: var(--text-primary); background: rgba(255,255,255,0.05); }
  /* Mobile collapse */
  .demo-banner-msg-short { display: none; }
  @media (max-width: 720px) {
    .demo-banner-v2 { padding: 10px 14px; gap: 8px; flex-wrap: wrap; }
    .demo-banner-msg-long { display: none; }
    .demo-banner-msg-short { display: inline; }
    .demo-banner-link { display: none; }
    .demo-banner-close { display: none; }
    .demo-banner-v2 .demo-banner-cta { font-size: 11px; padding: 7px 12px; }
  }

  /* Sticky mobile CTA pill (state B only, mobile only) */
  .demo-sticky-cta {
    position: fixed;
    left: 14px;
    right: 14px;
    bottom: 14px;
    z-index: 91;
    padding: 12px 16px;
    border-radius: 14px;
    background: linear-gradient(115deg, var(--brand, #5B5CF6) 0%, var(--accent, #06CFC4) 100%);
    color: #fff;
    font-family: inherit;
    font-weight: 700;
    font-size: 14px;
    border: none;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    box-shadow: 0 16px 40px rgba(91,92,246,0.35);
    text-align: left;
  }
  .demo-sticky-cta > span:first-child { display: flex; flex-direction: column; line-height: 1.25; }
  .demo-sticky-cta small { font-size: 11px; font-weight: 500; opacity: 0.9; margin-top: 2px; }
  @media (min-width: 721px) { .demo-sticky-cta { display: none !important; } }

  /* ── Industry picker v2 (6 cards) ─────────────────────────── */
  .demo-picker-shell {
    width: min(100%, 1080px);
    padding: 28px 22px;
    margin: 0 auto;
    background: transparent;
  }
  .demo-picker-head { text-align: center; margin-bottom: 28px; }
  .demo-picker-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 6px 14px;
    border-radius: 100px;
    background: rgba(6,207,196,0.08);
    border: 1px solid rgba(6,207,196,0.18);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 11px;
    color: var(--accent, #06CFC4);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 14px;
  }
  .demo-picker-eyebrow::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent, #06CFC4);
    box-shadow: 0 0 0 4px rgba(6,207,196,0.18);
  }
  .demo-picker-title {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-weight: 800;
    font-size: clamp(28px, 4.5vw, 44px);
    line-height: 1.05;
    letter-spacing: -0.03em;
    margin: 0 0 14px;
    text-wrap: balance;
    color: var(--text-primary);
  }
  .demo-picker-title em {
    font-style: normal;
    background: linear-gradient(115deg, var(--brand, #5B5CF6) 0%, var(--accent, #06CFC4) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .demo-picker-sub {
    font-size: 16px;
    color: var(--text-secondary);
    max-width: 560px;
    margin: 0 auto;
    text-wrap: pretty;
  }
  .demo-picker-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin-bottom: 24px;
  }
  @media (max-width: 880px) { .demo-picker-grid { grid-template-columns: repeat(2, 1fr); } }
  @media (max-width: 520px) { .demo-picker-grid { grid-template-columns: 1fr; } }
  .demo-vcard {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 22px 22px 20px;
    cursor: pointer;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
    position: relative;
    overflow: hidden;
    text-align: left;
    display: flex;
    flex-direction: column;
    gap: 10px;
    font-family: inherit;
    color: inherit;
    min-height: 168px;
    width: 100%;
  }
  .demo-vcard::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, color-mix(in oklab, var(--vc) 18%, transparent) 0%, transparent 55%);
    opacity: 0;
    transition: opacity 0.2s ease;
    pointer-events: none;
  }
  .demo-vcard:hover {
    transform: translateY(-2px);
    border-color: color-mix(in oklab, var(--vc) 45%, var(--border));
    box-shadow: 0 16px 40px rgba(0,0,0,0.35), 0 0 0 1px color-mix(in oklab, var(--vc) 25%, transparent);
  }
  .demo-vcard:hover::before { opacity: 1; }
  .demo-vcard:focus-visible { outline: 2px solid var(--vc); outline-offset: 3px; }
  .demo-vcard-head { display: flex; align-items: center; gap: 12px; }
  .demo-vcard-icon {
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: color-mix(in oklab, var(--vc) 15%, transparent);
    display: grid;
    place-items: center;
    color: var(--vc);
    flex-shrink: 0;
  }
  .demo-vcard-icon svg { width: 20px; height: 20px; }
  .demo-vcard-name {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-weight: 700;
    font-size: 17px;
    letter-spacing: -0.01em;
    color: var(--text-primary);
  }
  .demo-vcard-desc {
    font-size: 13px;
    color: var(--text-secondary);
    line-height: 1.5;
    text-wrap: pretty;
    flex: 1;
  }
  .demo-vcard-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 10px;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }
  .demo-vcard-seed { display: flex; align-items: center; gap: 6px; }
  .demo-vcard-seed::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--vc);
    opacity: 0.7;
  }
  .demo-vcard-arrow {
    color: var(--vc);
    font-size: 14px;
    transition: transform 0.18s ease;
  }
  .demo-vcard:hover .demo-vcard-arrow { transform: translateX(3px); }
  /* Vertical accents (shared with industrias.html palette) */
  .demo-vcard.v-construccion { --vc: #F97316; }
  .demo-vcard.v-transporte   { --vc: #F59E0B; }
  .demo-vcard.v-distribucion { --vc: #10B981; }
  .demo-vcard.v-retail       { --vc: #EF4444; }
  .demo-vcard.v-servicios    { --vc: #06CFC4; }
  .demo-vcard.v-agro         { --vc: #65A30D; }
  .demo-picker-foot {
    text-align: center;
    font-size: 13px;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    flex-wrap: wrap;
  }
  .demo-picker-foot a {
    color: var(--text-secondary);
    text-decoration: none;
    font-weight: 600;
    border-bottom: 1px solid var(--border);
    padding-bottom: 1px;
    transition: color 0.15s, border-color 0.15s;
  }
  .demo-picker-foot a:hover { color: var(--accent, #06CFC4); border-color: var(--accent, #06CFC4); }
  .demo-picker-sep { color: var(--border); }

  /* ── Action modal v2 (refined copy + bullets + price) ──────── */
  .demo-action-modal-v2 {
    max-width: 480px;
    padding: 0;
    text-align: left;
    overflow: hidden;
    position: relative;
    border-radius: 18px;
    box-shadow: 0 40px 80px rgba(0,0,0,0.55);
  }
  .demo-action-modal-bar {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg, var(--brand, #5B5CF6), var(--accent, #06CFC4));
  }
  .demo-action-modal-head { padding: 28px 26px 0; }
  .demo-action-modal-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    font-size: 11px;
    color: var(--accent, #06CFC4);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin-bottom: 12px;
  }
  .demo-action-modal-eyebrow::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent, #06CFC4);
    box-shadow: 0 0 0 4px rgba(6,207,196,0.18);
  }
  .demo-action-modal-v2 h3 {
    font-family: var(--font-display, 'Plus Jakarta Sans', sans-serif);
    font-weight: 800;
    font-size: 24px;
    letter-spacing: -0.02em;
    line-height: 1.15;
    margin: 0 0 12px;
    text-wrap: balance;
    color: var(--text-primary);
    text-align: left;
  }
  .demo-action-modal-body { padding: 14px 26px 18px; }
  .demo-action-modal-body p {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.55;
    margin: 0 0 4px;
    text-wrap: pretty;
    text-align: left;
  }
  .demo-action-bullets {
    list-style: none;
    margin: 16px 0 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .demo-action-bullets li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: var(--text-primary);
  }
  .demo-action-bullets li .ck {
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: rgba(16,185,129,0.18);
    color: #10B981;
    display: grid;
    place-items: center;
    flex-shrink: 0;
    margin-top: 1px;
  }
  .demo-action-bullets li .ck svg { width: 11px; height: 11px; }
  .demo-action-modal-foot {
    padding: 16px 26px 20px;
    border-top: 1px solid var(--border);
    display: flex;
    gap: 10px;
    align-items: center;
  }
  .demo-action-cta {
    flex: 1;
    padding: 13px 20px;
    border-radius: 10px;
    background: linear-gradient(115deg, var(--brand, #5B5CF6) 0%, var(--accent, #06CFC4) 100%);
    color: #fff;
    border: none;
    cursor: pointer;
    font-family: inherit;
    font-size: 14px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    box-shadow: 0 10px 24px rgba(91,92,246,0.30);
  }
  .demo-action-ghost {
    padding: 13px 18px;
    border-radius: 10px;
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-secondary);
    cursor: pointer;
    font-family: inherit;
    font-size: 14px;
    font-weight: 600;
  }
  .demo-action-ghost:hover { color: var(--text-primary); border-color: var(--text-secondary); }
  .demo-action-modal-price {
    text-align: center;
    font-size: 12px;
    color: var(--text-muted);
    padding: 14px 26px;
    background: var(--bg-surface, rgba(255,255,255,0.02));
    border-top: 1px solid var(--border);
  }
  .demo-action-modal-price strong { color: var(--text-primary); font-weight: 700; }

  /* ── FLU-724: Sucursal Selector ────────────────────────────── */
  .sucursal-selector { position: relative; }
  .sucursal-btn {
    display: flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,0.04);
    border: 1px solid var(--border);
    padding: 5px 10px; border-radius: 8px;
    cursor: pointer; color: var(--text-secondary);
    font-size: 12px; font-family: inherit;
    transition: all 0.15s ease;
    white-space: nowrap;
  }
  .sucursal-btn:hover { background: rgba(255,255,255,0.07); color: var(--text-primary); }
  .sucursal-label { max-width: 120px; overflow: hidden; text-overflow: ellipsis; }
  .sucursal-dropdown {
    position: absolute; top: calc(100% + 6px); right: 0;
    background: var(--bg-card); border: 1px solid var(--border);
    border-radius: 10px; min-width: 180px; z-index: 9999;
    box-shadow: 0 8px 24px rgba(0,0,0,0.4); padding: 4px;
  }
  .sucursal-opt {
    display: flex; align-items: center; gap: 8px;
    padding: 8px 10px; border-radius: 6px;
    cursor: pointer; font-size: 12px; color: var(--text-secondary);
    transition: all 0.15s ease;
  }
  .sucursal-opt:hover { background: rgba(255,255,255,0.05); color: var(--text-primary); }
  .sucursal-opt.active { color: var(--accent); }
  .sucursal-divider { height: 1px; background: var(--border); margin: 4px 0; }

  /* ── FLU-222: Header Demo Pill ─────────────────────────────── */
  .header-demo-pill {
    display: none;
    align-items: center;
    gap: 6px;
    background: rgba(6, 207, 196, 0.10);
    border: 1px solid rgba(6, 207, 196, 0.3);
    border-radius: 20px;
    padding: 4px 12px 4px 8px;
    font-size: 12px;
    font-weight: 700;
    color: var(--accent);
    cursor: pointer;
    font-family: inherit;
    white-space: nowrap;
    transition: background 0.15s;
    margin-right: 8px;
  }
  .header-demo-pill:hover { background: rgba(6, 207, 196, 0.18); }
  .header-demo-pill-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    animation: demoPulse 2s ease-in-out infinite;
    flex-shrink: 0;
  }
  .header-ver-demo {
    display: none;
    background: none;
    border: none;
    font-size: 12px;
    font-weight: 600;
    color: var(--text-muted);
    cursor: pointer;
    font-family: inherit;
    padding: 4px 8px;
    border-radius: 6px;
    transition: color 0.15s;
    margin-right: 8px;
    white-space: nowrap;
  }
  .header-ver-demo:hover { color: var(--text-secondary); }

  /* ── FLU-852: app-shell polish fixes ─────────────────────────
     S-1  user-menu dropdown
     S-2  home-welcome mobile stack
     S-3  home-content max-width at 1280+
     S-10 module-content max-width at 1600+
     S-11 search pill compact at 601-900px
  ─────────────────────────────────────────────────────────────── */
  .user-menu { position: relative; display: flex; align-items: center; }
  .user-menu-trigger {
    display: flex; align-items: center; gap: 8px;
    background: transparent; border: none; cursor: pointer;
    padding: 4px 6px; border-radius: 8px; min-height: 36px;
    font-family: inherit;
  }
  .user-menu-trigger:hover { background: rgba(255,255,255,0.05); }
  .user-menu-panel {
    position: absolute; right: 0; top: 100%; margin-top: 4px;
    background: var(--bg-card, #191929); border: 1px solid var(--border, #242438);
    border-radius: 8px; min-width: 160px; padding: 4px;
    z-index: 10002; box-shadow: 0 8px 24px rgba(0,0,0,0.4);
  }
  .user-menu-panel[hidden] { display: none; }
  .user-menu-panel button {
    width: 100%; padding: 10px 12px; background: transparent; border: none;
    cursor: pointer; color: var(--text-primary, #F0F0FA); font-size: 13px;
    font-weight: 500; font-family: inherit; border-radius: 6px;
    text-align: left; display: flex; align-items: center; gap: 8px;
  }
  .user-menu-panel button:hover { background: rgba(255,255,255,0.06); }
  /* FLU-1443 — IA credits ring */
  .user-avatar{width:32px;height:32px;border-radius:50%;background:rgba(91,92,246,0.15);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--brand,#5B5CF6);flex-shrink:0;overflow:hidden;}
  .ia-ring-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
  .ia-ring-svg{position:absolute;inset:-5px;width:calc(100% + 10px);height:calc(100% + 10px);overflow:visible;transform:rotate(-90deg);pointer-events:none;}
  .ia-ring-track{fill:none;stroke:rgba(255,255,255,0.07);stroke-width:2;}
  .ia-ring-arc{fill:none;stroke-width:2;stroke-linecap:round;transition:stroke-dasharray .4s ease,stroke .4s ease;}
  .ia-credits-panel{position:absolute;right:0;top:calc(100% + 10px);width:218px;background:var(--bg-card,#191929);border:1px solid var(--border,#242438);border-radius:12px;padding:14px 16px;box-shadow:0 12px 32px rgba(0,0,0,.65);z-index:10003;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .15s ease,transform .15s ease;}
  .user-menu:hover .ia-credits-panel{opacity:1;pointer-events:auto;transform:translateY(0);}
  .user-menu:has(.user-menu-panel:not([hidden])) .ia-credits-panel{opacity:0!important;pointer-events:none!important;}

  @media (max-width: 600px) {
    .home-welcome { flex-direction: column; align-items: flex-start; gap: var(--space-2, 8px); }
    .home-welcome .exec-toggle { margin-left: 0 !important; margin-top: var(--space-2, 8px); }
  }
  @media (min-width: 1280px) {
    .home-content { align-items: stretch; padding-top: var(--space-8, 32px); }
    .home-content > .home-welcome,
    .home-content > .modules-hub,
    .home-content > .exec-dash { width: 100%; max-width: 1440px; margin-left: auto; margin-right: auto; }
  }
  /* FLU-1644: removed `.module-content { max-width:1440px; margin:auto }` at ≥1600px.
     Modules render their own sidebar+content inside `.module-content`; centering
     the outer container pushes that sidebar away from the left edge and leaves a
     wide empty band on both sides at 1600px+ screens. Inner views already cap
     their own width (e.g. Ventas "Hoy" max-width:800px). */
  @media (min-width: 601px) and (max-width: 900px) {
    [data-tooltip="Buscar (⌘K)"] span { display: none !important; }
    [data-tooltip="Buscar (⌘K)"] { padding: 6px 8px !important; margin-right: 6px !important; }
  }

  /* Audit M28: iOS Safari hace zoom al enfocar inputs con font-size < 16px.
     En viewports táctiles los controles de formulario van a 16px. */
  @media (max-width: 768px) {
    input[type="text"], input[type="email"], input[type="password"], input[type="number"],
    input[type="search"], input[type="tel"], input[type="url"], input[type="date"],
    select, textarea {
      font-size: 16px !important;
    }
  }

  /* ═══ FRENTE 2 (2026-06-14): pase fino mobile módulo a módulo ═══
     Issues que ningún media query del módulo cubre (grids inline / anchos fijos).
     Las tablas con muchas columnas YA se apilan en cards via .fac-table/.g-ren-table
     (verificado): no se tocan acá. */
  @media (max-width: 560px) {
    /* Gráficos lado a lado: los grids INLINE con <canvas> (factura dashboard/reportes,
       finanzas, etc.) crean 2 columnas que no entran a 390px → el 2º canvas queda fuera
       de pantalla. Colapsar a 1 columna. (:has + !important vence el style inline.) */
    div[style*="grid-template-columns"]:has(> canvas),
    div[style*="grid-template-columns"]:has(> div > canvas),
    div[style*="grid-template-columns"]:has(> div > div > canvas) {
      grid-template-columns: 1fr !important;
    }
  }
  @media (max-width: 480px) {
    /* Drawer de conciliación bancaria (finanzas-banco): width:380px fijo desbordaba. */
    .finb-drawer { width: 100% !important; max-width: 100vw !important; }
    /* Modal de alta/edición de Catálogo: el grid 1fr 1fr no entra → 1 columna, y el
       .cat-input con min-width:260px rompía la celda. */
    .cat-grid { grid-template-columns: 1fr !important; }
    .cat-input { min-width: 0 !important; }

    /* Compras "Gasto por proveedor": .cmp-table-wrap tiene overflow:hidden y la tabla
       no apila → permitir scroll horizontal para no cortar columnas. */
    .cmp-table-wrap { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }

    /* Flujos "Mis solicitudes": tabla de 7 columnas dentro de una card overflow:hidden,
       sin scroll ni stacking → se corta. Apilar cada fila en card (sin headers; las
       celdas traen su propio contexto: título, solicitante, monto, estado). */
    #flujosContent table, #flujosContent table tbody,
    #flujosContent table tr, #flujosContent table td { display: block; width: auto; }
    #flujosContent table thead { display: none; }
    #flujosContent table tr { border: 1px solid var(--border, #1B1B2E); border-radius: 10px; margin-bottom: 8px; padding: 4px 2px; }
    #flujosContent table td { padding: 5px 12px !important; text-align: left !important; max-width: 100% !important; border: none !important; white-space: normal !important; }

    /* Conciliación bancaria (.finb-table, 4 col sin wrapper): apilar en cards (la fila
       sigue siendo clickeable para abrir el detalle del movimiento). */
    .finb-table, .finb-table tbody, .finb-table tr, .finb-table td { display: block; width: auto; }
    .finb-table thead { display: none; }
    .finb-table tr { border: 1px solid var(--border, #1B1B2E); border-radius: 10px; margin-bottom: 8px; padding: 4px 2px; }
    .finb-table td { padding: 5px 12px !important; text-align: left !important; border: none !important; }

    /* Proyectos: .prj-select se usaba en 12 filtros sin definición CSS → select nativo
       inconsistente. Estilarlo como .prj-input (16px ya por la regla anti-zoom iOS). */
    .prj-select { background: var(--bg-card, #191929); border: 1px solid var(--border, #1B1B2E); border-radius: 8px; color: var(--text-primary, #F0F0FA); padding: 9px 12px; font-family: inherit; outline: none; min-height: 44px; box-sizing: border-box; }

    /* Compras-pagos: la fila de ítems de factura (.cp-items-row) tenía 6 columnas fijas
       que a 390px quedaban en ~60px c/u. Producto a todo el ancho arriba; cant/precio/
       IVA/subtotal/× debajo. El header (.cp-items-head usa la misma clase) se realinea. */
    .cp-items-row { grid-template-columns: 1fr 1fr 1fr 1fr 28px !important; row-gap: 8px; }
    .cp-items-row > :first-child { grid-column: 1 / -1 !important; }

    /* media/baja del audit: grids de métricas (4 KPI cards apretadas a ~85px) → 2 col;
       grids de formulario 2-col → 1 col; botón chico de RRHH a tap ≥44px. */
    .prj-metrics, .stk-metrics { grid-template-columns: repeat(2, 1fr) !important; }
    .fin-form-grid-2, .cp-form { grid-template-columns: 1fr !important; }
    .rrhh-btn-sm { min-height: 44px !important; }
    /* Matriz de presupuesto 12 meses (~1000px): no colapsable → scroll horizontal. */
    .fin-grid-pres { overflow-x: auto !important; -webkit-overflow-scrolling: touch; }
  }

  /* ═══ UX polish (2026-06-15, auditoría de UX) ═══ */
  /* Dígitos de ancho fijo en montos/KPIs: con Plus Jakarta/Inter (proporcionales) los
     números "bailan" y las columnas no alinean. tabular-nums lo arregla (cero riesgo). */
  .exec-card-val, .exec-hero-val, .fin-kpi-val, .metric-value, .cmp-metric-val,
  .g-metric-value, .fac-card .val, .stk-metric-val, .prj-metric-val, .rrhh-kpi-val,
  .fl-kpi-val, .cp-kpi-val, td.num, .num,
  [class*="-metric-val"], [class*="-kpi-val"], [class*="-metric-value"] {
    font-variant-numeric: tabular-nums;
    font-feature-settings: "tnum";
  }
  /* Feedback táctil al presionar (faltaba :active en el botón primario). */
  .btn:active, .btn-primary:active, .btn-brand:active, .btn-accent:active,
  .fac-btn.prim:active, .cmp-btn-primary:active {
    transform: translateY(1px) scale(0.99);
    filter: brightness(0.95);
  }
