  :root{
    /* Marca Flowdex: negro casi puro, acento azul (triada), datos en verde/rojo, todo monoespaciado */
    --bg:#0a0a0a; --panel:#0d0d0d; --panel2:#171717; --border:#262626;
    --text:#cdcdcd; --muted:#6e6e6e; --accent:#5BB8D4; --accent2:#D4B86A;
    --buy:#33b157; --hold:#d8a21e; --sell:#e6483a;
    /* --buy/--sell = ganancias/pérdidas de precio (verde/rojo). El eje valuación
       (dislocación CCL) es independiente: RICH=naranja (caro), CHEAP=cian (oportunidad). */
    --rich:#e8821e; --cheap:#2bb6c4; --fair:#7a7a7a;
    --shadow:none;
  }
  /* Tema alternativo "phosphor": negro absoluto, estructura en blanco, verde de acento */
  body.terminal{
    --bg:#000000; --panel:#000000; --panel2:#0e0e0e; --border:#3a3a3a;
    --text:#dcdcdc; --muted:#6a6a6a; --accent:#39ff7a; --accent2:#e0b020;
    --buy:#39ff7a; --hold:#e0b020; --sell:#ff5b54;
    --rich:#e0b020; --cheap:#39e0e8; --fair:#7c7c7c;
  }
  /* ============================================================
     Tema "Mac" — macOS LIGHT mode. Rebranding visual fuerte (mismo layout,
     otra piel): fondo gris claro, cards blancas flotantes, barra translúcida
     (frosted), tipografía SF de Apple, bordes hairline, sombras en capas y
     TODO smooth. Mantiene los colores de marca (celeste + dorado). Aditivo:
     todo bajo `body.mac`, no toca los otros dos temas.
     ============================================================ */
  body.mac{
    --bg:#f3f3f6; --panel:#ffffff; --panel2:#f5f5f8; --border:#e5e5ea;
    /* Celeste de marca tal cual (#5BB8D4). El zoom base 1.05 (equivale al 105%
       del navegador) lo aplica applyZoom() por tema, no acá — el CSS zoom lo
       pisaba el body.style.zoom inline del control de zoom. */
    --text:#15151a; --muted:#6e6e78; --accent:#5BB8D4; --accent2:#A8781E;
    --buy:#1f9d4d; --hold:#b9770a; --sell:#e0312a;
    --rich:#c2560c; --cheap:#0e8aa0; --fair:#8a8a92;
    font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",system-ui,sans-serif;
    letter-spacing:.1px; background:var(--bg); color:var(--text);
    font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1,"cv01" 1;
  }
  /* Barras translúcidas estilo macOS (frosted glass) */
  body.mac .topbar,body.mac nav.tabsnav,body.mac .statusbar{
    background:rgba(248,248,250,.72)!important;
    -webkit-backdrop-filter:saturate(180%) blur(22px);backdrop-filter:saturate(180%) blur(22px);
    border-color:var(--border)!important}
  body.mac .topbar .brand b{color:var(--accent)}
  body.mac .mktbar,body.mac .wtape{background:#fbfbfd!important;border-color:var(--border)!important}
  body.mac .tape{background:#fff!important;border-color:var(--border)!important}
  body.mac nav.tabsnav a{color:var(--muted);border-radius:8px 8px 0 0;font-weight:600}
  body.mac nav.tabsnav a.active{color:var(--accent)}
  /* Cards blancas flotantes, redondeadas, con sombra en capas (profundidad Apple) */
  body.mac .card{background:#fff!important;border:1px solid var(--border)!important;border-radius:16px;
    box-shadow:0 1px 2px rgba(20,20,40,.05),0 10px 28px -12px rgba(20,20,40,.16)}
  body.mac .card:hover{box-shadow:0 1px 2px rgba(20,20,40,.06),0 22px 50px -18px rgba(20,20,40,.26)}
  body.mac .card h2{font-weight:680;letter-spacing:.2px;color:var(--text)}
  body.mac .glass-card,body.mac section.card,body.mac .panel{background:#fff!important}
  /* Inputs y botones macOS: blancos, redondeados, foco con halo del acento */
  body.mac input,body.mac select{background:#fff!important;border:1px solid var(--border)!important;
    border-radius:9px;color:var(--text)!important;box-shadow:0 1px 1px rgba(0,0,0,.03)}
  body.mac input:focus,body.mac select:focus{border-color:var(--accent)!important;box-shadow:0 0 0 4px rgba(91,184,212,.22)}
  body.mac .tbtn,body.mac .btn,body.mac button{border-radius:9px;border:1px solid var(--border);background:#fff;color:var(--text)}
  body.mac .tbtn:hover,body.mac .btn:hover,body.mac button:hover{background:#f7f7fa}
  /* Filas y tablas con separadores hairline */
  body.mac .moverrow{border-bottom:1px solid #f0f0f3}
  body.mac .moverrow:hover{background:#f6f6f9}
  body.mac table th{background:#fbfbfd!important;color:var(--muted)}
  body.mac table td{border-top:1px solid #f0f0f3}
  body.mac table.argT th{background:#fbfbfd!important}
  body.mac table.argT td{border-top:1px solid #f1f1f4}
  /* Scrollbars claras */
  body.mac *{scrollbar-color:#cfcfd6 transparent}
  body.mac *::-webkit-scrollbar-thumb{background:#cfcfd6}
  body.mac *::-webkit-scrollbar-thumb:hover{background:#b9b9c2}
  /* --- Pulido de contraste: textos claros hardcodeados → oscuros legibles --- */
  body.mac .mktbar .mk .nm{color:#1d1d1f}
  body.mac .mktbar .mk .ct{color:#6e6e73}
  body.mac .mktbar .mk.open .ct{color:#1f9d4d}
  body.mac .mk-marq-inner .nm,body.mac .mk-fixed .nm{color:#1d1d1f}
  body.mac .agent .txt,body.mac .rationale,body.mac .rd-lente,body.mac .rd-lectura{color:#2b2b2e!important}
  body.mac .rd-head .rd-title,body.mac .rd-head .tk,body.mac .rd-lente .rd-lname{color:#1d1d1f!important}
  body.mac .err{color:#c0271f!important;background:rgba(224,49,42,.07)!important;border-color:rgba(224,49,42,.3)!important}
  body.mac [style*="#9aa3b0"],body.mac [style*="#838c99"],body.mac [style*="#d4dde7"],
  body.mac [style*="#e6edf3"],body.mac [style*="#d4a72c"]{color:#3a3a3e!important}
  body.mac .deskfoot,body.mac .deskfoot a,body.mac .deskfoot .copy{color:#6b6b70}
  body.mac .foot{color:var(--muted)}
  /* --- Pulido fino estilo Apple: headers, push-buttons, badges, nav --- */
  body.mac .topbar .brand{color:#1d1d1f;letter-spacing:.4px}
  body.mac .topbar .brand b{color:var(--accent)}
  body.mac .topbar .logo{box-shadow:0 1px 3px rgba(0,0,0,.18)}
  /* Wordmark blanco → negro en el tema claro (si no, queda invisible sobre blanco) */
  body.mac .topbar .brand-word{filter:brightness(0) opacity(.88)}
  body.mac .card h2{font-size:12px;color:#1d1d1f;font-weight:650;letter-spacing:.45px}
  body.mac .pill{background:#fff;color:var(--muted)}
  body.mac .badge{box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}
  body.mac .tbtn,body.mac .btn,body.mac button{background:linear-gradient(#ffffff,#f5f5f8);box-shadow:0 1px 1.5px rgba(0,0,0,.06);font-weight:600}
  body.mac .tbtn:hover,body.mac .btn:hover,body.mac button:hover{background:linear-gradient(#ffffff,#edeef2)}
  body.mac nav.tabsnav a.active{border-bottom:2px solid var(--accent)}
  body.mac .live{color:#1f9d4d}
  /* Inputs de dividendos también blancos en Mac (el login mantiene su mundo oscuro) */
  body.mac #view-dividendos input,body.mac #view-dividendos select{background:#fff!important;color:var(--text)!important;border-color:var(--border)!important}
  /* Forzar a oscuro los textos claros hardcodeados (inline) que en blanco
     quedarían invisibles. Atributo-selector: pega solo sobre lo que los usa. */
  body.mac [style*="#e6e9ee"],body.mac [style*="#cdd6e0"],body.mac [style*="#cdcdcd"],
  body.mac [style*="#dcdcdc"],body.mac [style*="#e6e6e6"],body.mac [style*="#e2e2e2"],
  body.mac [style*="#cdcad4"]{color:#1d1d1f!important}
  /* Fondos oscuros hardcodeados → claros */
  body.mac [style*="background:#0a0a0a"],body.mac [style*="background:#0c0c0c"],
  body.mac [style*="background:#0d0d0d"],body.mac [style*="background:#0b0e0d"],
  body.mac [style*="background:#111"],body.mac [style*="background:#0e0e0e"]{background:var(--panel2)!important}
  /* Movimiento suave estilo Apple (solo el tema Mac) */
  body.mac .card,body.mac .tbtn,body.mac .btn,body.mac button,body.mac input,body.mac select,
  body.mac nav.tabsnav a,body.mac .moverrow,body.mac .mk,body.mac tr,body.mac .it,body.mac a{
    transition:background-color .22s cubic-bezier(.2,.7,.3,1),border-color .22s cubic-bezier(.2,.7,.3,1),
      color .18s ease,box-shadow .28s cubic-bezier(.2,.7,.3,1),transform .2s cubic-bezier(.2,.7,.3,1)}
  body.mac .moverrow:hover{transform:translateX(2px)}
  body.mac .tbtn:hover,body.mac .btn:hover,body.mac button:hover{transform:translateY(-1px)}
  body.mac .tbtn:active,body.mac .btn:active,body.mac button:active{transform:scale(.97)}
  body.mac nav.tabsnav a:hover{transform:translateY(-1px)}
  /* Fade-in suave al cambiar de vista (sensación 120Hz) */
  body.mac .view{animation:macfade .34s cubic-bezier(.2,.7,.3,1)}
  body.mac .card{animation:macrise .4s cubic-bezier(.2,.7,.3,1) both}
  @keyframes macfade{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:none}}
  @keyframes macrise{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
  /* ============================================================
     LIQUID GLASS — material actual de Apple (macOS Tahoe/Golden Gate, 2025-26).
     Translucidez + refracción + highlight especular en bordes + sombras
     adaptativas en capas + esquinas concéntricas + movimiento spring.
     Criterio de legibilidad (HIG): el CHROME es de vidrio; el CONTENIDO es
     sólido y crispy (texto siempre nítido). Todo bajo body.mac.
     ============================================================ */
  /* Fondo con tinte sutil para que el vidrio tenga algo vivo que refractar. */
  body.mac{background:
    radial-gradient(130% 90% at 100% 0%,#e9f3f8 0%,rgba(233,243,248,0) 52%),
    radial-gradient(130% 90% at 0% 100%,#f4efe7 0%,rgba(244,239,231,0) 52%),
    linear-gradient(180deg,#f6f7fb 0%,#edeff4 100%) fixed!important}
  /* Chrome de vidrio: blur fuerte + saturación + highlight especular arriba. */
  body.mac .topbar,body.mac nav.tabsnav{background:rgba(248,249,252,.6)!important;
    -webkit-backdrop-filter:saturate(180%) blur(28px);backdrop-filter:saturate(180%) blur(28px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 1px 0 rgba(16,24,40,.06)!important;border:0!important}
  body.mac .statusbar{background:rgba(248,249,252,.66)!important;
    -webkit-backdrop-filter:saturate(180%) blur(22px);backdrop-filter:saturate(180%) blur(22px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.7)!important;border:0!important}
  body.mac .mktbar,body.mac .wtape,body.mac .tape{background:rgba(251,252,254,.66)!important;
    -webkit-backdrop-filter:saturate(160%) blur(16px);backdrop-filter:saturate(160%) blur(16px);
    border-color:rgba(16,24,40,.06)!important}
  /* Cards: sólidas y legibles + borde de vidrio (highlight interno) + sombra en
     capas (ambient+key) + esquinas concéntricas grandes. */
  body.mac .card{background:rgba(255,255,255,.94)!important;border:.5px solid rgba(16,24,40,.08)!important;
    border-radius:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 1px 2px rgba(16,24,40,.05),0 16px 42px -18px rgba(16,24,40,.22)}
  body.mac .card:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 1px 2px rgba(16,24,40,.06),0 28px 64px -22px rgba(16,24,40,.3)}
  /* Botones secundarios e inputs de vidrio (el .btn primario y el toggle conservan su color). */
  body.mac .tbtn,body.mac button:not(.cedccy):not(.btn){background:rgba(255,255,255,.66);
    -webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);
    border:.5px solid rgba(16,24,40,.1);border-radius:11px;box-shadow:inset 0 1px 0 rgba(255,255,255,.85),0 1px 2px rgba(16,24,40,.06)}
  body.mac .tbtn:hover,body.mac button:not(.cedccy):not(.btn):hover{background:rgba(255,255,255,.92);transform:translateY(-1px)}
  body.mac .btn{border-radius:11px;box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 1px 2px rgba(16,24,40,.06)}
  body.mac input,body.mac select{background:rgba(255,255,255,.82)!important;border:.5px solid rgba(16,24,40,.12)!important;
    border-radius:11px;box-shadow:inset 0 1px 2px rgba(16,24,40,.05)}
  body.mac input:focus,body.mac select:focus{border-color:var(--accent)!important;
    box-shadow:0 0 0 4px rgba(91,184,212,.30),inset 0 1px 2px rgba(16,24,40,.04)!important}
  /* Hover/selección con tinte del acento (no gris plano). */
  body.mac .moverrow:hover{background:rgba(91,184,212,.10)!important;transform:translateX(2px)}
  /* Badges con borde de vidrio fino. */
  body.mac .badge,body.mac .RICH,body.mac .FAIR,body.mac .CHEAP{box-shadow:inset 0 0 0 .5px rgba(16,24,40,.07)}
  /* Lectura/decisión y bloques de agente con superficie y esquinas de vidrio. */
  body.mac .decision{background:rgba(255,255,255,.9)!important;border-radius:16px}
  body.mac .agent{border-radius:12px}
  /* Movimiento spring (overshoot sutil, sensación 120Hz) + entrada glassy de las vistas. */
  body.mac .tbtn,body.mac .btn,body.mac button,body.mac .card,body.mac .moverrow,body.mac nav.tabsnav a{
    transition:transform .34s cubic-bezier(.34,1.45,.6,1),background-color .25s ease,
      box-shadow .3s cubic-bezier(.2,.7,.3,1),border-color .22s ease,color .18s ease!important}
  body.mac .view{animation:macglass .46s cubic-bezier(.2,.8,.2,1)}
  @keyframes macglass{from{opacity:0;transform:translateY(10px) scale(.985);filter:blur(2px)}to{opacity:1;transform:none;filter:none}}
  /* ============ Jerarquía + legibilidad (armonía Apple) ============ */
  /* Números hero grandes pero con peso medio (SF semibold, no black) y cifras
     tabulares — el look de número de Apple, no el bloque pesado. */
  body.mac .big{font-size:30px;font-weight:600;letter-spacing:-.4px;color:var(--accent);
    font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
  body.mac .cmp-price{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}
  body.mac .statusbar b{color:#15151a;font-weight:600}
  /* Datos de tablas en negro intenso, peso normal (legible sin engrosar). */
  body.mac table .mono,body.mac .moverrow .mono,body.mac table td{color:#1d1d1f;font-weight:500}
  body.mac .moverrow .tk{color:#15151a;font-weight:600}
  /* Porcentuales SIEMPRE verde/rojo (gana sobre el negro de tabla de arriba). */
  body.mac .chg-up,body.mac .mono.chg-up{color:var(--buy)!important}
  body.mac .chg-dn,body.mac .mono.chg-dn{color:var(--sell)!important}
  /* Pills de estado: tinte + borde fino, peso medio. */
  body.mac .badge,body.mac .RICH,body.mac .FAIR,body.mac .CHEAP{
    font-weight:640;border-radius:7px;padding:3px 9px;letter-spacing:.3px;
    box-shadow:inset 0 0 0 1px rgba(16,24,40,.08)}
  body.mac .FAIR{background:rgba(130,130,140,.14)!important;color:#54545e!important}
  /* Headers de card y labels un punto más oscuros para que no se pierdan. */
  body.mac .card h2{color:#15151a;font-weight:640;letter-spacing:.45px}
  body.mac .lbl{color:#6e6e78}
  body.mac .stance{color:#6e6e78}
  /* ============================================================
     MAC APPLE OSCURO (4º tema) — el mismo Mac blanco pero en graphite
     dark estilo macOS dark mode. Mismas formas, mismo movimiento, mismo
     Liquid Glass; cambia la piel a oscuro. Colores de marca intactos
     (celeste + dorado, que sobre oscuro lucen vivos). Aditivo: todo bajo
     `body.macdark`, no toca los otros tres temas. El logo NO se invierte
     (el wordmark original es claro y va perfecto sobre oscuro).
     ============================================================ */
  body.macdark{
    /* Grafito bien oscuro (diferenciado del tema uno), barras en negro fuerte. */
    --bg:#0e0e10; --panel:#171719; --panel2:#141416; --border:#28282d;
    --text:#f5f5f7; --muted:#9a9aa2; --accent:#5BB8D4; --accent2:#D4B86A;
    --buy:#32d74b; --hold:#e0a92a; --sell:#ff453a;
    --rich:#ff9f3a; --cheap:#4fc3df; --fair:#98989d;
    font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue",system-ui,sans-serif;
    letter-spacing:.1px; color:var(--text);
    font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1,"cv01" 1;
    background:
      radial-gradient(130% 90% at 100% 0%,rgba(91,184,212,.07) 0%,rgba(91,184,212,0) 48%),
      radial-gradient(130% 90% at 0% 100%,rgba(212,184,106,.05) 0%,rgba(212,184,106,0) 48%),
      linear-gradient(180deg,#161619 0%,#0b0b0d 100%) fixed!important}
  /* Barra superior y nav: NEGRO fuerte (vidrio casi opaco, como el tema uno). */
  body.macdark .topbar,body.macdark nav.tabsnav{background:rgba(0,0,0,.64)!important;
    -webkit-backdrop-filter:saturate(170%) blur(28px);backdrop-filter:saturate(170%) blur(28px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 1px 0 rgba(0,0,0,.7)!important;border:0!important}
  body.macdark .statusbar{background:rgba(0,0,0,.62)!important;
    -webkit-backdrop-filter:saturate(170%) blur(22px);backdrop-filter:saturate(170%) blur(22px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.045)!important;border:0!important}
  /* Barra de horarios: casi negra con el verdoso del tema uno (#0b0e0d). */
  body.macdark .mktbar,body.macdark .wtape,body.macdark .tape{background:rgba(11,14,13,.62)!important;
    -webkit-backdrop-filter:saturate(150%) blur(16px);backdrop-filter:saturate(150%) blur(16px);
    border-color:rgba(255,255,255,.05)!important}
  body.macdark .topbar .brand{color:#f5f5f7;letter-spacing:.4px}
  body.macdark .topbar .brand b{color:var(--accent)}
  body.macdark .topbar .brand-word{filter:none}
  body.macdark .topbar .logo{box-shadow:0 1px 3px rgba(0,0,0,.5)}
  body.macdark nav.tabsnav a{color:var(--muted);border-radius:8px 8px 0 0;font-weight:600}
  body.macdark nav.tabsnav a.active{color:var(--accent);border-bottom:2px solid var(--accent)}
  /* Cards graphite flotantes: superficie translúcida + borde de vidrio + sombra honda. */
  body.macdark .card,body.macdark .glass-card,body.macdark section.card,body.macdark .panel{
    background:rgba(23,23,27,.78)!important;border:.5px solid rgba(255,255,255,.07)!important;
    border-radius:18px;-webkit-backdrop-filter:saturate(150%) blur(20px);backdrop-filter:saturate(150%) blur(20px);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.045),0 1px 2px rgba(0,0,0,.5),0 16px 42px -18px rgba(0,0,0,.9)}
  body.macdark .card:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.09),0 1px 2px rgba(0,0,0,.4),0 28px 64px -22px rgba(0,0,0,.8)}
  body.macdark .card h2{font-size:12px;color:#f5f5f7;font-weight:640;letter-spacing:.45px}
  /* Inputs y botones de vidrio oscuro; foco con halo del acento. */
  body.macdark input,body.macdark select,body.macdark #view-dividendos input,body.macdark #view-dividendos select{
    background:rgba(32,32,37,.62)!important;border:.5px solid rgba(255,255,255,.09)!important;
    border-radius:11px;color:var(--text)!important;box-shadow:inset 0 1px 2px rgba(0,0,0,.5)}
  body.macdark input:focus,body.macdark select:focus{border-color:var(--accent)!important;
    box-shadow:0 0 0 4px rgba(91,184,212,.30),inset 0 1px 2px rgba(0,0,0,.3)!important}
  body.macdark .tbtn,body.macdark button:not(.cedccy):not(.btn){background:rgba(32,32,37,.62);
    -webkit-backdrop-filter:blur(12px) saturate(160%);backdrop-filter:blur(12px) saturate(160%);
    border:.5px solid rgba(255,255,255,.09);border-radius:11px;color:var(--text);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 1px 2px rgba(0,0,0,.5)}
  body.macdark .tbtn:hover,body.macdark button:not(.cedccy):not(.btn):hover{background:rgba(44,44,50,.74);transform:translateY(-1px)}
  body.macdark .btn{border-radius:11px;box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 1px 2px rgba(0,0,0,.4)}
  body.macdark .pill{background:rgba(32,32,37,.55);color:var(--muted)}
  /* Filas y tablas con separadores hairline claros sobre oscuro. */
  body.macdark .moverrow{border-bottom:1px solid rgba(255,255,255,.06)}
  body.macdark .moverrow:hover{background:rgba(91,184,212,.12)!important;transform:translateX(2px)}
  body.macdark table th,body.macdark table.argT th{background:rgba(255,255,255,.03)!important;color:var(--muted)}
  body.macdark table td,body.macdark table.argT td{border-top:1px solid rgba(255,255,255,.06)}
  /* Scrollbars oscuras. */
  body.macdark *{scrollbar-color:#4a4a4e transparent}
  body.macdark *::-webkit-scrollbar-thumb{background:#4a4a4e}
  body.macdark *::-webkit-scrollbar-thumb:hover{background:#5e5e64}
  /* Lectura/decisión y bloques de agente con superficie de vidrio oscura. */
  body.macdark .decision{background:rgba(23,23,27,.84)!important;border-radius:16px}
  body.macdark .agent{border-radius:12px}
  body.macdark .live{color:var(--buy)}
  body.macdark .deskfoot,body.macdark .deskfoot a,body.macdark .deskfoot .copy,body.macdark .foot{color:var(--muted)}
  body.macdark .mktbar .mk .nm,body.macdark .mk-marq-inner .nm,body.macdark .mk-fixed .nm{color:#f0f0f2}
  body.macdark .mktbar .mk .ct{color:var(--muted)}
  body.macdark .mktbar .mk.open .ct{color:var(--buy)}
  /* Movimiento spring idéntico al Mac blanco (sensación 120Hz). */
  body.macdark .card,body.macdark .tbtn,body.macdark .btn,body.macdark button,body.macdark .moverrow,body.macdark nav.tabsnav a{
    transition:transform .34s cubic-bezier(.34,1.45,.6,1),background-color .25s ease,
      box-shadow .3s cubic-bezier(.2,.7,.3,1),border-color .22s ease,color .18s ease!important}
  body.macdark input,body.macdark select{transition:background-color .22s ease,border-color .22s ease,box-shadow .28s cubic-bezier(.2,.7,.3,1)}
  body.macdark .tbtn:active,body.macdark .btn:active,body.macdark button:active{transform:scale(.97)}
  body.macdark nav.tabsnav a:hover{transform:translateY(-1px)}
  body.macdark .view{animation:macglass .46s cubic-bezier(.2,.8,.2,1)}
  body.macdark .card{animation:macrise .4s cubic-bezier(.2,.7,.3,1) both}
  /* Jerarquía + legibilidad (misma armonía Apple, sobre oscuro). */
  body.macdark .big{font-size:30px;font-weight:600;letter-spacing:-.4px;color:var(--accent);
    font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}
  body.macdark .cmp-price{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}
  body.macdark .statusbar b{color:#f5f5f7;font-weight:600}
  body.macdark table .mono,body.macdark .moverrow .mono,body.macdark table td{color:#e8e8ec;font-weight:500}
  body.macdark .moverrow .tk{color:#f5f5f7;font-weight:600}
  body.macdark .chg-up,body.macdark .mono.chg-up{color:var(--buy)!important}
  body.macdark .chg-dn,body.macdark .mono.chg-dn{color:var(--sell)!important}
  body.macdark .badge,body.macdark .RICH,body.macdark .FAIR,body.macdark .CHEAP{
    font-weight:640;border-radius:7px;padding:3px 9px;letter-spacing:.3px;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
  body.macdark .FAIR{background:rgba(152,152,157,.18)!important;color:#c2c2c8!important}
  body.macdark .lbl,body.macdark .stance{color:var(--muted)}
  body.macdark .err{color:#ff6b61!important;background:rgba(255,69,58,.12)!important;border-color:rgba(255,69,58,.35)!important}
  *{box-sizing:border-box}
  body{margin:0;background:var(--bg);color:var(--text);padding-bottom:34px;
    font:12.5px/1.45 "SF Mono",ui-monospace,Menlo,Consolas,"Cascadia Code",monospace;}
  /* Scrollbars al tono de la terminal (no el slider blanco del navegador) */
  *{scrollbar-width:thin;scrollbar-color:var(--border) transparent}
  *::-webkit-scrollbar{width:9px;height:9px}
  *::-webkit-scrollbar-track{background:transparent}
  *::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}
  *::-webkit-scrollbar-thumb:hover{background:var(--accent)}
  code,.mono{font-family:"SF Mono",ui-monospace,Menlo,Consolas,monospace}
  /* ===== Chrome estilo terminal (topbar / nav / statusbar) ===== */
  .topbar{display:flex;align-items:center;gap:14px;padding:5px 12px;background:#000;
    border-bottom:1px solid var(--border);position:sticky;top:0;z-index:9;font-size:11.5px}
  .topbar .logo{width:22px;height:22px;border-radius:3px;background:linear-gradient(135deg,var(--accent),var(--accent2));
    display:grid;place-items:center;font-weight:800;color:#000;font-size:13px}
  .topbar .brand{font-weight:700;letter-spacing:1px;color:var(--text)}
  .topbar .brand b{color:var(--accent)}
  .topbar .brand-word{height:18px;width:auto;display:block}
  .topbar .brand-terminal{font-weight:700;letter-spacing:2.5px;color:var(--text);font-size:12px;border-left:1px solid var(--border);padding-left:12px}
  .mini-mark{height:11px;width:11px;vertical-align:-2px;margin-right:5px;display:inline-block}
  /* Command bar */
  .cmdbar{position:relative;flex:1;max-width:540px;display:flex;align-items:center;gap:7px;
    background:var(--panel2);border:1px solid var(--border);border-radius:3px;padding:3px 9px}
  .cmdbar:focus-within{border-color:var(--accent)}
  .cmd-prompt{color:var(--accent);font-weight:700}
  .cmdbar input{flex:1;background:transparent;border:0;outline:none;color:var(--text);font-family:inherit;font-size:11.5px;min-width:0}
  .cmd-hint{font-size:10.5px;color:var(--muted);white-space:nowrap;max-width:230px;overflow:hidden;text-overflow:ellipsis}
  .cmd-help{position:absolute;top:calc(100% + 6px);left:0;z-index:40;min-width:400px;
    background:var(--panel);border:1px solid var(--accent);border-radius:5px;box-shadow:0 10px 36px rgba(0,0,0,.5);
    padding:10px 13px;font-size:11px;line-height:1.8;color:var(--text)}
  .cmd-help code{color:var(--accent2);font-family:inherit}
  .cmd-help .muted{color:var(--muted)}
  .topbar .desk{color:var(--muted);letter-spacing:1.5px;font-size:10.5px;border-left:1px solid var(--border);padding-left:14px}
  .topbar .spacer{flex:1}
  .topbar .live{color:var(--buy);font-weight:700;display:flex;align-items:center;gap:5px;letter-spacing:.5px}
  .topbar .live .dot{width:7px;height:7px;border-radius:50%;background:var(--buy);animation:livepulse 1.6s infinite}
  @keyframes livepulse{0%,100%{opacity:1}50%{opacity:.2}}
  .topbar .clock{color:var(--text);font-variant-numeric:tabular-nums;letter-spacing:.5px}
  .chip{font-size:10.5px;color:var(--muted);border:1px solid var(--border);border-radius:3px;padding:3px 8px;background:var(--panel)}
  .pill{font-size:10.5px;color:var(--muted);border:1px solid var(--border);border-radius:3px;padding:3px 8px;background:var(--panel)}
  .tbtn{cursor:pointer;color:var(--muted);border:1px solid var(--border);background:transparent;
    padding:3px 9px;border-radius:3px;font-size:10.5px;font-family:inherit;transition:.12s}
  .tbtn:hover{color:var(--accent);border-color:var(--accent)}
  nav.tabsnav{display:flex;gap:2px;padding:0 8px;background:#000;border-bottom:1px solid var(--border);
    overflow-x:auto;position:sticky;top:33px;z-index:8}
  nav.tabsnav a{padding:7px 13px;font-size:10.5px;letter-spacing:1px;color:var(--muted);cursor:pointer;
    text-decoration:none;border-bottom:2px solid transparent;white-space:nowrap;text-transform:uppercase}
  nav.tabsnav a:hover{color:var(--text)}
  nav.tabsnav a.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}
  .statusbar{position:fixed;left:0;right:0;bottom:0;z-index:9;display:flex;flex-wrap:wrap;align-items:center;gap:18px;
    padding:4px 12px;background:#000;border-top:1px solid var(--border);font-size:10.5px;color:var(--muted);letter-spacing:.5px}
  .statusbar .spacer{flex:1}
  .statusbar b{color:var(--text);font-weight:700}
  .statusbar .ok{color:var(--buy);font-weight:700}
  .statusbar .amber{color:var(--accent);font-weight:700}
  .dotbg{position:fixed;inset:0;z-index:-1;pointer-events:none;
    background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.025) 1px, transparent 0);background-size:34px 34px;
    -webkit-mask-image:radial-gradient(ellipse 85% 75% at 50% 42%, #000 30%, transparent 100%);
    mask-image:radial-gradient(ellipse 85% 75% at 50% 42%, #000 30%, transparent 100%)}
  .scanbg{position:fixed;left:0;right:0;height:180px;z-index:-1;pointer-events:none;
    background:linear-gradient(180deg, transparent, rgba(91,184,212,.04), transparent);animation:scanbg 9s linear infinite}
  @keyframes scanbg{0%{top:-180px}100%{top:100%}}

  /* Modal de detalle del historial */
  .modal-overlay{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.62);
    display:none;align-items:center;justify-content:center;padding:5vh 16px;overflow-y:auto}
  .modal-box{background:var(--panel);border:1px solid var(--accent);border-radius:5px;
    max-width:840px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 12px 48px rgba(0,0,0,.6)}
  .modal-head{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--border);
    position:sticky;top:0;background:var(--panel);z-index:1}
  .modal-head .mtitle{flex:1;font-weight:700;color:var(--accent);font-size:11px;letter-spacing:1px;text-transform:uppercase;
    display:flex;align-items:center;gap:7px}
  .modal-head .mtitle img{height:13px;width:13px}
  .modal-body{padding:14px;display:flex;flex-direction:column;gap:12px}
  .row-del{cursor:pointer;color:var(--muted);font-weight:700;padding:2px 7px;border-radius:3px;font-size:12px}
  .row-del:hover{color:var(--sell);background:rgba(230,72,58,.14)}
  /* Comparar 2 activos */
  /* Inputs de la calculadora de dividendos: full negro con los números a color
     (el blanco default del browser pegaba un fogonazo en el theme oscuro). */
  #view-dividendos input[type=number], #view-dividendos select{
    background:var(--bg);border:1px solid var(--border);border-radius:3px;
    color:var(--accent);font-family:inherit;font-size:12.5px;font-weight:600;
    padding:7px 10px;outline:none;transition:border-color .15s}
  #view-dividendos input[type=number]:focus, #view-dividendos select:focus{border-color:var(--accent)}
  /* Inputs de las calculadoras del tab Argentina */
  #view-argentina input[type=number], #view-argentina select{
    background:var(--bg);border:1px solid var(--border);border-radius:3px;
    color:var(--text);font-family:inherit;font-size:12.5px;font-weight:600;
    padding:7px 10px;outline:none;transition:border-color .15s}
  #view-argentina input[type=number]:focus, #view-argentina select:focus{border-color:var(--accent)}
  #view-argentina .bondrow:hover{background:var(--panel2)}
  /* Tablas compactas y alineadas del panel Argentina */
  #view-argentina table.argT{width:100%;border-collapse:collapse;font-size:11.5px}
  #view-argentina table.argT th{padding:6px 10px;font-size:9.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);position:sticky;top:0;background:var(--panel)}
  #view-argentina table.argT td{padding:4px 10px;border-top:1px solid #161616}
  #view-argentina table.argT .tk{font-weight:700}
  #view-argentina table.argT .mono{font-variant-numeric:tabular-nums}
  /* Card del análisis de dividendo: borde acentuado para que no pase desapercibida */
  #divAnCard{border-color:color-mix(in srgb, var(--accent) 40%, var(--border))}
  #divAnCard h2{color:var(--accent)}
  .cmp-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  @media(max-width:640px){.cmp-grid{grid-template-columns:1fr}}
  .cmp-col{border:1px solid var(--border);border-radius:4px;background:var(--panel2);padding:11px 13px}
  .cmp-head{border-bottom:1px solid var(--border);padding-bottom:7px;margin-bottom:9px}
  .cmp-price{font-size:20px;font-weight:800;color:var(--accent)}
  /* LAB */
  .lab-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}
  @media(max-width:900px){.lab-grid{grid-template-columns:1fr}}
  .bt-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:8px;margin-top:12px}
  .bt-metric{border:1px solid var(--border);border-radius:4px;background:var(--panel2);padding:9px 11px}
  .bt-metric .l{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
  .bt-metric .v{font-size:18px;font-weight:800;margin-top:2px}
  .macro-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(115px,1fr));gap:8px;margin-bottom:12px}
  .macro-tile{border:1px solid var(--border);border-radius:4px;background:var(--panel2);padding:9px 11px}
  .macro-tile .l{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
  .macro-tile .v{font-size:17px;font-weight:800;color:var(--accent);margin-top:2px}
  .cal-row{display:flex;gap:8px;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px}
  .cal-row .d{color:var(--muted);font-size:10.5px;white-space:nowrap;min-width:90px}
  .cal-row .imp{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;text-transform:uppercase}
  .cal-row .imp.high{background:rgba(230,72,58,.16);color:var(--sell)}
  .cal-row .imp.medium{background:rgba(232,130,30,.16);color:var(--accent)}
  /* Vistas full-screen (tabs) */
  .view{max-width:1680px;margin:0 auto;padding:10px}
  /* Panel de configuración (GUÍA) */
  .cfg-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-top:12px}
  .cfg-l{display:block;font-size:10.5px;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
  .cfg-l .muted{text-transform:none;letter-spacing:0}
  #view-guia input{width:100%;background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:3px;padding:7px 10px;font-size:11.5px;font-family:inherit}
  #view-guia input:focus{outline:none;border-color:var(--accent)}
  .merc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:8px;align-items:stretch}
  /* Mercados prolijo: columnas de ancho y ALTURA uniformes, scroll SOLO vertical */
  #mercadosGrid .card{display:flex;flex-direction:column}
  #mercadosGrid .card .body{height:62vh;overflow-y:auto;overflow-x:hidden}
  #mercadosGrid table{table-layout:fixed;width:100%}
  #mercadosGrid td,#mercadosGrid th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  /* Historial full-screen más cómodo */
  #historyTable2 td{padding:7px 12px;font-size:12px}
  #historyTable2 td:nth-child(8){max-width:520px}
  #view-movers .moverrow{padding:6px 12px}
  /* Autocompletado de inputs sueltos (backtest, etc.) */
  .ac-dd{position:absolute;top:calc(100% + 3px);left:0;z-index:45;min-width:230px;max-height:250px;overflow:auto;
    background:var(--panel);border:1px solid var(--border);border-radius:4px;box-shadow:var(--shadow)}
  .ac-opt{padding:6px 10px;cursor:pointer;font-size:12px;white-space:nowrap;display:flex;gap:7px;align-items:center}
  .ac-opt:hover{background:var(--panel2)}
  .ac-opt .nm{color:var(--muted);font-size:11px;overflow:hidden;text-overflow:ellipsis}

  /* ===== Grilla densa de 3 columnas ===== */
  /* ANÁLISIS atraviesa las dos filas: así las cards de macro quedan pegadas
     debajo de MERCADOS y MOVERS aunque el análisis sea largo (antes la fila 1
     crecía con el análisis y las macro se despegaban hacia abajo). */
  main{max-width:1680px;margin:0 auto;padding:10px;display:grid;gap:8px;
    grid-template-columns:minmax(300px,340px) minmax(0,1fr) minmax(280px,330px);
    grid-template-rows:auto 1fr;
    grid-template-areas:"panel analyze movers" "gmac analyze amac" "history history history";align-items:start}
  #panelCard{grid-area:panel} #analyzeCard{grid-area:analyze} #moversCard{grid-area:movers}
  #dashGlobalMacro{grid-area:gmac} #dashMacroAR{grid-area:amac}
  #historyCard{grid-area:history}
  @media(max-width:1200px){main{grid-template-columns:minmax(280px,1fr) minmax(0,1.4fr);grid-template-rows:auto auto auto 1fr;
    grid-template-areas:"panel analyze" "movers analyze" "gmac analyze" "amac analyze" "history history"}}
  @media(max-width:860px){main{grid-template-columns:1fr;
    grid-template-areas:"panel" "analyze" "movers" "gmac" "amac" "history"}}
  .card{background:var(--panel);border:1px solid var(--border);border-radius:3px;box-shadow:none}
  .card h2{font-size:10.5px;text-transform:uppercase;letter-spacing:1.2px;color:var(--accent);
    margin:0;padding:6px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:7px;font-weight:700}
  .card h2::before{content:"▸";opacity:.7}
  .card .body{padding:10px}
  .btn{cursor:pointer;border:1px solid var(--border);background:var(--panel2);color:var(--text);
    border-radius:3px;padding:7px 11px;font-size:11.5px;font-family:inherit;transition:.12s}
  .btn:hover{border-color:var(--accent);color:var(--accent)}
  .btn.primary{background:var(--accent);border:1px solid var(--accent);color:#000;font-weight:700}
  .btn.primary:hover{background:var(--accent2);border-color:var(--accent2);color:#000}
  .btn.active{border-color:var(--accent);color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--panel2))}
  .btn:disabled{opacity:.5;cursor:not-allowed}
  select{background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:3px;
    padding:7px 10px;font-size:11.5px;font-family:inherit;min-width:120px}
  .row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

  /* Combobox buscable (selector de activos) */
  .combo{position:relative;min-width:260px}
  .combo input{width:100%;background:var(--panel2);color:var(--text);border:1px solid var(--border);
    border-radius:9px;padding:9px 32px 9px 12px;font-size:13px}
  .combo input:focus{outline:none;border-color:var(--accent)}
  .combo .caret{position:absolute;right:11px;top:50%;transform:translateY(-50%);color:var(--muted);
    pointer-events:none;font-size:11px}
  .combo-dd{position:absolute;top:calc(100% + 5px);left:0;right:0;z-index:30;max-height:360px;overflow-y:auto;
    background:var(--panel);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow)}
  .combo-dd .grp{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);
    padding:8px 12px 4px;position:sticky;top:0;background:var(--panel);font-weight:700}
  .combo-opt{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;font-size:13px}
  .combo-opt:hover,.combo-opt.active{background:var(--panel2)}
  .combo-opt .tk{font-weight:700}
  .combo-opt .nm{color:var(--muted);font-size:11px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .combo-empty{padding:14px 12px;color:var(--muted);font-size:12px;text-align:center}
  .star{cursor:pointer;color:var(--muted);font-size:15px;line-height:1;user-select:none;flex-shrink:0}
  .star:hover{color:var(--hold)}
  .star.on{color:var(--hold)}
  /* Tira de favoritos */
  #watchStrip:empty{display:none}
  .wchip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;
    background:var(--panel2);border:1px solid var(--border);border-radius:999px;padding:5px 10px;cursor:pointer}
  .wchip:hover{border-color:var(--accent)}
  .wchip .x{color:var(--muted);font-weight:400;font-size:13px;line-height:1}
  .wchip .x:hover{color:var(--sell)}
  .watch-hint{font-size:11px;color:var(--muted)}

  /* Panel table */
  .tabs{display:flex;flex-wrap:wrap;gap:4px;padding:10px 12px;border-bottom:1px solid var(--border)}
  .tab{cursor:pointer;border:1px solid var(--border);background:var(--panel2);color:var(--muted);
    border-radius:8px;padding:6px 11px;font-size:12px;transition:.12s}
  .tab:hover{color:var(--text)}
  .tab.active{background:var(--accent);border-color:var(--accent);color:#04121e;font-weight:700}
  .chg-up{color:var(--buy)} .chg-dn{color:var(--sell)}
  .tape{overflow:hidden;border-bottom:1px solid var(--border);background:var(--panel);white-space:nowrap}
  .tape-inner{display:inline-block;padding:7px 0;animation:marquee 80s linear infinite}
  .tape:hover .tape-inner{animation-play-state:paused}
  @keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
  .tape .it{display:inline-block;padding:0 16px;font-size:12px;font-family:"SF Mono",ui-monospace,monospace;color:var(--muted)}
  .tape .it b{color:var(--text)}
  .moverrow{padding:7px 14px;border-bottom:1px solid var(--border);cursor:pointer;font-size:13px}
  .moverrow:hover{background:var(--panel2)}
  .banner{display:flex;gap:14px;align-items:baseline;flex-wrap:wrap;padding:9px 12px;border-bottom:1px solid var(--border)}
  .banner .big{font-size:18px;font-weight:800;letter-spacing:.5px;color:var(--accent)}
  .banner .lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
  table{width:100%;border-collapse:collapse;font-size:11.5px}
  th,td{text-align:right;padding:4px 10px;border-bottom:1px solid var(--border)}
  th{color:var(--muted);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.6px;cursor:pointer}
  th:first-child,td:first-child{text-align:left}
  tbody tr:hover{background:var(--panel2)}
  tbody tr{cursor:pointer}
  .tk{font-weight:700}
  /* Nombre del activo en los quote boards: una sola línea (altura de fila uniforme) */
  .qname{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
  .qname .qn{color:var(--muted);font-size:11px;margin-left:5px}
  /* Quote boards: precio y día% nunca se parten (la flecha queda junto al %) */
  #quoteTable td, #quoteTable th{white-space:nowrap}
  /* Panel CCL: compacto para que entre en su recuadro (4 columnas + barra) */
  #panelTable td, #panelTable th{padding:4px 6px;white-space:nowrap}
  #panelTable .qname{max-width:116px}
  #panelTable .disbar{min-width:32px}
  .badge{display:inline-block;font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.4px}
  .RICH{background:rgba(240,136,62,.16);color:var(--rich)}
  .CHEAP{background:rgba(43,182,196,.16);color:var(--cheap)}
  .FAIR{background:rgba(125,136,150,.16);color:var(--fair)}
  .disbar{height:6px;border-radius:4px;background:var(--panel2);position:relative;overflow:hidden;min-width:60px}
  .disbar > span{position:absolute;top:0;bottom:0;left:50%}

  /* Analyze */
  .status{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:13px;min-height:20px}
  .spinner{width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);
    border-radius:50%;animation:spin .8s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
  .stream{display:flex;flex-direction:column;gap:12px;margin-top:14px}
  .agent{border:1px solid var(--border);border-radius:3px;background:var(--panel);overflow:hidden;
    animation:fade .35s ease}
  @keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
  .agent .head{display:flex;align-items:center;gap:8px;padding:10px 14px;border-bottom:1px solid var(--border);
    font-weight:700;font-size:13px}
  .agent .head .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
  .agent .txt{padding:12px 14px;color:#d4dde7;font-size:13px;white-space:pre-wrap}
  .agent.constructive .dot{background:var(--buy)} .agent.cautious .dot{background:var(--sell)}
  .agent.neutral .dot{background:var(--hold)}
  .agent.bull .dot{background:var(--buy)} .agent.bear .dot{background:var(--sell)}
  .stance{margin-left:auto;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
  .debate{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  @media(max-width:600px){.debate{grid-template-columns:1fr}}
  .bull{border-color:rgba(46,160,67,.4)} .bear{border-color:rgba(248,81,73,.4)}
  .bull .head{color:var(--buy)} .bear .head{color:var(--sell)}
  .chips{display:flex;flex-wrap:wrap;gap:6px}
  .chip{font-size:11px;color:var(--muted);background:var(--panel);border:1px solid var(--border);
    border-radius:8px;padding:5px 9px;max-width:100%}
  .riskgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
  @media(max-width:600px){.riskgrid{grid-template-columns:1fr}}
  .riskbox{border:1px solid var(--border);border-radius:9px;padding:9px 11px;background:var(--panel)}
  .riskbox .t{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:4px}

  /* Decision */
  .decision{margin-top:16px;border-radius:4px;padding:18px;border:1px solid var(--border);
    background:var(--panel);animation:fade .4s ease;position:relative;overflow:hidden}
  .decision::after{content:"";position:absolute;right:-34px;top:-34px;width:170px;height:170px;
    background:url(/logo-orbital.svg) no-repeat center/contain;opacity:.05;pointer-events:none}
  .decision > *{position:relative;z-index:1}
  .decision .action{font-size:30px;font-weight:900;letter-spacing:1px;display:flex;align-items:center;gap:12px}
  /* Badge Flowdex reutilizable: chico por defecto (headers de analistas), grande en la decisión */
  .fdx-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;
    background:rgba(232,130,30,.16);color:var(--accent);padding:2px 7px;border-radius:3px;
    letter-spacing:.5px;vertical-align:middle;white-space:nowrap;margin-left:6px}
  .fdx-badge img{height:9px;width:9px;display:block}
  .fdx-badge.lg{font-size:14px;padding:5px 12px;gap:7px;border-radius:4px;letter-spacing:1.5px;margin-left:0}
  .fdx-badge.lg img{height:16px;width:16px}
  /* Mark orbital inline (reemplaza al rayito): hereda el color del texto via currentColor */
  .fdx-mark{display:inline-block;width:.95em;height:.95em;vertical-align:-0.12em;margin:0 1px;
    background:currentColor;-webkit-mask:url(/logo-orbital.svg) center/contain no-repeat;
    mask:url(/logo-orbital.svg) center/contain no-repeat}
  .decision.BUY{border-color:var(--buy);box-shadow:0 0 0 1px rgba(46,160,67,.3) inset}
  .decision.SELL{border-color:var(--sell);box-shadow:0 0 0 1px rgba(248,81,73,.3) inset}
  .decision.HOLD{border-color:var(--hold);box-shadow:0 0 0 1px rgba(210,153,34,.3) inset}
  .decision.BUY .action{color:var(--buy)} .decision.SELL .action{color:var(--sell)} .decision.HOLD .action{color:var(--hold)}
  .stars{font-size:18px;letter-spacing:2px;color:var(--hold)}
  .rationale{margin-top:10px;color:#d4dde7;font-size:13.5px}
  /* Lectura Flowdex — tablero de estado (reemplaza el badge BUY/SELL) */
  .reading{margin-top:16px;border:1px solid var(--border);border-radius:4px;padding:18px 20px;background:var(--panel)}
  .rd-head{display:flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.5px;color:var(--muted);padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:14px}
  .rd-head .rd-title{font-weight:800;letter-spacing:1.5px;color:#e6edf3}
  .rd-head .tk{font-weight:700;color:#e6edf3}
  .rd-board{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);border:1px solid var(--border);border-radius:3px;padding:2px 7px;margin-left:2px}
  .rd-ejes{display:flex;flex-direction:column;gap:9px}
  .rd-eje{display:flex;align-items:baseline;gap:10px;font-size:14px}
  .rd-eje .rd-sym{font-size:13px;width:18px;flex:none;text-align:center}
  .rd-eje .rd-lbl{color:var(--muted);min-width:90px}
  .rd-eje .rd-state{font-weight:800;letter-spacing:.6px}
  .rd-fuerza .rd-dots{letter-spacing:3px;color:var(--accent);font-size:15px;vertical-align:-1px}
  .rd-fuerza .rd-fnote{color:var(--muted);font-weight:400;font-size:12px;letter-spacing:.3px;text-transform:none;margin-left:8px}
  .rd-lentes-title{margin:18px 0 9px;font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
  .rd-lentes{display:flex;flex-direction:column;gap:7px}
  .rd-lente{display:flex;align-items:baseline;gap:10px;font-size:13px;color:#d4dde7}
  .rd-lente .rd-sym{font-size:12px;width:18px;flex:none;text-align:center}
  .rd-lente .rd-lname{font-weight:700;min-width:150px;color:#e6edf3}
  .rd-lente .rd-lnote{color:var(--muted);font-size:12.5px}
  .rd-lectura{margin-top:16px;padding-top:14px;border-top:1px solid var(--border);color:#d4dde7;font-size:13.5px;line-height:1.55}
  .rd-disc{margin-top:14px;font-size:10.5px;color:var(--muted)}
  .err{border:1px solid var(--sell);background:rgba(248,81,73,.08);color:#ffb3ae;border-radius:10px;padding:12px 14px;font-size:13px}
  .empty{color:var(--muted);font-size:13px;text-align:center;padding:26px}
  .foot{max-width:1280px;margin:0 auto;padding:8px 22px 30px;color:var(--muted);font-size:11.5px}
  /* Semáforo de sesión por activo */
  .sess-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.5px;
    border:1px solid var(--border);border-radius:3px;padding:4px 8px;text-transform:uppercase}
  .sess-badge .sess-dot{width:7px;height:7px;border-radius:50%}
  .sess-badge.on{color:var(--buy);border-color:rgba(51,177,87,.45)}
  .sess-badge.on .sess-dot{background:var(--buy);animation:livepulse 1.6s infinite}
  .sess-badge.off{color:var(--muted)} .sess-badge.off .sess-dot{background:var(--muted)}
  /* Exportar a PDF (imprimir solo el análisis) */
  @media print{
    .topbar,nav.tabsnav,.tape,.statusbar,.foot,#moversCard,#panelCard,#historyCard,
    #cmdForm,.btn,.tbtn,#watchStrip,#progressWrap,#sessionBadge,.status,#howBox{display:none !important}
    body{background:#fff !important;color:#000 !important}
    main{display:block !important;max-width:100% !important;padding:0 !important}
    #analyzeCard{border:0 !important}
    .agent,.decision,.card{break-inside:avoid;border-color:#ccc !important}
    .agent,.decision,.txt,.rationale{color:#000 !important}
  }

  /* ===== Dashboard armonizado: MERCADOS y TOP MOVERS = misma ventana ===== */
  :root{--dash-card-h:600px}
  /* Ambas cards laterales con la MISMA altura total; el cuerpo scrollea y rellena */
  #panelCard, #moversCard{height:var(--dash-card-h);display:flex;flex-direction:column}
  #panelCard > h2, #panelCard .tabs, #moversCard > h2{flex:none}
  #panelCard #cclView, #panelCard #quoteView{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}
  #moversCard .body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}
  #panelCard thead th{position:sticky;top:0;z-index:3;background:var(--panel)}
  /* Las dos macros del dashboard: misma altura entre sí, cuerpo con scroll interno */
  :root{--dash-macro-h:235px}
  #dashGlobalMacro, #dashMacroAR{height:var(--dash-macro-h);display:flex;flex-direction:column}
  #dashGlobalMacro > h2, #dashMacroAR > h2{flex:none}
  #dashGlobalMacro .body, #dashMacroAR .body{flex:1 1 auto;min-height:0;overflow-y:auto;overflow-x:hidden}
  /* Columnas idénticas y alineadas en TODOS los tabs (arregla el desfase de Índices) */
  #quoteTable{table-layout:fixed}
  #quoteTable th:nth-child(2),#quoteTable td:nth-child(2){width:104px}
  #quoteTable th:nth-child(3),#quoteTable td:nth-child(3){width:74px}
  #quoteTable td,#quoteTable th{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:11.5px}
  /* Panel CCL: layout fijo para que entren las 4 columnas sin recortar ESTADO */
  #panelTable{table-layout:fixed;width:100%}
  #panelTable th:nth-child(2),#panelTable td:nth-child(2){width:66px}
  #panelTable th:nth-child(3),#panelTable td:nth-child(3){width:100px}
  #panelTable th:nth-child(4),#panelTable td:nth-child(4){width:58px;text-align:right}
  #panelTable td,#panelTable th{overflow:hidden;text-overflow:ellipsis}
  /* Tipografia/densidad de filas unificada entre quote boards y movers */
  #moversCard .moverrow{font-size:11.5px;padding:5px 12px}
  #moversCard .moverrow .tk{font-size:11.5px}
  /* Columna activa de orden: resaltada en acento, con la flechita ▲/▼ */
  th.sorted{color:var(--accent)}
  th{user-select:none}
  .mktbar{display:flex;flex-wrap:wrap;align-items:center;gap:5px 22px;padding:6px 16px;background:#0b0e0d;border-bottom:1px solid var(--border);font-size:12px;letter-spacing:.3px}
  .mktbar .mk{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
  .mktbar .mk .d{width:7px;height:7px;border-radius:50%;background:#3a3a3a;flex:none}
  .mktbar .mk.open .d{background:#7DD4C0;box-shadow:0 0 6px rgba(125,212,192,.7)}
  .mktbar .mk .nm{color:#e2e2e2;font-weight:700}
  .mktbar .mk .ct{color:#8c8c8c;font-variant-numeric:tabular-nums}
  .mktbar .mk.open .ct{color:#7DD4C0}
  /* Marquee de más bolsas internacionales, en el mismo renglón que las fijas */
  .mktbar{flex-wrap:nowrap}
  .mk-fixed{display:inline-flex;align-items:center;gap:5px 22px;flex:none}
  .mk-sep{color:#2c2c2c}
  .mk-sep-main{color:#3a3a3a;padding:0 6px;flex:none}
  .mk-marq{flex:1 1 0;min-width:0;overflow:hidden}
  .mk-marq-inner{display:inline-flex;align-items:center;gap:0 20px;white-space:nowrap;animation:mktmarq 90s linear infinite;will-change:transform}
  .mk-marq:hover .mk-marq-inner{animation-play-state:paused}
  @keyframes mktmarq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.fxa-overlay{display:none;position:fixed;inset:0;z-index:99999;background:#070707;overflow:hidden;
  align-items:center;justify-content:center;font-family:'DM Sans',system-ui,sans-serif;color:#e6e6e6}
.fxa-mono{font-family:ui-monospace,'Cascadia Code',Menlo,Consolas,monospace}
.fxa-bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.035) 1px, transparent 0);
  background-size:34px 34px;
  -webkit-mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, #000 40%, transparent 100%);
  mask-image:radial-gradient(ellipse 70% 70% at 50% 50%, #000 40%, transparent 100%)}
.fxa-scan{position:absolute;left:0;right:0;height:140px;z-index:0;pointer-events:none;
  background:linear-gradient(180deg, transparent, rgba(91,184,212,.05), transparent);animation:fxa-scan 7s linear infinite}
@keyframes fxa-scan{0%{top:-140px}100%{top:100%}}
.fxa-tape{position:absolute;left:0;right:0;z-index:0;white-space:nowrap;overflow:hidden;font-size:11px;color:#1c1c1c;letter-spacing:1px;user-select:none}
.fxa-tape.top{top:18px}.fxa-tape.bot{bottom:18px}
.fxa-tape span{display:inline-block;padding-left:100%;animation:fxa-marq 38s linear infinite}
.fxa-tape.bot span{animation-duration:46s;animation-direction:reverse}
@keyframes fxa-marq{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
.fxa-card{position:relative;z-index:2;width:360px;max-width:92vw;background:#0d0d0d;border:1px solid #262626;
  border-radius:12px;padding:34px 30px 26px;text-align:center;box-shadow:0 30px 80px -30px rgba(0,0,0,.9)}
.fxa-triada{position:absolute;top:0;left:24px;right:24px;height:2px;border-radius:2px;opacity:.9;
  background:linear-gradient(90deg,#5BB8D4 0 33%,#7DD4C0 33% 66%,#D4B86A 66% 100%);
  transform:scaleX(0);transform-origin:left;animation:fxa-draw .9s .15s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes fxa-draw{to{transform:scaleX(1)}}
.fxa-eyebrow{font-size:10.5px;letter-spacing:2.5px;color:#555;text-transform:uppercase;margin-bottom:18px}
.fxa-cur{display:inline-block;width:7px;height:13px;background:#5BB8D4;margin-left:3px;vertical-align:-2px;animation:fxa-blink 1.1s steps(1) infinite}
@keyframes fxa-blink{50%{opacity:0}}
.fxa-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:6px}
.fxa-wordmark{width:190px;max-width:76%;height:auto;opacity:.97;animation:fxa-rise .6s .15s both}
.fxa-desk{font-weight:800;letter-spacing:9px;font-size:14px;color:#5BB8D4;padding-left:9px;line-height:1}
.fxa-sub{font-size:10.5px;color:#777;letter-spacing:1px;margin:14px 0 22px}
.fxa-field{margin-bottom:12px;text-align:left;animation:fxa-rise .6s both}
.fxa-field.f1{animation-delay:.25s}.fxa-field.f2{animation-delay:.33s}
@keyframes fxa-rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.fxa-lab{display:block;font-size:9.5px;letter-spacing:1.5px;color:#555;text-transform:uppercase;margin:0 0 6px 2px}
.fxa-inp{width:100%;background:#121212;border:1px solid #2c2c2c;border-radius:7px;color:#e6e6e6;
  padding:11px 13px;font-family:'DM Sans',system-ui,sans-serif;font-size:14px;outline:none;transition:.15s}
.fxa-inp::placeholder{color:#444}
.fxa-inp:focus{border-color:#5BB8D4;box-shadow:0 0 0 3px rgba(91,184,212,.12)}
.fxa-btn{width:100%;border:none;border-radius:7px;padding:12px;font-family:'DM Sans',system-ui,sans-serif;
  font-size:14px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:.15s;animation:fxa-rise .6s .42s both}
.fxa-btn.primary{background:#5BB8D4;color:#04222c}
.fxa-btn.primary:hover{filter:brightness(1.08);box-shadow:0 0 22px -6px rgba(91,184,212,.5)}
.fxa-btn.primary:disabled{opacity:.6;cursor:default;box-shadow:none}
.fxa-sep{display:flex;align-items:center;gap:10px;color:#555;font-size:10px;letter-spacing:1px;margin:16px 0;animation:fxa-rise .6s .5s both}
.fxa-sep::before,.fxa-sep::after{content:"";height:1px;background:#262626;flex:1}
.fxa-btn.google{background:#121212;color:#e6e6e6;border:1px solid #2c2c2c;font-weight:500;
  display:flex;align-items:center;justify-content:center;gap:10px;animation-delay:.56s}
.fxa-btn.google:hover{border-color:#3a3a3a;background:#161616}
.fxa-btn.google svg{width:17px;height:17px}
.fxa-toggle{display:block;margin-top:18px;font-size:11px;color:#777;text-decoration:none;letter-spacing:.5px;cursor:pointer;animation:fxa-rise .6s .62s both}
.fxa-toggle b{color:#5BB8D4;font-weight:500}
.fxa-msg{font-size:11.5px;color:#D4B86A;min-height:15px;margin-top:12px;letter-spacing:.3px}
.fxa-foot{margin-top:18px;font-size:9.5px;color:#3a3a3a;letter-spacing:1.5px}
/* ---- Pantalla de carga del Desk (mismo theme que el login) ---- */
.fxb-bar{height:8px;background:#121212;border:1px solid #2c2c2c;border-radius:5px;overflow:hidden;margin:20px 0 8px}
.fxb-fill{height:100%;width:0%;border-radius:4px;background:linear-gradient(90deg,#5BB8D4,#7DD4C0);
  box-shadow:0 0 14px -2px rgba(91,184,212,.55);transition:width .3s cubic-bezier(.2,.7,.2,1)}
.fxb-row{display:flex;justify-content:space-between;font-size:10.5px;color:#777;letter-spacing:1px}
.fxb-log{margin-top:14px;text-align:left;font-size:10px;color:#555;letter-spacing:.5px;min-height:66px;line-height:1.9}
.fxb-log .ok{color:#7DD4C0}
.fxa-overlay.fxb-out{opacity:0;transition:opacity .5s ease}

  .deskfoot{max-width:1180px;margin:0 auto;padding:26px 22px 40px;text-align:center;color:var(--muted);font-size:11.5px;line-height:1.6}
  .deskfoot a{color:var(--muted);text-decoration:none;transition:color .15s}
  .deskfoot a:hover{color:var(--accent)}
  .deskfoot .ftrow{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 14px;margin-bottom:12px}
  .deskfoot .sep{color:#2a2a2a}
  .deskfoot .partners{color:var(--accent2)}
  .deskfoot .partners:hover{color:#e2ce92}
  .deskfoot .secure{color:var(--teal,#7DD4C0);font-weight:700;font-size:11px;margin-bottom:6px}
  .deskfoot .disc{font-size:10px;line-height:1.65;color:#6a6a6a;max-width:920px;margin:0 auto 10px}
  .deskfoot .copy{font-size:10.5px;color:#8a8a8a}
  .deskfoot .dama{display:inline-block;margin-top:14px;font-size:10px;font-style:italic;letter-spacing:.5px;color:#3f3f3f}
  .deskfoot .dama:hover{color:var(--accent2)}

/* ===== Pestaña EMPRESAS ===== */
#view-empresas .emp-head .body{padding:14px 16px}
.emp-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px;flex-wrap:wrap}
.emp-tk{font-size:22px;font-weight:700;letter-spacing:.5px}
.emp-name{font-size:15px;color:var(--muted)}
.emp-kind{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--accent2);border:1px solid var(--border);border-radius:4px;padding:2px 7px;white-space:nowrap}
.emp-meta{margin-top:6px;font-size:12px;color:var(--accent)}
.emp-summary{margin-top:8px;font-size:12px;line-height:1.6;color:var(--muted)}
.emp-note{font-size:12.5px;color:var(--muted);line-height:1.6}
.emp-chart-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:6px}
.emp-chart-price{font-size:20px;font-weight:700}
.emp-chart-chg{font-size:13px;font-weight:600;margin-left:4px}
.emp-chart-chg.up{color:var(--buy)} .emp-chart-chg.dn{color:var(--sell)}
.emp-ranges{display:flex;gap:4px}
.emp-range{background:transparent;border:1px solid var(--border);color:var(--muted);border-radius:4px;padding:3px 9px;font-size:11px;cursor:pointer;font-family:inherit}
.emp-range:hover{border-color:var(--accent2);color:var(--accent2)}
.emp-range.on{background:var(--accent2);border-color:var(--accent2);color:#06231e;font-weight:700}
.emp-chart{position:relative;width:100%;height:300px}
.emp-chart-cur{font-size:10.5px;color:var(--muted);margin-top:4px;text-align:right}
.emp-ctip{position:absolute;z-index:30;background:var(--panel2,#11161d);border:1px solid var(--border);border-radius:5px;padding:5px 8px;font-size:11px;font-family:ui-monospace,monospace;pointer-events:none;line-height:1.4;box-shadow:0 4px 14px rgba(0,0,0,.4)}
.emp-mcap{font-size:13px;color:var(--muted);margin-bottom:12px}
.emp-group{margin-bottom:14px}
.emp-gtitle{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent2);margin-bottom:7px;border-bottom:1px solid var(--border);padding-bottom:4px}
.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.emp-metric{background:var(--panel2,rgba(255,255,255,.02));border:1px solid var(--border);border-radius:6px;padding:8px 10px;cursor:help;transition:border-color .15s}
.emp-metric:hover{border-color:var(--accent2)}
.emp-mlabel{font-size:10.5px;color:var(--muted);margin-bottom:3px;line-height:1.25}
.emp-mval{font-size:17px;font-weight:700;font-variant-numeric:tabular-nums}
.emp-mbench{font-size:9.5px;color:var(--muted);margin-top:2px;line-height:1.2}
.emp-src{font-size:10.5px;color:var(--muted);margin-top:6px;font-style:italic}
.emp-tip{position:absolute;z-index:9999;max-width:290px;background:var(--panel2,#11161d);border:1px solid var(--accent2);border-radius:6px;padding:8px 11px;font-size:11.5px;line-height:1.5;box-shadow:0 6px 22px rgba(0,0,0,.5);pointer-events:none}
.emp-tip .muted{color:var(--muted)}
.emp-scoregrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.emp-scorecard{border:1px solid var(--border);border-radius:7px;padding:11px 12px;background:var(--panel2,rgba(255,255,255,.02))}
.emp-collap .emp-schead{cursor:pointer}
.emp-schead{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600}
.emp-scbig{margin-left:auto;font-size:22px;font-weight:800;font-variant-numeric:tabular-nums}
.emp-scmax{font-size:12px;color:var(--muted);font-weight:600}
.emp-chev{color:var(--muted);font-size:11px}
.emp-scsub{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.5}
.emp-checks{margin-top:9px;display:flex;flex-direction:column;gap:5px}
.emp-check{display:flex;gap:7px;font-size:11.5px;line-height:1.35;align-items:flex-start}
.emp-cmark{font-weight:800;width:13px;flex:none;text-align:center}
.emp-check.ok .emp-cmark{color:var(--buy)} .emp-check.no .emp-cmark{color:var(--muted)} .emp-check.nd .emp-cmark{color:var(--muted)}
.emp-cnote{display:block;color:var(--muted);font-size:10.5px;margin-top:1px}
.emp-flags-card{border-color:var(--sell)}
.emp-flags-intro,.emp-noflags{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:10px}
.emp-noflags{margin-bottom:0}
.emp-flag{border-left:3px solid var(--sell);padding:6px 0 6px 11px;margin-bottom:9px}
.emp-flag-t{font-size:12.5px;font-weight:700;color:var(--sell)}
.emp-flag-n{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:2px}
.emp-sankey-intro{font-size:12px;color:var(--muted);line-height:1.6;margin-bottom:10px}
.emp-sankey{width:100%;height:auto;max-height:280px}
.emp-sankey .sankey-lbl{font-size:10px;fill:var(--muted);font-family:ui-monospace,monospace}
.emp-radar{width:280px;height:280px;flex:none}
.emp-radar .radar-grid{fill:none;stroke:var(--border)}
.emp-radar .radar-spoke{stroke:var(--border)}
.emp-radar .radar-lbl{fill:var(--muted);font-size:11px;font-family:ui-monospace,monospace}
.emp-radar .radar-area{fill:color-mix(in srgb, var(--accent2) 35%, transparent);stroke:var(--accent2);stroke-width:2}
.emp-radar-note{font-size:11.5px;color:var(--muted);line-height:1.6;flex:1;min-width:200px}
#empDropdown .combo-opt .tk{font-weight:700;margin-right:8px}
#empDropdown .combo-opt .nm{color:var(--muted);font-size:12px}
/* Perfil: descripción + tabla de datos */
.emp-profile-cols{display:grid;grid-template-columns:1fr 280px;gap:18px;margin-top:8px;align-items:start}
.emp-facts{border-collapse:collapse;font-size:11.5px;width:100%}
.emp-facts td{padding:3px 0;border-bottom:1px solid var(--border);vertical-align:top}
.emp-facts .ef-k{color:var(--muted);padding-right:12px;white-space:nowrap}
.emp-facts .ef-v{text-align:right}
.emp-link{color:var(--accent2);text-decoration:none}
.emp-link:hover{text-decoration:underline}
@media(max-width:760px){.emp-profile-cols{grid-template-columns:1fr}}
/* Layout 2 columnas (fundamentals | scores) */
.emp-cols{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);gap:8px;align-items:start}
.emp-cols>div{min-width:0}
.emp-col-side .emp-scorecard{margin-bottom:8px}
@media(max-width:900px){.emp-cols{grid-template-columns:1fr}}
.sankey-amt{fill:var(--muted)}
/* Buscador: badge del universo */
.emp-search-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.emp-universe{font-size:11.5px;color:var(--muted);white-space:nowrap}
.emp-universe b{color:var(--accent2);font-size:13px}
/* Noticias */
.emp-news-item{display:block;padding:8px 0;border-bottom:1px solid var(--border);text-decoration:none;color:inherit}
.emp-news-item:last-of-type{border-bottom:none}
.emp-news-item:hover .emp-news-t{color:var(--accent2)}
.emp-news-t{font-size:12.5px;line-height:1.4}
.emp-news-m{font-size:10.5px;color:var(--muted);margin-top:2px}
.emp-news-foot{font-size:10px;color:var(--muted);font-style:italic;margin-top:8px}
/* Brasil: calculadoras de preço justo */
.emp-calc-intro{font-size:11.5px;color:var(--muted);line-height:1.5;margin-bottom:10px}
.emp-calc{display:flex;align-items:baseline;gap:10px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;margin-bottom:7px;cursor:help;background:var(--panel2,rgba(255,255,255,.02))}
.emp-calc:hover{border-color:var(--accent2)}
.emp-calc-name{font-size:12px;font-weight:700;width:64px;flex:none}
.emp-calc-fair{font-size:17px;font-weight:700;font-variant-numeric:tabular-nums}
.emp-calc-up{font-size:11px;margin-left:auto;font-weight:600}
.emp-calc-foot{font-size:10.5px;color:var(--muted);margin-top:4px;font-variant-numeric:tabular-nums}
/* Brasil: proventos */
.emp-prov-head{display:flex;align-items:baseline;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.emp-prov-dy{font-size:14px} .emp-prov-dy b{color:var(--buy);font-size:18px}
.emp-prov-cols{display:grid;grid-template-columns:1fr 200px;gap:16px;align-items:end}
.emp-prov-chart{display:flex;align-items:flex-end;gap:8px;height:120px;border-bottom:1px solid var(--border);padding-bottom:2px}
.emp-prov-bar{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.emp-prov-fill{width:60%;max-width:34px;background:var(--accent2);border-radius:3px 3px 0 0;min-height:2px}
.emp-prov-yr{font-size:10px;color:var(--muted);margin-top:3px}
.emp-prov-val{font-size:9.5px;color:var(--muted);font-variant-numeric:tabular-nums}
.emp-prov-table{width:100%;border-collapse:collapse;font-size:11px}
.emp-prov-table th{color:var(--muted);font-weight:600;padding:2px 0;border-bottom:1px solid var(--border)}
.emp-prov-table td{padding:3px 0;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums}
.emp-prov-foot{font-size:10px;color:var(--muted);font-style:italic;margin-top:8px}
@media(max-width:760px){.emp-prov-cols{grid-template-columns:1fr}}
/* Sub-pestañas (Brasil) */
.subnav{display:flex;gap:2px;margin-bottom:14px;border-bottom:1px solid var(--border)}
.subnav a{padding:8px 16px;font-size:11px;letter-spacing:1.5px;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;text-decoration:none;font-weight:600}
.subnav a:hover{color:var(--accent2)}
.subnav a.active{color:var(--accent2);border-bottom-color:var(--accent2)}
/* Panel "cómo leer" de Dividendos */
.div-howto{display:grid;grid-template-columns:1fr 1fr;gap:8px 18px;margin-top:11px}
.div-howto-item{font-size:11px;color:var(--muted);line-height:1.5;padding-left:11px;border-left:2px solid var(--border)}
.div-howto-item b{color:var(--text,#e8eef5)}
.amber-note{color:var(--rich)}
@media(max-width:760px){.div-howto{grid-template-columns:1fr}}

/* ===== PULSO (sentiment de mercado, amurallado de la Lectura) ===== */
.pulse-intro{font-size:12px;line-height:1.6;color:var(--muted);background:var(--panel2);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:6px;padding:11px 14px}
.pulse-intro b{color:var(--text,#e8eef5)}
.pulse-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:16px}
.pulse-block h3{font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--text,#e8eef5);margin:0 0 2px}
.pulse-cap{font-size:11px;color:var(--muted);margin-bottom:8px}
.pulse-fng{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:14px 16px}
.pf-head{display:flex;align-items:center;gap:14px}
.pf-num{font-size:40px;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}
.pf-lab{font-size:15px;font-weight:700}
.pf-cap{font-size:10.5px;color:var(--muted);margin-top:2px}
.pf-bar{position:relative;height:10px;border-radius:6px;margin:16px 0 6px;background:linear-gradient(90deg,var(--sell) 0%,var(--hold) 35%,var(--fair) 50%,var(--buy) 80%)}
.pf-marker{position:absolute;top:-3px;width:4px;height:16px;border-radius:2px;background:#fff;box-shadow:0 0 0 2px rgba(0,0,0,.45);transform:translateX(-50%)}
.pf-scale{display:flex;justify-content:space-between;font-size:10px;color:var(--muted)}
.pulse-table{width:100%;border-collapse:collapse}
.pulse-table th{font-size:10.5px;color:var(--muted);font-weight:600;text-align:right;padding:4px 6px;border-bottom:1px solid var(--border)}
.pulse-table td{font-size:12px;text-align:right;padding:5px 6px;border-bottom:1px solid var(--border)}
.pulse-table tr.clk{cursor:pointer}
.pulse-table tr.clk:hover{background:var(--panel2)}
.pulse-table .qn{color:var(--muted);font-size:10.5px}
.pulse-chips{display:flex;flex-wrap:wrap;gap:7px}
.pulse-chip{font-size:11.5px;background:var(--panel2);border:1px solid var(--border);border-radius:14px;padding:4px 10px}
.pulse-chip .qn{color:var(--muted)}
.pulse-rank{color:var(--accent);font-size:10px}
.apulse{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:11.5px;color:var(--muted);background:var(--panel2);border:1px dashed var(--border);border-radius:6px;padding:7px 11px}
.apulse-tag{font-size:9px;letter-spacing:1px;font-weight:700;color:var(--accent);border:1px solid var(--accent);border-radius:3px;padding:1px 5px}
.apulse-body b{color:var(--text,#e8eef5)}
.apulse-note{margin-left:auto;font-size:10px;font-style:italic;opacity:.75}
@media(max-width:760px){.pulse-grid{grid-template-columns:1fr}.apulse-note{margin-left:0}}
/* Pulso v2 — termómetros equity-first + componentes + risk-on/off */
.pulse-therms{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;margin-top:16px;align-items:start}
.pulse-therm-side{display:flex;flex-direction:column;gap:12px}
.pf-contra{display:flex;justify-content:space-between;font-size:9.5px;color:var(--muted);font-style:italic;margin-top:4px;opacity:.85}
.pf-comps{margin-top:14px;border-top:1px solid var(--border);padding-top:11px}
.pf-comps-h{font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.pf-comp{display:grid;grid-template-columns:1fr 64px 92px;align-items:center;gap:9px;margin-bottom:6px;font-size:11px}
.pfc-lab{color:var(--text,#e8eef5)}
.pfc-bar{height:6px;border-radius:4px;background:rgba(255,255,255,.05);border:1px solid var(--border);overflow:hidden}
.pfc-fill{display:block;height:100%}
.pfc-rt{text-align:right;font-size:10.5px;font-weight:600}
.pulse-stat{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:13px 15px}
.ps-h{font-size:10.5px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.ps-v{font-size:30px;font-weight:800;line-height:1.1;margin-top:3px;font-variant-numeric:tabular-nums}
.ps-sub{font-size:10.5px;color:var(--muted);margin-top:5px;line-height:1.45}
.ps-sub b{font-weight:700}
.risk-verdict{display:inline-block;font-size:12px;font-weight:700;border:1px solid;border-radius:5px;padding:4px 10px;margin-bottom:10px}
.pulse-cryptostrip{margin-top:18px;border-top:1px dashed var(--border);padding-top:12px;opacity:.92}
.pulse-strip-head{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.pulse-strip-body{margin-top:8px}
@media(max-width:860px){.pulse-therms{grid-template-columns:1fr}}

/* ===== INSIDERS (el dinero que sabe: 13F superinversores + Form 4) ===== */
.ins-section-h{font-size:13px;letter-spacing:.5px;text-transform:uppercase;color:var(--text,#e8eef5);font-weight:700;margin:20px 0 4px;padding-bottom:5px;border-bottom:1px solid var(--border)}
.ins-tracked{display:flex;flex-wrap:wrap;gap:5px;margin:8px 0 12px}
.ins-inv{font-size:10.5px;color:var(--muted);background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:2px 9px;cursor:default}
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:6px}
.ins-card{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:12px 14px}
.ins-card.wide{grid-column:span 1}
.ins-card h3{font-size:12px;letter-spacing:.3px;text-transform:uppercase;color:var(--text,#e8eef5);margin:0 0 1px}
.ins-cap{font-size:10.5px;color:var(--muted);margin-bottom:8px;line-height:1.4}
.ins-table{width:100%;border-collapse:collapse}
.ins-table td{font-size:11.5px;padding:4px 2px;border-bottom:1px solid var(--border);vertical-align:middle}
.ins-table tr:last-child td{border-bottom:0}
.ins-table tr.clk{cursor:pointer}
.ins-table tr.clk:hover{background:rgba(255,255,255,.03)}
.ins-table tr.hl{background:rgba(212,167,44,.10)}
.ins-table tr.hl:hover{background:rgba(212,167,44,.16)}
.ins-nm{text-align:left}
.ins-mt{text-align:right;white-space:nowrap;color:var(--text,#e8eef5)}
.ins-issuer{color:var(--muted);font-size:10px}
.ins-sub{color:var(--muted);font-size:10px}
.ins-star{color:var(--rich,#d4a72c)}
.ins-table.buys th{font-size:10px;color:var(--muted);font-weight:600;text-align:right;padding:3px 6px;border-bottom:1px solid var(--border)}
.ins-table.buys td{padding:5px 6px;text-align:right}
.ins-table.buys td:first-child,.ins-table.buys td:nth-child(2){text-align:left}
.ins-cross{background:linear-gradient(90deg,rgba(212,167,44,.12),transparent);border:1px solid var(--rich,#d4a72c);border-radius:8px;padding:11px 14px;margin:4px 0 14px}
.ins-cross-h{font-size:12px;font-weight:700;color:var(--rich,#d4a72c);margin-bottom:7px}
.ins-cross-body{display:flex;flex-wrap:wrap;gap:7px}
.ins-cross-chip{font-size:11.5px;background:var(--panel2);border:1px solid var(--border);border-radius:13px;padding:3px 10px;cursor:pointer}
.ins-cross-chip:hover{border-color:var(--rich,#d4a72c)}
.ins-inv{cursor:pointer}
.ins-inv:hover{border-color:var(--accent);color:var(--text,#e8eef5)}
/* drill-down: cartera por gestor / holders por acción */
.ins-drill{background:var(--panel2);border:1px solid var(--accent);border-radius:8px;padding:12px 14px;margin:4px 0 14px}
.ins-drill-h{font-size:12.5px;font-weight:700;color:var(--text,#e8eef5);margin-bottom:8px;display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.ins-drill-x{margin-left:auto;font-size:10.5px;font-weight:600;color:var(--muted);background:transparent;border:1px solid var(--border);border-radius:5px;padding:2px 8px;cursor:pointer}
.ins-drill-x:hover{color:var(--sell);border-color:var(--sell)}
.ins-drill-an{font-size:10.5px;font-weight:700;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:5px;padding:2px 9px;cursor:pointer}
.ins-drill .ins-table td{font-size:11.5px}
/* card de insiders por activo (dashboard) */
.aiq{background:var(--panel2);border:1px dashed var(--border);border-radius:6px;padding:8px 11px}
.aiq-head{font-size:11.5px;color:var(--muted);display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px}
.aiq-row{font-size:11px;color:var(--muted);padding:3px 0;border-top:1px solid var(--border)}
@media(max-width:980px){.ins-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.ins-grid{grid-template-columns:1fr}}