:root{
    /* Surfaces */
    --bg:#f6f7fb; --bg-warm:#f8fafc; --panel:#fff;
    /* Ink scale */
    --ink:#0f172a; --ink-soft:#475569; --ink-mute:#64748b; --ink-faint:#94a3b8;
    /* Lines */
    --line:#e5e9f0; --line-2:#eef1f6; --line-strong:#cbd5e1;
    /* Navy scale */
    --navy:#0f172a; --navy-2:#1e293b; --navy-3:#334155;
    /* Brand (action / link / focus) */
    --brand:#4f46e5; --brand-soft:#eef2ff; --brand-dark:#3730a3;
    /* Semantic (frozen palette — no rainbow allowed) */
    --bad:#b91c1c; --bad-ink:#7f1d1d; --bad-soft:#fee2e2; --bad-tint:#fef2f2;
    --warn:#b45309; --warn-ink:#78350f; --warn-soft:#fde68a; --warn-tint:#fef9ed;
    --good:#047857; --good-soft:#d1fae5;
    /* Legacy aliases — kept so the .ms-bar gradient renders as mono navy
       (was cyan→indigo rainbow). Any new use should reference --navy directly. */
    --c1:#1e293b; --c2:#475569; --c3:#94a3b8;
    /* Radii */
    --radius-sm:6px; --radius:10px; --radius-lg:14px; --radius-pill:999px;
    /* Shadows */
    --shadow:0 1px 2px rgba(15,23,42,.04),0 1px 2px rgba(15,23,42,.05);
    --shadow-md:0 4px 14px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.05);
    --shadow-lg:0 10px 30px rgba(15,23,42,.08),0 2px 6px rgba(15,23,42,.06);
    /* Durations — transiciones suaves */
    --duration-fast:120ms; --duration-base:200ms; --duration-slow:300ms;
    /* Typography */
    --font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",system-ui,Roboto,sans-serif;
    --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  }
  *{box-sizing:border-box}
  html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font:14px/1.45 var(--font);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;-webkit-text-size-adjust:100%;text-size-adjust:100%;overflow-x:hidden;max-width:100%}

  /* Badge "Dar de alta" — médicos sin APM propias cruzado */
  .alta-badge{display:inline-flex;align-items:center;gap:4px;background:var(--warn-tint);color:var(--warn-ink);border:1px dashed var(--warn);border-radius:var(--radius-pill);padding:2px 9px 2px 7px;font-size:11px;font-weight:600;white-space:nowrap}
  .alta-badge.sm{font-size:10px;padding:1px 7px 1px 5px;border-radius:var(--radius-sm)}
  .alta-badge .ic{color:var(--warn)}
  /* Toggle "No visitados": off = pill neutra, on = ámbar (mismo lenguaje que el badge alta). */
  .alta-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;background:#fff;border:1px solid var(--line-strong);color:var(--ink);border-radius:7px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
  .alta-filter-btn:hover{border-color:var(--warn);color:var(--warn-ink)}
  .alta-filter-btn .ic{color:var(--warn)}
  .alta-filter-btn.active{background:var(--warn-tint);border-color:var(--warn);color:var(--warn-ink)}

  /* Toggles segmentados en el toolbar (alcance "Mi cartera | Todos" y región) */
  .scope-toggle,.geo-toggle{display:inline-flex;background:var(--bg-warm);border:1px solid var(--line);border-radius:8px;padding:2px;gap:1px;flex-shrink:0;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .scope-toggle::-webkit-scrollbar,.geo-toggle::-webkit-scrollbar{display:none}
  .scope-toggle button,.geo-toggle button{padding:5px 12px;background:transparent;border:none;color:var(--ink-soft);border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;cursor:pointer;white-space:nowrap}
  .scope-toggle button:hover,.geo-toggle button:hover{color:var(--ink)}
  .scope-toggle button.active,.geo-toggle button.active{background:#fff;color:var(--navy);box-shadow:var(--shadow);font-weight:600}
  /* En mobile la franja de regiones es UNA sola fila fina que scrollea horizontal (antes wrapeaba
     a 2 filas y "San Fco" quedaba solo abajo). Ocupa menos alto → el listado sube y se ven más médicos. */
  @media (max-width:780px){ .geo-toggle{flex-wrap:nowrap;overflow-x:auto;width:100%;max-width:100%;justify-content:flex-start} }

  /* ============================================================
     POLISH (subset curado) — animaciones, skeletons y micro-interacciones.
     Scoped a propósito: SIN globals sobre <button>/<table>/letter-spacing
     ni cambios de paleta, para no romper la UI densa ya pulida.
     ============================================================ */
  @keyframes modalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
  @keyframes overlayFadeIn{from{opacity:0}to{opacity:1}}
  @keyframes skeletonPulse{0%,100%{opacity:.6}50%{opacity:1}}
  @keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
  @keyframes slideInRight{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
  @keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

  /* Modal: entrada suave (scoped a .upl-*) */
  .upl-overlay{animation:overlayFadeIn var(--duration-base) ease-out}
  .upl-modal{animation:modalIn var(--duration-base) cubic-bezier(.16,1,.3,1)}

  /* Micro-interacciones SCOPED (nada de "button" global) */
  .apm-btn{transition:background var(--duration-base) ease-out,box-shadow var(--duration-base) ease-out}
  .apm-item{transition:border-color var(--duration-fast) ease-out,background var(--duration-fast) ease-out}
  .alta-filter-btn{transition:border-color var(--duration-fast) ease-out,color var(--duration-fast) ease-out,box-shadow var(--duration-fast) ease-out}
  .scope-toggle button,.geo-toggle button{transition:color var(--duration-fast) ease-out,background var(--duration-fast) ease-out,box-shadow var(--duration-fast) ease-out}
  .update-banner button{transition:background var(--duration-fast) ease-out}

  /* Foco visible para teclado (solo :focus-visible → no afecta click con mouse) */
  button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--brand);outline-offset:2px}

  /* Touch targets ≥44px en mobile (scoped a botones de acción, no a todo) */
  @media (max-width:768px){ .apm-btn,.alta-filter-btn,.update-banner button{min-height:44px} }

  /* Skeleton loaders (clases nuevas — se activan desde JS cuando quieras) */
  .skeleton{background:linear-gradient(90deg,var(--line) 0%,var(--line-2) 50%,var(--line) 100%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}
  .skeleton-text{height:14px;margin-bottom:10px;border-radius:var(--radius-sm)}
  .skeleton-title{height:20px;width:60%;margin-bottom:12px;border-radius:var(--radius-sm)}
  .skeleton-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:12px}
  .skeleton-card .skeleton-text:last-child{margin-bottom:0}

  /* Spinner de carga */
  .spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite}

  /* Pill de "ocupado" (ej: generando PDF de una ficha) — feedback mientras corre html2pdf */
  .busy-pill{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(78px + env(safe-area-inset-bottom));z-index:2100;background:var(--navy);color:#fff;border-radius:var(--radius-pill);padding:11px 18px;box-shadow:var(--shadow-lg);display:none;align-items:center;gap:10px;font-size:13px;font-weight:600;max-width:90vw}
  .busy-pill.show{display:inline-flex;animation:modalIn var(--duration-base) ease-out}
  .busy-pill .spinner{border-color:rgba(255,255,255,.3);border-top-color:#fff}
  @media (min-width:781px){ .busy-pill{bottom:24px} }

  /* Estado vacío / error / éxito (clases nuevas) */
  .empty-state{text-align:center;padding:40px 20px;color:var(--ink-mute)}
  .empty-state p{margin:0;line-height:1.6}
  .error-box{background:var(--bad-tint);border:1px solid var(--bad-soft);color:var(--bad-ink);border-radius:var(--radius);padding:16px;display:flex;align-items:flex-start;gap:12px;animation:slideInRight var(--duration-base) ease-out}
  .error-box svg{flex-shrink:0;margin-top:2px}
  .success-box{background:var(--good-soft);border:1px solid var(--good);color:var(--good);border-radius:var(--radius);padding:16px;animation:slideInRight var(--duration-base) ease-out}

  /* Barra de progreso para exports */
  .export-progress{width:100%;height:4px;background:var(--line);border-radius:2px;overflow:hidden;margin:12px 0}
  .export-progress-bar{height:100%;background:var(--brand);width:0;transition:width .3s ease-out}
  .export-progress.indeterminate .export-progress-bar{background:linear-gradient(90deg,var(--brand),var(--brand-dark),var(--brand));background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}

  /* Banner "versión nueva disponible" */
  .update-banner{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(78px + env(safe-area-inset-bottom));z-index:1900;background:var(--navy);color:#fff;border-radius:var(--radius-pill);padding:10px 16px;box-shadow:var(--shadow-lg);display:none;align-items:center;gap:12px;font-size:13px;max-width:92vw}
  .update-banner.show{display:inline-flex}
  .update-banner button{background:var(--brand);color:#fff;border:none;border-radius:var(--radius-pill);padding:7px 14px;font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap}
  .update-banner button:hover{background:var(--brand-dark)}
  .update-banner .x{background:transparent;color:#94a3b8;padding:4px 8px}
  @media (min-width:781px){ .update-banner{bottom:24px} }

  /* "Mi cartera" — botón de identidad APM en el header */
  .apm-btn{background:rgba(255,255,255,.06);border:1px solid rgba(148,163,184,.22);color:#fff;padding:7px 12px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;max-width:200px}
  .apm-btn:hover{background:rgba(255,255,255,.12);border-color:rgba(148,163,184,.35)}
  .apm-btn #apm-btn-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .apm-btn .ic{color:#cbd5e1;flex-shrink:0}
  /* Picker de APM (reusa el overlay del modal de carga) */
  .apm-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
  .apm-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:9px;padding:12px 14px;font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}
  .apm-item:hover{border-color:var(--line-strong);background:var(--bg-warm)}
  .apm-item.active{border-color:var(--brand);background:var(--brand-soft);color:var(--brand-dark)}
  .apm-item .ic{color:var(--ink-soft)}
  .apm-item.active .ic{color:var(--brand)}
  .apm-item .check{margin-left:auto;color:var(--brand)}
  .apm-all{width:100%;text-align:center;background:#fff;border:1px dashed var(--line-strong);border-radius:9px;padding:11px 14px;font-size:13px;font-weight:500;color:var(--ink-soft);cursor:pointer}
  .apm-all:hover{border-color:var(--brand);color:var(--brand)}

  /* Modal de carga múltiple de exports (principal + giras) */
  .upl-overlay{position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:2000;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;backdrop-filter:blur(3px)}
  .upl-overlay.open{display:flex}
  .upl-modal{background:#fff;border-radius:var(--radius-lg);max-width:560px;width:100%;box-shadow:var(--shadow-lg);overflow:hidden}
  .upl-head{padding:18px 22px;background:var(--navy);color:#fff;display:flex;justify-content:space-between;align-items:center}
  .upl-head h2{margin:0;font-size:17px;font-weight:600;display:flex;align-items:center;gap:9px}
  .upl-close{background:transparent;border:none;color:#cbd5e1;font-size:22px;cursor:pointer;line-height:1;padding:2px 6px;border-radius:var(--radius-sm)}
  .upl-close:hover{background:var(--navy-2);color:#fff}
  .upl-body{padding:18px 22px;max-height:calc(100vh - 230px);overflow-y:auto}
  .upl-intro{font-size:13px;color:var(--ink-soft);line-height:1.5;margin-bottom:16px}
  .upl-file{border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px;margin-bottom:10px;background:var(--bg-warm)}
  .upl-file .fn{font-size:13px;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:7px;margin-bottom:9px;word-break:break-all}
  .upl-file .fn .cnt{margin-left:auto;font-size:11px;color:var(--ink-faint);font-weight:500;white-space:nowrap;flex-shrink:0}
  .upl-file .fn .ic{color:var(--ink-soft);flex-shrink:0}
  .upl-zone{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
  .upl-zone label{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--ink);cursor:pointer;white-space:nowrap}
  .upl-zone input[type=radio]{accent-color:var(--brand);margin:0}
  .upl-zone input[type=text]{flex:1;min-width:140px;border:1px solid var(--line);border-radius:7px;padding:8px 10px;font:13px/1 var(--font);color:var(--ink);outline:none;height:36px}
  .upl-zone input[type=text]:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .upl-zone input[type=text]:disabled{background:var(--line-2);color:var(--ink-faint)}
  .upl-hint{font-size:11.5px;color:var(--ink-faint);margin-top:10px;line-height:1.5;display:flex;gap:6px;align-items:flex-start}
  .upl-foot{padding:14px 22px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px;background:#fff}
  .upl-foot button{padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
  .upl-foot .ghost{background:#fff;border:1px solid var(--line);color:var(--ink)}
  .upl-foot .ghost:hover{border-color:var(--line-strong)}
  .upl-foot .primary{background:var(--brand);border:1px solid var(--brand);color:#fff}
  .upl-foot .primary:hover{background:var(--brand-dark)}
  /* Resultado de carga + generador de deploy (showMergeResult) */
  .dg-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
  .dg-stat{background:var(--bg-warm);border:1px solid var(--line);border-radius:9px;padding:10px 8px;text-align:center}
  .dg-stat .n{display:block;font-size:18px;font-weight:700;color:var(--ink);line-height:1.1}
  .dg-stat .l{display:block;font-size:11px;color:var(--ink-soft);margin-top:3px}
  .dg-zonas{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
  .dg-zonas li{display:flex;justify-content:space-between;align-items:center;font-size:12.5px;color:var(--ink);background:var(--bg-warm);border:1px solid var(--line);border-radius:7px;padding:6px 10px}
  .dg-zonas li .tabular{color:var(--ink-soft)}
  .dg-deploy{margin-top:16px;background:var(--brand-soft);border:1px solid #bfd4ff;border-left:3px solid var(--brand);border-radius:9px;padding:12px 14px}
  .dg-deploy .t{font-size:12.5px;font-weight:700;color:var(--brand-dark);display:flex;align-items:center;gap:6px;margin-bottom:6px}
  .dg-deploy p{font-size:12.5px;color:var(--ink);line-height:1.5;margin:0 0 10px}
  .dg-deploy code{background:#fff;border:1px solid var(--line);padding:1px 5px;border-radius:4px;font-family:var(--font-mono);font-size:11px}
  .dg-deploy .deploy-actions{display:flex;flex-wrap:wrap;gap:8px}
  .dg-deploy button.primary,.dg-deploy button.secondary{padding:9px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
  .dg-deploy button.primary{background:var(--brand);border:1px solid var(--brand);color:#fff}
  .dg-deploy button.primary:hover{background:var(--brand-dark)}
  .dg-deploy button.secondary{background:#fff;border:1px solid var(--line-strong);color:var(--ink)}
  .dg-deploy button.secondary:hover{border-color:var(--brand);color:var(--brand-dark)}
  .dg-deploy button.primary:disabled,.dg-deploy button.secondary:disabled{opacity:.7;cursor:default}
  @media (max-width:480px){ .dg-stats{grid-template-columns:repeat(2,1fr)} }
  .dg-pass-l{display:block;font-size:12px;font-weight:600;color:var(--ink);margin:4px 0 4px}
  .dg-pass{width:100%;padding:9px 12px;font-size:14px;border:1px solid var(--line-strong);border-radius:8px;font-family:var(--font-mono);box-sizing:border-box}
  .dg-pass:focus{outline:none;border-color:var(--brand)}
  .dg-pass-h{font-size:11.5px;color:var(--ink-soft);margin:6px 0 10px;line-height:1.45}
  /* Gate de desbloqueo (datos cifrados) */
  .lock-overlay{position:fixed;inset:0;z-index:9000;background:linear-gradient(160deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;padding:24px}
  .lock-card{background:#fff;border-radius:16px;box-shadow:0 25px 60px rgba(0,0,0,.45);padding:30px 26px;width:100%;max-width:340px;text-align:center}
  .lock-logo{display:flex;align-items:center;justify-content:center;gap:8px;font-size:21px;font-weight:700;color:var(--navy)}
  .lock-logo .ic{color:var(--brand)}
  .lock-sub{font-size:12px;color:var(--ink-soft);margin:6px 0 20px}
  .lock-overlay input[type=password]{width:100%;padding:12px 14px;font-size:16px;border:1px solid var(--line-strong);border-radius:var(--radius);text-align:center;box-sizing:border-box}
  .lock-overlay input[type=password]:focus{outline:none;border-color:var(--brand)}
  .lock-remember{display:flex;align-items:center;gap:7px;justify-content:center;font-size:12.5px;color:var(--ink-soft);margin:13px 0;cursor:pointer}
  .lock-overlay button{width:100%;padding:12px;background:var(--brand);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer}
  .lock-overlay button:hover{background:var(--brand-dark)}
  .lock-overlay button:disabled{opacity:.7;cursor:default}
  /* Barra de carga (indeterminada) entre descifrar y primer render — evita pantalla en blanco */
  .lock-loader-bar{margin-top:16px;height:4px;background:#e2e8f0;border-radius:var(--radius-pill);overflow:hidden;position:relative}
  .lock-loader-bar > div{position:absolute;top:0;bottom:0;width:38%;background:linear-gradient(90deg,#1d6094,#60a5fa);border-radius:var(--radius-pill);animation:lock-load 1.1s ease-in-out infinite}
  @keyframes lock-load{0%{left:-40%}100%{left:100%}}
  .lock-err{color:var(--bad);font-size:12.5px;margin-top:10px;min-height:16px}
  /* Toast no bloqueante (reemplaza los alert nativos) — estilo ejecutivo */
  .toast-wrap{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:9500;display:flex;flex-direction:column;gap:8px;align-items:center;max-width:92vw;pointer-events:none}
  .toast{pointer-events:auto;background:#fff;color:var(--ink);border:1px solid var(--line);border-left:3px solid var(--ink-soft);border-radius:var(--radius);padding:11px 15px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:flex-start;gap:9px;max-width:440px;line-height:1.45;white-space:pre-line;animation:toastIn .2s ease}
  .toast .ic{flex-shrink:0;margin-top:1px;color:var(--ink-soft)}
  .toast.success{border-left-color:#16a34a}
  .toast.success .ic{color:#16a34a}
  .toast.error{border-left-color:var(--bad)}
  .toast.error .ic{color:var(--bad)}
  .toast.info{border-left-color:var(--brand)}
  .toast.info .ic{color:var(--brand)}
  .toast.hide{animation:toastOut .18s ease forwards}
  @keyframes toastIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
  @keyframes toastOut{to{opacity:0;transform:translateY(8px)}}
  @media (max-width:780px){ .toast-wrap{bottom:84px;left:8px;right:8px;transform:none;align-items:stretch} .toast{max-width:none} }
  /* Tendencia MES vs TRIM (flechas ↑/↓) */
  .trend{display:inline-flex;align-items:center;vertical-align:middle}
  .trend .ic{width:13px;height:13px}
  .trend.up{color:#16a34a}
  .trend.down{color:var(--bad)}
  .trend.flat{color:var(--ink-faint);font-weight:700;font-size:11px}
  .mkt-trend{display:inline-flex;align-items:center;gap:3px;padding:1px 9px 1px 6px;border-radius:var(--radius-pill);font-size:10.5px;font-weight:700;vertical-align:middle;margin-left:7px}
  .mkt-trend .ic{width:13px;height:13px}
  .mkt-trend.up{background:#dcfce7;color:#166534}
  .mkt-trend.down{background:#fee2e2;color:#991b1b}
  .mkt-trend.flat{background:var(--bg-warm);color:var(--ink-soft)}
  /* Chip de tendencia con etiqueta para listas (más visible que el chevron solo) */
  .trend-chip{display:inline-flex;align-items:center;gap:2px;padding:1px 7px 1px 5px;border-radius:var(--radius-pill);font-size:10px;font-weight:600;vertical-align:middle;letter-spacing:.02em}
  .trend-chip .ic{width:12px;height:12px}
  .trend-chip.up{background:#dcfce7;color:#166534}
  .trend-chip.down{background:#fee2e2;color:#991b1b}

  /* Bulk export progress overlay — used by exportFichasMultiPDF when generando
     un PDF unificado de muchas fichas. Cubre toda la pantalla con backdrop blur. */
  .bulk-overlay{position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:2000;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
  .bulk-box{background:#fff;border-radius:var(--radius-lg);padding:28px 36px;text-align:center;max-width:380px;width:90%;box-shadow:0 25px 60px rgba(15,23,42,.4)}
  .bulk-spinner{width:38px;height:38px;margin:0 auto 16px;border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;animation:bulkSpin .8s linear infinite}
  @keyframes bulkSpin{to{transform:rotate(360deg)}}
  .bulk-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px;letter-spacing:-.005em}
  .bulk-status{font-size:13px;color:var(--ink-soft);margin-bottom:16px;min-height:18px}
  .bulk-progress{background:var(--line-2);height:6px;border-radius:var(--radius-pill);overflow:hidden;margin-bottom:6px}
  .bulk-progress-bar{height:100%;background:var(--brand);transition:width .25s ease;border-radius:var(--radius-pill)}
  .bulk-count{font-size:13px;color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
  .bulk-hint{font-size:11px;color:var(--ink-faint);margin-top:12px}

  /* Icon system — single monochrome set (Tabler-style 1.6px stroke).
     Usage: <svg class="ic"><use href="#i-name"/></svg>. Size with .ic-sm/.ic-lg or inline style. */
  .ic{width:16px;height:16px;flex-shrink:0;display:inline-block;vertical-align:-3px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
  .ic-sm{width:13px;height:13px;vertical-align:-2px}
  .ic-lg{width:20px;height:20px;vertical-align:-5px}
  .ic-xl{width:24px;height:24px;vertical-align:-6px}
  /* numbers in the app should be tabular by default */
  .num,.tabular{font-variant-numeric:tabular-nums}
  a{color:var(--brand);text-decoration:none}
  button{font:inherit;cursor:pointer}

  /* Header — compact 56px navy bar, single concatenated context chip. */
  /* padding-top con safe-area: en la PWA instalada (full-screen) la barra de
     estado del iPhone queda sobre el contenido; esto empuja el header debajo.
     En navegador/desktop env() = 0, no afecta. */
  .header{position:sticky;top:0;z-index:40;background:linear-gradient(180deg,#0e6ba8,#0c2a43);color:#fff;border-bottom:1px solid rgba(255,255,255,.14);box-shadow:0 6px 18px -10px rgba(190,18,60,.5);padding-top:env(safe-area-inset-top)}
  /* Header rojo de marca: contraste de los elementos internos sobre fondo rojo */
  .header .brand .sub{color:rgba(255,255,255,.82)}
  .header .doc-btn-header,.header .ghost-btn{color:rgba(255,255,255,.9)}
  .header .doc-btn-header:hover,.header .ghost-btn:hover{background:rgba(255,255,255,.16);color:#fff}
  .header .upload-btn{background:#fff;color:#0c4a6e;border-color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.12)}
  .header .upload-btn:hover{background:#eff6fc;color:#0c4a6e}
  .header .ctx-chip,.header .apm-btn{color:#fff;border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.16)}
  .header-inner{max-width:1600px;margin:0 auto;padding:8px 22px;min-height:58px;display:flex;align-items:center;gap:10px 14px;flex-wrap:wrap}
  /* La fila de acciones ocupa todo el ancho y se alinea a la derecha cuando el header
     envuelve a 2 líneas (antes height:58px fijo recortaba los botones envueltos). */
  .header .header-actions{margin-left:auto}
  .header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
  .header-actions button{white-space:nowrap}
  .brand h1{font-size:16px}
  .ctx-chip{background:rgba(148,163,184,.16);border:1px solid rgba(255,255,255,.12);}
  .nolter-logo{height:34px;width:auto;background:#fff;padding:6px 12px;border-radius:10px;display:block;flex-shrink:0;box-shadow:0 2px 7px rgba(0,0,0,.2);object-fit:contain}
  .brand-div{width:1px;align-self:center;height:34px;background:rgba(255,255,255,.30);flex:none;border-radius:1px;margin:0 3px}
  .brand{display:flex;flex-direction:column;justify-content:center;min-width:0;line-height:1.08}
  .brand h1{margin:0;font-size:17px;font-weight:800;letter-spacing:-.02em;white-space:nowrap;color:#fff}
  .brand-credit{font-size:10px;font-weight:500;color:rgba(255,255,255,.7);margin-top:3px;white-space:nowrap;letter-spacing:.01em}
  .brand-credit b{font-weight:700;color:rgba(255,255,255,.9)}
  .header .spacer{flex:1}
  /* Context chip — concatenated pill: Edición · Mercado · Marca (audit: 3 chips → 1) */
  .ctx-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(148,163,184,.16);color:#cbd5e1;padding:5px 11px;border-radius:var(--radius-pill);font-size:12px;font-weight:500;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis;max-width:42vw;border:1px solid rgba(255,255,255,.12)}
  .ctx-chip .sep{display:inline-block;width:3px;height:3px;border-radius:var(--radius-pill);background:#475569;flex-shrink:0}
  .ctx-chip .ctx-label{color:var(--ink-faint);font-weight:500}
  /* Legacy .meta-chips kept as fallback in case JS still writes to #meta-chips */
  .meta-chips{display:flex;gap:6px;flex-wrap:nowrap;min-width:0;overflow:hidden}
  .meta-chips .chip{background:var(--navy-2);color:#cbd5e1;padding:4px 10px;border-radius:var(--radius-pill);font-size:11.5px;font-weight:500;white-space:nowrap;flex-shrink:0}
  /* Header responsive: ocultar contexto secundario de forma progresiva para que nunca
     se solape con los botones en anchos intermedios (tablet / laptop chico). */
  @media (max-width:1240px){ .header .meta-chips, .header .ctx-chip{display:none} }
  @media (max-width:1100px){ .header .brand .sub{display:none} }
  @media (max-width:900px){ .header .brand .brand-suffix{display:none} }
  .upload-btn{background:var(--brand);color:#fff;border:1px solid transparent;padding:8px 14px;border-radius:8px;font-weight:600;font-size:13px;display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow)}
  .upload-btn:hover{background:var(--brand-dark)}
  .ghost-btn{background:transparent;border:1px solid transparent;color:#cbd5e1;padding:7px 10px;border-radius:8px;font-size:13px;display:inline-flex;align-items:center;gap:6px}
  .ghost-btn:hover{background:rgba(255,255,255,.08);color:#fff}
  .doc-btn-header{background:transparent;border:none;color:#cbd5e1;padding:7px 10px;font-size:13px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border-radius:8px}
  .doc-btn-header:hover{background:rgba(255,255,255,.08);color:#fff}

  .container{max-width:1600px;margin:0 auto;padding:18px 24px 60px;display:grid;grid-template-columns:300px 1fr;gap:18px}

  .summary{grid-column:1/-1;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-bottom:4px}
  .card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}
  .card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}
  .card.market-focus{border-color:rgba(37,99,235,.18);background:linear-gradient(180deg,rgba(236,248,255,.95),#fff);box-shadow:0 18px 40px rgba(37,99,235,.12)}
  .card.market-focus .label{color:var(--brand);letter-spacing:.06em}
  .card.market-focus .hint{color:var(--brand-dark)}
  .card.market-focus .value{color:var(--navy);font-size:24px}
  /* Responsive tweaks for summary/main layout */
  @media (max-width:900px){
    .container{grid-template-columns:1fr;gap:12px;padding:14px 16px 90px}
    .summary{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px}
    .card{padding:12px 14px;border-radius:12px}
  }
  @media (max-width:520px){
    .summary{grid-template-columns:repeat(2,1fr);gap:8px}
    .card .value{font-size:18px}
  }
  .card .label{color:var(--ink-soft);font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
  .card .value{font-size:22px;font-weight:600;margin-top:4px;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
  .card .hint{font-size:11px;color:var(--ink-soft);margin-top:2px}

  /* Sidebar — unified input style (36px high, brand-soft focus ring), gray text-link
     reset, monochrome filter-group counts, less chunky quick-actions. Audit: avoid
     the "lista interminable" feel and the alarming red "reset" button. */
  .sidebar{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:0;box-shadow:var(--shadow);height:fit-content;position:sticky;top:72px;max-height:calc(100vh - 88px);overflow-y:auto;display:flex;flex-direction:column}
  .sidebar-mobile-head{display:none} /* header con ✕ — solo visible en el drawer mobile */
  .sidebar h3{margin:0;font-size:11.5px;color:var(--ink);letter-spacing:-.005em;font-weight:600;text-transform:none}
  /* Input — single canonical style (the "best input" the audit said to replicate) */
  .input-search{position:relative;display:flex;align-items:center}
  .input-search > .ic{position:absolute;left:10px;color:var(--ink-faint);pointer-events:none}
  .input-search input[type=text]{width:100%;border:1px solid var(--line);border-radius:8px;padding:8px 10px 8px 32px;height:36px;font:14px/1 var(--font);color:var(--ink);outline:none;background:#fff}
  .input-search input[type=text]:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .sidebar input[type=text]:not(.input-search input){width:100%;border:1px solid var(--line);border-radius:8px;padding:7px 10px;height:34px;font:13px/1 var(--font);color:var(--ink);outline:none;background:#fff}
  .sidebar input[type=text]:not(.input-search input):focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  /* Active filter chips bar at top of sidebar */
  .sidebar-section{padding:13px 14px;border-bottom:1px solid var(--line-2)}
  .sidebar-section:last-child{border-bottom:none}
  .active-filters-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
  .active-filters-title{font-size:12px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.08em}
  .clear-filters-btn{background:transparent;border:none;color:var(--ink-soft);font-size:12px;font-weight:600;cursor:pointer;padding:4px 6px;border-radius:7px;transition:background var(--duration-fast) ease,color var(--duration-fast) ease}
  .clear-filters-btn:hover{background:var(--bg-warm);color:var(--ink)}
  .clear-filters-btn{display:none}
  .active-chips{display:flex;flex-wrap:wrap;gap:5px}
  .active-chip{display:inline-flex;align-items:center;gap:5px;background:var(--brand-soft);color:var(--brand-dark);padding:3px 6px 3px 9px;border-radius:var(--radius-pill);font-size:11.5px;font-weight:500;cursor:pointer;border:none}
  .active-chip .ic{opacity:.6}
  .active-chip:hover .ic{opacity:1}
  .active-chips .empty{color:var(--ink-faint);font-size:11.5px}
  .mobile-filters-btn{position:relative}
  .mobile-filters-btn .filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:4px;font-size:11px;font-weight:700;color:#fff;background:var(--brand);border-radius:var(--radius-pill);line-height:1;visibility:hidden;opacity:0;transition:opacity var(--duration-fast) ease,visibility var(--duration-fast) ease}
  .mobile-filters-btn.has-count .filter-count{visibility:visible;opacity:1}
  /* Filter group — collapsible, gray monochrome counts, no decorative borders */
  .filter-group{padding:12px 14px;border-bottom:1px solid var(--line-2);margin:0}
  .filter-group.market-group .head{border-left:3px solid var(--brand);padding-left:10px}
  .filter-group.market-group .head h3{display:inline-flex;align-items:center;gap:8px}
  .filter-group:last-of-type{border-bottom:none}
  .filter-group .head{display:flex;justify-content:space-between;align-items:center;cursor:pointer;user-select:none;gap:6px}
  .filter-group .head .count{background:transparent;color:var(--ink-faint);font-size:11px;font-weight:500;font-variant-numeric:tabular-nums;padding:0}
  .filter-group .head .ic{color:var(--ink-faint);transition:transform .15s ease}
  .filter-group.collapsed .head .ic{transform:rotate(-90deg)}
  .filter-group.collapsed .filter-body{display:none}
  .filter-body{margin-top:9px}
  .market-note{margin:8px 0 10px;padding:10px 12px;border-radius:var(--radius);background:var(--brand-soft);color:var(--brand-dark);font-size:12px;line-height:1.45;border:1px solid #bfd4ff;border-left:3px solid var(--brand)}
  .filter-group .group-tag{display:inline-flex;margin-left:6px;padding:2px 7px;border-radius:var(--radius-pill);background:rgba(37,99,235,.12);color:var(--brand);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
  .check-list{max-height:240px;overflow-y:auto;display:flex;flex-direction:column;gap:2px}
  .check-list label{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;color:var(--ink)}
  .check-list label:hover{background:var(--bg-warm)}
  .check-list input{accent-color:var(--brand);margin:0;flex-shrink:0}
  .check-list .sub{color:var(--ink-faint);font-size:11px;margin-left:auto}
  /* Quick-actions: text-link style, no chunky pills. Only "Solo propias" keeps the
     amber tint because it's a brand-specific scope filter (semantic, not decoration). */
  .quick-actions{display:flex;gap:4px;margin-top:7px;flex-wrap:wrap;align-items:center}
  .quick-actions button{flex:0 1 auto;background:transparent;border:none;color:var(--ink-soft);padding:3px 7px;border-radius:5px;font-size:11.5px;font-weight:500;cursor:pointer}
  .quick-actions button:hover{background:var(--bg-warm);color:var(--brand)}
  .quick-actions button.nolter{color:var(--warn-ink);background:var(--warn-tint)}
  .quick-actions button.nolter:hover{background:#fff3d6;color:var(--warn-ink)}
  /* Reset — gray text link with refresh icon and dynamic count */
  .reset-all{width:100%;background:transparent;border:none;color:var(--ink-soft);padding:8px 0;font-size:12px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;text-align:center}
  .reset-all:hover{color:var(--brand)}
  .reset-all.danger{color:var(--ink-faint)}
  .reset-all.danger:hover{color:var(--bad)}

  /* min-width:0 deja que el grid-item se encoja: las tablas anchas (Plan Semanal,
     Detalle) scrollean dentro de su .table-wrap en vez de empujar el layout. */
  .main{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:visible;min-width:0;max-width:100%}
  /* Tabs — monochrome, navy underline on active. Audit: kill rainbow + emoji chrome.
     5 principales visible; 8 secundarias dentro de .tabs-menu (popover). Todos los
     .tab[data-tab] siguen presentes en el DOM para no romper el routing existente. */
  .tabs-row{display:flex;align-items:stretch;border-bottom:1px solid var(--line);background:#fff;padding:0 6px;position:relative;overflow-x:auto;overflow-y:visible}
  .tab{padding:0 16px;height:44px;font-size:13px;font-weight:500;color:var(--ink-soft);border:none;background:none;border-bottom:2px solid transparent;white-space:nowrap;letter-spacing:-.005em;display:inline-flex;align-items:center;gap:7px;cursor:pointer;transition:color .15s ease,border-color .15s ease}
  .tab:focus-visible{outline:2px solid rgba(37,99,235,.5);outline-offset:3px}
  .tab:hover:not(.active){color:var(--ink)}
  .tab.active{color:var(--navy);border-bottom-color:var(--navy);font-weight:600;background:transparent}
  .tab .ic{color:currentColor;opacity:.85}
  .tabs-spacer{flex:1}
  /* "Análisis ▾" dropdown trigger */
  .tabs-menu-wrap{position:relative;display:inline-flex;align-items:stretch}
  .tabs-menu-trigger{height:44px;padding:0 14px;background:none;border:none;color:var(--ink-soft);font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px;cursor:pointer;border-bottom:2px solid transparent}
  .tabs-menu-trigger:hover{color:var(--ink)}
  .tabs-menu-trigger.has-active{color:var(--navy);font-weight:600;border-bottom-color:var(--navy)}
  .tabs-menu-trigger .caret{transition:transform .15s ease}
  .tabs-menu-wrap.open .tabs-menu-trigger .caret{transform:rotate(180deg)}
  /* The popover that contains the 8 secondary .tab buttons */
  /* Menu fixed → no lo recorta el overflow del tabs-row. JS lo posiciona al abrir. */
  .tabs-menu{position:fixed;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);padding:6px;display:none;opacity:0;transform:translateY(-8px);pointer-events:none;z-index:1500;transition:transform .18s ease,opacity .18s ease}
  .tabs-menu{border-color:rgba(148,163,184,.18);}
  .tabs-menu-wrap.open .tabs-menu{display:block;opacity:1;transform:translateY(0);pointer-events:auto}
  /* When a .tab lives inside .tabs-menu, render it as a stacked menu item */
  .tabs-menu .tab{display:flex;justify-content:flex-start;width:100%;height:auto;padding:10px 12px;border-bottom:none;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--ink);transition:background .15s ease,color .15s ease}
  .tabs-menu .tab{gap:10px}
  .tabs-menu .tab:hover{background:var(--bg-warm);color:var(--ink)}
  .tabs-menu .tab:focus-visible{outline:2px solid rgba(37,99,235,.5);outline-offset:2px}
  .tabs-menu-group{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);padding:8px 12px 3px}
  .tabs-menu-group:first-child{padding-top:4px}
  .tabs-menu .tab:hover{background:var(--bg-warm);color:var(--ink)}
  .tabs-menu .tab.active{background:var(--brand-soft);color:var(--brand-dark);border-bottom:none}
  /* Backdrop when the popover becomes a mobile bottom-sheet */
  .tabs-backdrop{position:fixed;inset:0;background:rgba(2,6,23,0.45);opacity:0;visibility:hidden;transition:opacity .18s ease;z-index:1400}
  .tabs-backdrop.show{opacity:1;visibility:visible}
  @media (max-width:780px){
    .tabs-menu.mobile-sheet{left:8px;right:8px;bottom:76px;top:auto;border-radius:12px 12px 10px 10px;min-width:0;transform:translateY(12px);opacity:0;pointer-events:none}
    .tabs-menu.mobile-sheet{transition:transform .18s ease,opacity .18s ease}
    .tabs-menu.mobile-sheet.open-state{transform:translateY(0);opacity:1;pointer-events:auto}
  }
  .toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line);background:#fbfcfe;font-size:13px;color:var(--ink-soft);flex-wrap:wrap;gap:10px}
  body.static-tab .toolbar{display:none}
  .toolbar .result-count strong{color:var(--ink);font-weight:600}
  .toolbar .actions{display:flex;gap:8px}
  .toolbar .actions button{background:#fff;border:1px solid var(--line-strong);padding:5px 10px;border-radius:var(--radius-sm);color:var(--ink);font-size:12px}
  .toolbar .actions button:hover{border-color:var(--brand);color:var(--brand)}
  /* Header spacing tweaks for medium screens */
  @media (max-width:1100px){
    .header{padding:10px 14px}
    .header .brand{gap:8px}
    .toolbar{padding:8px 12px}
  }
  @media (max-width:780px){
    .header .actions{display:flex;gap:6px}
    .toolbar{padding:8px 12px}
  }

  /* Microinteractions: table/list rows and filters */
  .row, .table-row, .list-row{transition:background .14s ease,transform .12s ease}
  .row:hover, .table-row:hover, .list-row:hover{background:var(--bg-warm);transform:translateY(-1px)}
  .row:focus-within, .table-row:focus-within{outline:2px solid var(--brand-soft);outline-offset:2px}
  .filter-group .head button, .quick-actions button{transition:background .12s ease,transform .12s ease}
  .filter-group .head button:active, .quick-actions button:active{transform:translateY(1px)}
  .tab{transition:color .15s ease,border-color .15s ease,transform .12s ease}
  .tab:active{transform:translateY(1px)}

  .table-wrap{overflow-x:auto;max-height:calc(100vh - 340px);overflow-y:auto}
  /* Table truncation for small screens */
  @media (max-width:780px){
    .table-wrap td{max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .table-wrap th{white-space:nowrap}
  }

  /* Tab content transitions — crossfade puro, SIN desplazamiento vertical.
     (Antes usaba translateY(6px) y el contenido "se subía" en cada navegación.) */
  #tab-content{transition:opacity .18s ease}
  #tab-content.tab-exit{opacity:0}
  #tab-content.tab-enter{opacity:1}
  table{width:100%;border-collapse:collapse;font-size:13px}
  thead{position:sticky;top:0;background:var(--bg-warm);z-index:1}
  th{text-align:left;padding:9px 10px;font-weight:600;color:var(--ink-soft);font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line-strong);cursor:pointer;user-select:none;white-space:nowrap}
  th:hover{color:var(--brand)}
  th .arrow{opacity:.4;margin-left:3px}
  th.sorted .arrow{opacity:1;color:var(--brand)}
  td{padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
  tbody tr:hover{background:#f8fafc}
  .medico-name{font-weight:600;color:var(--ink)}
  .badge{display:inline-block;padding:1px 7px;border-radius:4px;font-size:11px;font-weight:500}
  .badge.cat-1{background:#bbf7d0;color:#14532d}
  .badge.cat-2{background:#dcfce7;color:#166534}
  .badge.cat-3{background:#fef9c3;color:#854d0e}
  .badge.cat-4{background:#fed7aa;color:#9a3412}
  .badge.cat-5{background:#fee2e2;color:#991b1b}
  .badge.cat-none{background:#f1f5f9;color:#64748b}
  .badge.rnk{background:var(--bg-warm);color:var(--ink-soft);font-variant-numeric:tabular-nums}
  .badge.rnk-1{background:var(--navy);color:#fff;font-weight:700}
  .esp-tag{display:inline-block;background:#eef2ff;color:#4338ca;padding:1px 6px;border-radius:3px;font-size:11px;margin-right:3px;font-weight:500}
  .marca-tag{display:inline-block;background:#f1f5f9;color:var(--ink-soft);padding:1px 7px;border-radius:4px;font-size:11px;font-weight:500;margin-right:3px}
  .marca-tag.nolter{background:var(--navy);color:#fff;font-weight:600}
  .mercado-cell{font-weight:500;color:var(--ink)}
  .ms-bar{position:relative;background:#f1f5f9;height:6px;border-radius:3px;overflow:hidden;margin-top:3px;width:80px}
  .ms-bar div{position:absolute;left:0;top:0;bottom:0;background:var(--navy);border-radius:3px}
  .ms-val{font-variant-numeric:tabular-nums}
  .empty{text-align:center;padding:60px 20px;color:var(--ink-soft)}
  .empty .icon{font-size:32px;margin-bottom:8px}

  .pagination{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
  .pagination .pages{display:flex;gap:4px;flex-wrap:wrap}
  .pagination button{background:#fff;border:1px solid var(--line-strong);padding:4px 9px;border-radius:5px;color:var(--ink);min-width:30px}
  .pagination button:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}
  .pagination button:disabled{opacity:.4;cursor:not-allowed}
  .pagination button.current{background:var(--brand);color:#fff;border-color:var(--brand)}

  .market-section{border-bottom:1px solid var(--line)}
  .market-header{padding:14px 16px;background:#f8fafc;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
  .market-header .name{font-weight:600;font-size:14px}
  .market-header .stats{font-size:12px;color:var(--ink-soft);display:flex;gap:6px;flex-wrap:wrap;align-items:center}

  .medico-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:10px;padding:14px}
  .medico-card{border:1px solid var(--line);border-radius:8px;padding:11px 13px;background:#fff}
  .medico-card .top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
  .medico-card .nm{font-weight:700;font-size:15px}
  .medico-card .mt{font-size:11px;color:var(--ink-soft)}
  .mkt-block{margin-top:6px;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
  .mkt-block .mkt-h{padding:5px 9px;background:#f8fafc;display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:500}
  .mkt-block .mkt-h .ms{color:var(--ink-soft);font-size:11px}
  .mkt-block .prod-row{display:grid;grid-template-columns:1fr 28px 60px 28px 60px;gap:5px;padding:3px 9px;font-size:11px;align-items:center;border-top:1px solid var(--line)}
  .mkt-block .prod-row .pn{font-weight:500}
  .mkt-block .prod-row .pn.nolter{color:#92400e;font-weight:600}
  .mkt-block .prod-row .col-h{font-size:9px;color:var(--ink-soft);text-transform:uppercase;font-weight:600;text-align:center}
  .mkt-block .prod-head{background:#fafbfc}
  .num{font-variant-numeric:tabular-nums;text-align:right;color:var(--ink-soft);font-size:10px}
  .ms-mini{position:relative;background:#f1f5f9;height:4px;border-radius:2px;overflow:hidden;width:50px;display:inline-block}
  .ms-mini div{position:absolute;left:0;top:0;bottom:0;background:var(--navy)}

  details summary{cursor:pointer;list-style:none;outline:none}
  details summary::-webkit-details-marker{display:none}
  details summary::before{content:"▸ ";color:var(--ink-soft);font-size:10px;margin-right:4px}
  details[open] summary::before{content:"▾ "}

  /* FICHA MEDICO */
  .ficha-search-compact{padding:10px 18px;background:#f0f4f8;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
  .ficha-search-compact .info{font-size:13px;color:var(--ink)}
  .ficha-search-compact .search-toggle{background:#fff;border:1px solid var(--line-strong);padding:6px 12px;border-radius:var(--radius-sm);font-size:12px;color:var(--ink);cursor:pointer;font-weight:500}
  .ficha-search-compact .search-toggle:hover{border-color:var(--brand);color:var(--brand)}
  .ficha-search{padding:18px 20px;background:#fbfcfe;border-bottom:1px solid var(--line)}
  .ficha-search input{width:100%;font-size:16px;padding:12px 16px;border:2px solid var(--line-strong);border-radius:var(--radius);outline:none}
  .ficha-search input:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
  /* Tap targets cómodos en mobile (≥40px, sin agrandar en desktop) — pulgar friendly. */
  @media (max-width:780px){
    .input-search input[type=text]{height:auto;min-height:44px}
    .alta-filter-btn,.toolbar .actions button{min-height:40px}
    /* Franja de regiones afinada: control secundario, target algo menor para que la fila sea fina. */
    .geo-toggle button,.scope-toggle button{min-height:34px}
    /* Los toggles segmentados de etiqueta corta (TRIM/MES, etc.) se ven desproporcionados a 40px. */
    .ficha-sort-btn,.pill-toggle button{min-height:32px}
  }
  .ficha-results{padding:10px 20px;max-height:340px;overflow-y:auto;border-bottom:1px solid var(--line)}
  .ficha-results .hint{font-size:12px;color:var(--ink-soft);margin-bottom:8px}
  /* Fila de resultado COMPACTA: nombre + 1 línea (esp · matrícula · zona). Sin la dirección
     completa (eso va en la ficha al seleccionar) → entran ~9-10 médicos por pantalla en vez de 4-5.
     La columna derecha (marcas/propias) es nowrap para que "6 marcas" no se parta en dos líneas. */
  .ficha-medico-item{padding:7px 11px;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:10px;border:1px solid transparent}
  .ficha-medico-item:hover{background:#f1f5f9;border-color:var(--line)}
  .ficha-medico-item.selected{background:var(--brand-soft);border-color:var(--brand)}
  .ficha-medico-item .fmi-main{min-width:0;flex:1}
  .ficha-medico-item .nm{font-weight:600;font-size:13.5px;line-height:1.3;display:flex;align-items:center;gap:5px;min-width:0}
  .ficha-medico-item .nm-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .ficha-medico-item .meta{font-size:11px;color:var(--ink-soft);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  .ficha-medico-item .fmi-zona{color:var(--brand-dark);font-weight:500}
  .ficha-medico-item .fmi-side{flex:0 0 auto;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px;white-space:nowrap}
  .ficha-medico-item .fmi-marcas{font-size:12.5px;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap}
  .ficha-medico-item .fmi-nolter{font-size:11px;color:var(--warn-ink);font-weight:600;font-variant-numeric:tabular-nums;display:inline-flex;align-items:center;gap:3px;white-space:nowrap}
  .ficha-detail{padding:20px}
  .ficha-detail .head{border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px;background:#fff}
  .ficha-detail .head .row{display:flex;flex-wrap:wrap;gap:18px;font-size:13px;margin-bottom:5px}
  .ficha-detail .head .row .lbl{font-weight:600;color:var(--ink-soft);min-width:120px}
  .pdf-btn{background:#dc2626;color:#fff;border:none;padding:8px 14px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
  .pdf-btn:hover{background:#b91c1c}
  .pdf-btn:disabled{opacity:.5;cursor:wait}
  @media print {
    .header, .container > .summary, .sidebar, .tabs, .toolbar, .ficha-search, .ficha-results, .pdf-btn, #sidebar-backdrop, .mobile-filters-btn, .ficha-sort-btn, .pill-toggle { display:none !important; }
    .container { display:block !important; padding:0 !important; }
    .main { box-shadow:none !important; border:none !important; }
    body { background:#fff !important; }
    .ficha-detail { padding:0 !important; }
  }
  .ficha-sort-btn{padding:5px 11px;background:#fff;border:1px solid var(--line-strong);color:var(--ink);border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer}
  .ficha-sort-btn:hover{border-color:var(--brand);color:var(--brand)}
  .ficha-sort-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}
  .ficha-sort-btn.active:hover{background:#0c4a6e;color:#fff}
  .ficha-detail .head h2{margin:0 0 10px;font-size:20px;font-weight:600;letter-spacing:-.01em}
  .ficha-mkt{border:1px solid var(--line);border-left:3px solid var(--line-strong);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;background:#fff}
  /* Semáforo de ventana de mercado: azul = propias presente (reforzar) · ámbar = oportunidad
     de conquista (solo competencia). Codifica el estado de un vistazo sin recargar de color. */
  .ficha-mkt.has-nolter{border-left-color:var(--brand)}
  .ficha-mkt.has-nolter .ficha-mkt-head{background:linear-gradient(180deg,rgba(37,99,235,.07),#eef4fc)}
  .ficha-mkt.has-nolter .ficha-mkt-head .name{color:var(--navy)}
  .ficha-mkt.opp{border-left-color:#e0a64a}
  .ficha-mkt.opp .ficha-mkt-head{background:linear-gradient(180deg,rgba(217,119,6,.08),#fdf6ec)}
  .merc-flag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;padding:2px 8px 2px 6px;border-radius:var(--radius-sm);white-space:nowrap;margin-left:2px}
  .merc-flag .ic{width:12px;height:12px}
  .merc-flag.nolter{background:var(--brand-soft);color:var(--navy)}
  .merc-flag.opp{background:#fdebd2;color:#b45309}
  .ficha-mkt-head{padding:10px 14px;background:#f0f4f8;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:10px}
  .ficha-mkt-head .name{font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:7px;flex-wrap:wrap}
  .ficha-mkt-head .stats{display:flex;gap:14px;font-size:12px;color:var(--ink-soft);align-items:center;flex-wrap:wrap}
  .ficha-mkt-head .stats .pill{background:#fff;border:1px solid var(--line-strong);padding:3px 10px;border-radius:5px}
  .ficha-mkt-head .stats .pill strong{color:var(--ink);margin-left:4px;font-variant-numeric:tabular-nums}
  /* Card de mercado colapsable: tap en el encabezado para ver/ocultar la evolución TRIM vs MES. */
  .ficha-mkt>summary{list-style:none;cursor:pointer;position:relative;padding-right:34px;-webkit-tap-highlight-color:transparent}
  .ficha-mkt>summary::-webkit-details-marker{display:none}
  .ficha-mkt>summary:active{background:rgba(14, 107, 168,.04)}
  .ficha-mkt-chev{position:absolute;right:14px;top:50%;width:8px;height:8px;border-right:2px solid var(--ink-mute,#94a3b8);border-bottom:2px solid var(--ink-mute,#94a3b8);transform:translateY(-65%) rotate(45deg);transition:transform .18s ease,border-color .15s}
  .ficha-mkt[open]>summary .ficha-mkt-chev{transform:translateY(-35%) rotate(-135deg)}
  .ficha-mkt>summary:hover .ficha-mkt-chev{border-color:var(--brand,#0e6ba8)}
  .ficha-mkt-empty{padding:14px 16px;color:var(--ink-soft);font-style:italic;font-size:13px}
  .ficha-quick-actions{display:flex;gap:8px;align-items:center;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 0 10px;padding:2px 0}
  .ficha-quick-actions::-webkit-scrollbar{display:none}
  .fqa-btn,.fqa-link{min-height:38px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--ink);padding:8px 12px;font-size:12.5px;font-weight:650;text-decoration:none;cursor:pointer;box-shadow:var(--shadow)}
  .fqa-btn.primary{background:var(--navy);border-color:var(--navy);color:#fff}
  .fqa-btn.on{background:var(--good-soft);border-color:#86efac;color:#065f46}
.fqa-datos{background:var(--brand-soft);border-color:var(--brand);color:var(--brand-dark);font-weight:700}
.fqa-datos .ic{color:var(--brand)}
  .fqa-link.strong{background:var(--brand-soft);border-color:#cfe0ff;color:var(--brand-dark)}
  .fqa-btn .ic,.fqa-link .ic{width:14px;height:14px}
  .ficha-market-list{scroll-margin-top:72px}
  .ficha-section-title{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:2px 0 10px;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
  .ficha-section-title .t{font-size:13px;font-weight:800;color:var(--ink);display:inline-flex;align-items:center;gap:7px}
  .ficha-section-title .s{font-size:11.5px;color:var(--ink-soft);font-variant-numeric:tabular-nums;white-space:nowrap}
  /* Desktop ancho (≥1280px): las cards de mercado en 2 columnas → aprovecha el ancho y baja el scroll.
     El título de sección ocupa el ancho completo; las tablas se ajustan a su columna. En <1280 queda 1 col. */
  @media (min-width:1280px){
    .ficha-market-list{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start}
    .ficha-market-list > .ficha-section-title{grid-column:1/-1}
    .ficha-market-list > .ficha-mkt{margin-bottom:0}
    .ficha-market-list > .ficha-mkt .ficha-prod-table{min-width:0}
  }
  .ficha-prod-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .ficha-prod-scroll::-webkit-scrollbar{height:5px}
  .ficha-prod-scroll::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:var(--radius-pill)}
  .ficha-prod-table{width:100%;border-collapse:collapse;font-size:13px;min-width:440px}
  .ficha-prod-table thead{background:var(--bg-warm)}
  .ficha-prod-table th{padding:7px 12px;font-size:11px;text-transform:uppercase;color:var(--ink-soft);font-weight:600;letter-spacing:.04em;border-bottom:1px solid var(--line);text-align:left}
  .ficha-prod-table th.num{text-align:right}
  /* Encabezado agrupado por período (TRIM 04/26 / MES 04/26) */
  .ficha-prod-table th.grp{text-align:center;color:var(--ink-soft);letter-spacing:.04em;font-variant-numeric:tabular-nums}
  .ficha-prod-table th.grp-l,.ficha-prod-table td.grp-l{border-left:1px solid var(--line)}
  .ficha-prod-table td{padding:6px 12px;border-bottom:1px solid #f1f5f9;font-size:13px}
  .ficha-prod-table td.num{text-align:right;font-variant-numeric:tabular-nums}
  .ficha-prod-table tr.is-nolter{background:var(--brand-soft);box-shadow:inset 3px 0 0 var(--brand)}
  .ficha-prod-table tr.is-nolter td{font-weight:600}
  .ficha-prod-table tr.is-nolter td:first-child{color:var(--brand-dark);font-weight:700}
  .ficha-prod-table tr.is-rnk1 td.num.rnk{color:var(--ink);font-weight:700}
  .ficha-prod-table tbody tr:hover{background:#f8fafc}
  .ficha-prod-table tr.is-nolter:hover{background:#d7e5ff}
  .clickable-medico{cursor:pointer;text-decoration:none;color:inherit}
  .clickable-medico:hover{color:var(--brand);text-decoration:underline}

  /* OPORTUNIDADES */
  /* === Oportunidades propias === Audit: neutral chrome, mono pill toggle, ámbar
     accent reserved for propias brand mentions in content. */
  .oppo-toolbar{padding:12px 18px;background:#fff;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;gap:14px;align-items:center}
  .oppo-toolbar label{font-size:11px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:6px}
  .oppo-toolbar select{padding:7px 12px;border:1px solid var(--line);border-radius:7px;background:#fff;font:13px/1 var(--font);font-weight:500;color:var(--ink);outline:none;cursor:pointer}
  .oppo-toolbar select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .oppo-toolbar .pill-toggle{display:inline-flex;background:var(--bg-warm);border:1px solid var(--line);border-radius:7px;padding:2px;gap:1px}
  .oppo-toolbar .pill-toggle button{padding:4px 10px;background:transparent;border:none;color:var(--ink-soft);border-radius:5px;font-size:12px;font-weight:500;cursor:pointer}
  .oppo-toolbar .pill-toggle button:hover{color:var(--ink)}
  .oppo-toolbar .pill-toggle button.active{background:#fff;color:var(--navy);box-shadow:var(--shadow);font-weight:600}
  .oppo-header{padding:16px 20px;background:#fff;border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;align-items:flex-end}
  .oppo-header h2{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}
  .oppo-header .sub{font-size:13px;color:var(--ink-soft);margin-top:3px}
  .oppo-header .stats{display:flex;gap:8px;flex-wrap:wrap}
  .oppo-header .stats .pill{font-size:12px;padding:4px 10px;border-radius:5px;background:#f1f5f9;color:var(--ink)}
  .oppo-header .stats .pill strong{color:var(--ink);margin-left:3px}
  .oppo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}
  .oppo-col{background:#fff;padding:14px 16px}
  .oppo-col .ttl{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding-bottom:8px;margin-bottom:8px;border-bottom:2px solid}
  .oppo-col.conquistar .ttl{color:var(--brand-dark);border-color:#bfdbfe}
  .oppo-col.proteger .ttl{color:#059669;border-color:#a7f3d0}
  .oppo-col .ttl-sub{font-size:11px;color:var(--ink-soft);font-weight:400;text-transform:none;letter-spacing:0;margin-top:2px}
  .oppo-list{display:flex;flex-direction:column;gap:6px;max-height:calc(100vh - 380px);overflow-y:auto;padding-right:4px}
  .oppo-list::-webkit-scrollbar{width:8px}
  .oppo-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}
  .oppo-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}
  .oppo-item{border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;background:#fff;cursor:pointer}
  .oppo-item:hover{background:#fff;border-color:var(--brand)}
  .oppo-item .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px}
  .oppo-item .nm{font-weight:600;font-size:13px}
  .oppo-item .mt{font-size:11px;color:var(--ink-soft)}
  .oppo-item .stats{display:flex;gap:5px;flex-wrap:wrap;align-items:center;margin-top:3px}
  .oppo-item .stats span{font-size:11px}
  .oppo-item.conquistar{border-left:3px solid var(--brand)}
  .oppo-item.proteger{border-left:3px solid #059669}
  .oppo-empty{text-align:center;padding:30px 10px;color:var(--ink-soft);font-size:12px;font-style:italic}
  @media (max-width:900px){ .oppo-grid{grid-template-columns:1fr} }

  .nlt-stat-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px}
  .nlt-stat-card .lbl{font-size:10.5px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:5px}
  .nlt-stat-card .val{font-size:22px;font-weight:600;margin-top:4px;font-variant-numeric:tabular-nums;letter-spacing:-.015em;color:var(--ink)}
  .nlt-stat-card .val.conq{color:var(--brand)}
  .nlt-stat-card .val.ret{color:var(--good)}
  .nlt-stat-card .hint{font-size:11px;color:var(--ink-soft);margin-top:2px}

  /* GIRAS TAB */
  /* === Giras === Audit: same Top-100 treatment, mono navy ranking, no cyan rainbow */
  .gir-intro{padding:14px 20px;background:#fff;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
  .gir-intro h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}
  .gir-intro h3 .ic{color:var(--ink-soft)}
  .gir-stats-bar{padding:14px 18px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px;border-bottom:1px solid var(--line);background:var(--bg-warm)}
  .gir-toolbar{padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
  .gir-toolbar .actions button{background:#fff;color:var(--ink);border:1px solid var(--line);padding:7px 12px;border-radius:7px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;margin-left:6px}
  .gir-toolbar .actions button:hover{border-color:var(--line-strong);color:var(--brand)}
  .gir-row{display:grid;grid-template-columns:48px 1fr 100px 90px 1fr;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line-2);align-items:center;cursor:pointer;font-size:13px;transition:background .1s}
  .gir-row:hover{background:var(--bg-warm)}
  .gir-row.top10{border-left:3px solid var(--line-strong);padding-left:13px}
  .gir-row.top3{border-left-color:var(--navy)}
  .gir-rank{font-weight:600;font-size:20px;color:var(--ink-faint);text-align:center;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
  .gir-row.top10 .gir-rank{color:var(--ink)}
  .gir-row.top3 .gir-rank{color:var(--navy);font-size:24px;font-weight:700}
  .gir-nm{font-weight:600;font-size:14px;color:var(--ink)}
  .gir-mt{font-size:11.5px;color:var(--ink-soft);margin-top:3px}
  .gir-score-box{text-align:center}
  .gir-score{font-weight:600;font-size:18px;color:var(--ink);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
  .gir-score-bar{position:relative;background:var(--line-2);height:4px;border-radius:var(--radius-pill);overflow:hidden;margin-top:4px}
  .gir-score-bar div{position:absolute;left:0;top:0;bottom:0;background:var(--navy);border-radius:var(--radius-pill)}
  .gir-stats-cell{text-align:center}
  .gir-stats-cell .n{font-weight:600;font-size:15px;color:var(--ink);font-variant-numeric:tabular-nums}
  .gir-stats-cell .l{font-size:10.5px;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
  .gir-mkt-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:500;margin-right:3px;margin-bottom:3px;background:var(--bg-warm);color:var(--ink-soft);border:1px solid var(--line)}
  .gir-mkt-chip.no-nolter{background:var(--bad-tint);color:var(--bad-ink);border-color:var(--bad-soft)}
  .gir-mkt-chip.has-nolter{background:var(--good-soft);color:#065f46;border-color:transparent}
  @media (max-width:780px){
    .gir-stats-bar{grid-template-columns:repeat(2,1fr)}
    .gir-row{grid-template-columns:36px 1fr;grid-template-areas:'rank info' '. score' '. stats' '. mkts';row-gap:6px;padding:10px 12px}
    .gir-rank{grid-area:rank}
    .gir-row > .gir-info-col{grid-area:info}
    .gir-score-box{grid-area:score;text-align:left}
    .gir-stats-cell{grid-area:stats;text-align:left;display:flex;gap:14px}
    .gir-mkts-col{grid-area:mkts}
  }

  /* === Top 100 Conquista === Audit: mono ranking, no gradients, no red as
     default. Red reserved for barrera/critical, navy for ranking emphasis. */
  .tc-intro{padding:14px 20px;background:#fff;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-soft)}
  .tc-intro h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}
  .tc-intro h3 .ic{color:var(--ink-soft)}
  .tc-toolbar{padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
  .tc-toolbar button{background:#fff;border:1px solid var(--line);color:var(--ink);padding:7px 12px;border-radius:7px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
  .tc-toolbar button:hover{border-color:var(--line-strong);color:var(--brand)}
  /* Top 100 — tarjeta de jugada (mismo lenguaje que la Ficha), responsive */
  .tc-list{padding:10px 14px}
  .tc-row{display:flex;align-items:flex-start;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:13px 14px;margin-bottom:9px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.03);transition:box-shadow .14s ease,border-color .14s ease,transform .14s ease}
  .tc-row:hover{border-color:var(--line-strong);box-shadow:0 8px 20px -12px rgba(15,23,42,.22);transform:translateY(-1px)}
  .tc-row.top3{border-color:#d3e0f5;background:linear-gradient(180deg,#fbfcfe,#fff)}
  .tc-rank{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:var(--bg-warm);border:1px solid var(--line);color:var(--ink-mute);font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}
  .tc-row.top3 .tc-rank{background:var(--navy);border-color:var(--navy);color:#fff}
  .tc-main{flex:1;min-width:0}
  .tc-nm{font-weight:700;font-size:15px;color:var(--ink);display:flex;align-items:center;gap:6px;flex-wrap:wrap;line-height:1.2;letter-spacing:-.01em}
  .tc-mt{font-size:11.5px;color:var(--ink-soft);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .tc-mt code{font-family:var(--font-mono);font-size:10.5px;color:var(--ink-mute);background:none;padding:0}
  .tc-addr{font-size:11.5px;color:var(--ink-soft);margin-top:3px;display:flex;align-items:center;gap:4px;line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .tc-addr svg{color:var(--brand);flex:0 0 auto;width:12px;height:12px}
  .tc-play{display:flex;align-items:center;gap:7px;flex-wrap:wrap;margin-top:10px;background:transparent;border:none;border-left:2px solid var(--brand);border-radius:0;padding:4px 0 4px 11px;font-size:12.5px;color:var(--ink-soft);line-height:1.35}
  .tc-play .pl-brand{color:var(--brand-dark);font-weight:700}
  .tc-play.ret{border-left-color:var(--good)}
  .tc-play.gr.cold{border-left-color:var(--ink-faint)}
  .tc-play.gr.cold .pl-brand{color:var(--ink)}
  /* Selector de vista del Top 100 / Ganá rápido (reemplaza el toggle de 4 botones) */
  .tc-vista-select{-webkit-appearance:none;appearance:none;padding:6px 26px 6px 10px;border:1px solid var(--line-strong);border-radius:8px;background:#fff;color:var(--navy);font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;min-height:34px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 9px center}
  .tc-vista-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .tc-play.ret .pl-brand{color:#065f46}
  .tc-play .pl-more{color:var(--ink-soft);font-size:11px;font-weight:600}
  /* === Score pill · componente único (lo usan Ganá rápido y Mi día) === */
  .score-pill{flex:0 0 auto;text-align:center;background:#fff;border:1px solid var(--line-strong);border-radius:var(--radius);padding:7px 9px 6px;min-width:50px}
  .score-pill .s{font-size:21px;font-weight:700;color:var(--brand);line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
  .score-pill .l{font-size:8px;color:var(--ink-faint);font-weight:700;letter-spacing:.1em;margin-top:4px}
  .score-pill.ret{background:var(--good-soft);border-color:#a7f3d0}
  .score-pill.ret .s{color:var(--good)}
  /* Exportar colapsable (al pie del encabezado, sin tapar la lista) */
  .tc-exports summary{cursor:pointer;color:var(--ink-soft);font-weight:600;font-size:12.5px;list-style:none;display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border:1px solid var(--line);border-radius:7px}
  .tc-exports summary::-webkit-details-marker{display:none}
  .tc-exports summary:hover{border-color:var(--line-strong);color:var(--brand)}
  .tc-exports[open] summary{margin-bottom:8px;color:var(--brand);border-color:var(--brand-soft)}
  .tc-exports .tc-exp-row{display:flex;gap:6px;flex-wrap:wrap}

  /* Botón "Filtros": en desktop AHORA se ve (permite ocultar el panel lateral y agrandar el
     contenido). En mobile (≤780px) abre el drawer como siempre. */
  .mobile-filters-btn{display:inline-flex;align-items:center}
  /* Filtros ocultos en desktop → grid a 1 columna + sidebar oculto. Scoped a ≥781px para no
     tocar nunca el drawer mobile (que se controla con .sidebar-open). */
  @media (min-width:781px){
    body.filters-hidden .container{grid-template-columns:1fr}
    body.filters-hidden .sidebar{display:none}
  }
  #sidebar-backdrop{display:none}

  /* === Mobile bottom nav === Audit: 5-icon fixed bottom nav (Ficha, Top 100,
     Plan, Reunión, Más). 56px hit target. Hidden on desktop. Tapping a button
     dispatches a click to the corresponding .tab[data-tab] in the main tabs row
     so the existing routing logic handles the switch. "Más" opens the Análisis
     popover. */
  .mobile-bottom-nav{display:none}
  @media (max-width:780px){
    .mobile-bottom-nav{
      display:grid;grid-template-columns:repeat(5,1fr);
      position:fixed;left:0;right:0;bottom:0;z-index:90;
      background:#fff;border-top:1px solid var(--line);
      padding:6px 0 max(8px, env(safe-area-inset-bottom));
      box-shadow:0 -2px 18px rgba(15,23,42,.1);
      backdrop-filter:blur(14px);
    }
    .mobile-bottom-nav button{
      background:none;border:none;padding:6px 4px;
      display:flex;flex-direction:column;align-items:center;gap:4px;
      color:var(--ink-mute);font-size:10.5px;font-weight:500;cursor:pointer;
      min-height:48px;transition:color var(--duration-fast) ease;
    }
    .mobile-bottom-nav button .ic{width:22px;height:22px;vertical-align:0;opacity:.9;transition:opacity var(--duration-fast) ease}
    .mobile-bottom-nav button.active{color:var(--navy);font-weight:600;background:var(--brand-soft);border-radius:12px}
    .mobile-bottom-nav button.active{box-shadow:0 8px 18px rgba(37,99,235,.08)}
    .mobile-bottom-nav button.active .ic{color:var(--brand);opacity:1}
    .mobile-bottom-nav button:hover{background:var(--bg-warm)}
    .mobile-bottom-nav button:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
    .mobile-bottom-nav button{transition:transform .12s ease,box-shadow .12s ease}
    .mobile-bottom-nav button.pulse{animation:bn-pulse .36s cubic-bezier(.2,.8,.2,1)}
    @keyframes bn-pulse{0%{transform:translateY(0) scale(1);box-shadow:none}50%{transform:translateY(-3px) scale(1.03);box-shadow:0 6px 18px rgba(2,6,23,.08)}100%{transform:translateY(0) scale(1);box-shadow:none}}
    /* Reserve space at bottom of main scroll area so content isn't hidden by the nav */
    .container{padding-bottom:80px !important}
    /* Con teclado abierto (campo enfocado), ocultamos el bottom-nav: en iOS un
       position:fixed bottom:0 flota mal y termina tapando médicos en el medio de la
       pantalla. Mientras buscás no necesitás la barra; vuelve al cerrar el teclado.
       Liberamos también el padding reservado para que la lista use toda la altura. */
    body.kbd-open .mobile-bottom-nav{display:none}
    body.kbd-open .container{padding-bottom:12px !important}
    /* Sidebar drawer — polish to match audit's spec (88vw, slide from left, sticky close at bottom) */
    body.sidebar-open .sidebar{width:88vw;max-width:360px;padding:0 0 max(14px,env(safe-area-inset-bottom));display:flex;flex-direction:column}
    body.sidebar-open .sidebar .sidebar-mobile-head{display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:2;padding:calc(13px + env(safe-area-inset-top)) 14px 13px;background:#fff;border-bottom:1px solid var(--line);font-size:14px;font-weight:700;color:var(--ink)}
    body.sidebar-open .sidebar .sidebar-mobile-head .sbh-x{background:var(--bg-warm);border:1px solid var(--line);width:32px;height:32px;border-radius:8px;font-size:20px;line-height:1;color:var(--ink-soft);cursor:pointer;flex-shrink:0}
    body.sidebar-open .sidebar .sidebar-mobile-head .sbh-x:active{background:var(--line)}
    body.sidebar-open .sidebar::after{
      content:'';position:sticky;bottom:0;height:0;
    }
    /* En mobile el bottom-nav reemplaza la barra de tabs: escondemos las tabs
       visibles y el trigger "Análisis" (el botón "Más" del bottom-nav lo dispara).
       Los .tab[data-tab] siguen en el DOM para el routing. El .tabs-menu es
       position:fixed, así que funciona aunque el tabs-row colapse a 0 de alto. */
    .tabs-row{overflow:visible;padding:0;border-bottom:none;min-height:0}
    .tabs-row > .tab{display:none}
    .tabs-row > .tabs-spacer{display:none}
    .tabs-menu-trigger{display:none}
    .tabs-menu-wrap{position:static}
    /* El menú como bottom-sheet en mobile (JS setea left/right/bottom) */
    .tabs-menu .tab{padding:12px 14px;font-size:14px}
  }

  @media (max-width:1100px){
    .container{grid-template-columns:1fr}
    .sidebar{position:static;max-height:none}
    .summary{grid-template-columns:repeat(2,1fr)}
  }
  /* Phone: collapse sidebar into a drawer */
  @media (max-width:780px){
    /* Header compacto mobile: logo + "Tosto Analytics" + Filtros + Cargar (icono).
       Método y el sufijo "· Análisis" se ocultan; el gerente en cel consulta. */
    .header{overflow:hidden}
    .header-inner{padding:0 12px;gap:8px;height:52px;min-width:0;max-width:100%}
    .brand{min-width:0;overflow:hidden}
    .brand h1{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .brand .brand-suffix{display:none}
    .brand .sub{display:none}
    /* Logo propias (wordmark horizontal) compacto en cel; el crédito queda solo "por Bruno Tosto". */
    .nolter-logo{height:24px;padding:5px 8px;border-radius:8px}
    .brand-div{height:24px;margin:0 1px}
    .bc-extra{display:none}
    .brand-credit{font-size:9px;margin-top:2px;color:rgba(255,255,255,.66)}
    .meta-chips,.ctx-chip{display:none}
    .header .doc-btn-header,.header .upload-btn{display:none}
    /* Filtros + Mi cartera -> solo icono en mobile; las acciones de carga/publicacion
       quedan fuera del uso diario del APM para liberar foco a ficha, marcas y mercados. */
    .header .ghost-btn,.header .apm-btn{font-size:0;gap:0;padding:8px;max-width:none}
    .header .ghost-btn .ic,.header .apm-btn .ic{font-size:13px}
    .container{padding:8px 12px 90px;gap:8px;min-width:0}
    /* KPI summary cards ocultas en mobile (Bruno: no aportan al análisis y tapan) */
    .summary{display:none}
    /* Anti-overflow: los items del grid pueden encogerse y no empujar el ancho */
    .main{min-width:0;max-width:100%}
    #tab-content{min-width:0;max-width:100%}
    /* Todos los toolbars envuelven y sus grupos de botones también, así nada se corta */
    .toolbar,.tc-toolbar,.po-toolbar,.gir-toolbar,.oppo-toolbar{
      flex-wrap:wrap;align-items:flex-start;gap:8px;padding:10px 12px;
    }
    .toolbar .actions,.gir-toolbar .actions{display:flex;flex-wrap:wrap;gap:6px;width:100%}
    .tc-toolbar > div,.po-toolbar > div{flex-wrap:wrap}
    /* Pill-toggle (vista Conquistar/Retener/Todos, sort TRIM/MES) con scroll
       interno si no entra, así no desborda la pantalla. */
    .pill-toggle{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .pill-toggle::-webkit-scrollbar{display:none}
    /* Sub-filtros (Plan Semanal, Por OSS) full width y selects que no desbordan */
    .po-subfilters{flex-direction:column;align-items:stretch}
    .po-subfilters select,.po-subfilters .input-search{width:100%;max-width:none}
    .mobile-filters-btn{display:inline-flex;align-items:center}
    .sidebar{
      display:block;position:fixed;top:0;left:0;bottom:0;width:90vw;max-width:340px;
      z-index:100;border-radius:0;background:#fff;box-shadow:0 0 40px rgba(0,0,0,.3);
      overflow-y:auto;max-height:100vh;padding:14px;
      transform:translateX(-100%);transition:transform .22s ease,opacity .22s ease;
      opacity:0;visibility:hidden;
    }
    body.sidebar-open .sidebar{
      transform:translateX(0);opacity:1;visibility:visible;
    }
    #sidebar-backdrop{
      display:block;position:fixed;top:0;left:0;right:0;bottom:0;
      background:rgba(15,23,42,.55);z-index:99;
      opacity:0;visibility:hidden;transition:opacity .22s ease,visibility .22s ease;
    }
    body.sidebar-open #sidebar-backdrop{
      opacity:1;visibility:visible;
    }
    body.sidebar-open{overflow:hidden}
    /* Inputs a 16px en mobile → iOS no hace auto-zoom al enfocar (clave para
       que el buscador se sienta amigable). */
    input[type=text]{font-size:16px !important}
    .input-search input[type=text]{font-size:16px !important}
    .ficha-search{padding:12px 14px}
    .ficha-search .input-search{max-width:none}
    .ficha-search input{font-size:16px;padding:12px 14px}
    /* Lista fluye natural (sin scroll-box anidado) y el placeholder vacío
       ocupa poco — así no queda el espacio blanco grande abajo. */
    .ficha-results{padding:8px 14px;max-height:none;overflow:visible}
    .empty{padding:28px 18px}
    /* Items de búsqueda más altos y tapeables */
    .ficha-medico-item{padding:12px;gap:8px}
    .ficha-medico-item .nm{font-size:14px}
    .ficha-detail{padding:10px 12px;display:flex;flex-direction:column}
    .ficha-detail > .ficha-hero{order:0}
    .ficha-detail > .ficha-quick-actions{order:1}
    .ficha-detail > .decision-card{order:2}
    .ficha-detail > .head{order:3}
    .ficha-detail > .ficha-market-list{order:4}
    .ficha-detail > .ficha-memoria{order:5}
    .ficha-detail > .ficha-oss-wrap{order:6}
    .ficha-detail .head{padding:11px 12px;margin-bottom:9px}
    .ficha-detail .head h2{font-size:19px}
    .ficha-head-actions{width:100%}
    .ficha-head-actions .pdf-btn{flex:1;justify-content:center}
    .ficha-detail .head .row{flex-direction:column;gap:2px;margin-bottom:8px}
    .ficha-detail .head .row .lbl{min-width:0;font-size:11px}
    .ficha-detail .head .ficha-meta-row,.ficha-detail .head .ficha-foot-tools{display:none}
    .ficha-detail .head .ficha-summary-row{margin-top:0 !important;padding-top:0 !important;border-top:none !important}
    .ficha-hero{padding:12px 13px;border-radius:var(--radius-lg);margin-bottom:8px}
    .ficha-hero .fh-top{gap:11px}
    .ficha-hero .fh-ring{width:64px;height:64px}
    .ficha-hero .fh-ring svg{width:64px;height:64px}
    .ficha-hero .fh-num b{font-size:21px}
    .ficha-hero h2{font-size:17px;line-height:1.18}
    .ficha-hero .fh-meta{font-size:11.5px;line-height:1.35}
    .ficha-hero .fh-badges{margin-top:9px;gap:5px}
    .ficha-quick-actions{position:sticky;top:52px;z-index:35;background:rgba(246,247,251,.96);backdrop-filter:blur(8px);margin:0 -12px 8px;padding:8px 12px;border-bottom:1px solid var(--line)}
    .fqa-btn,.fqa-link{min-height:36px;padding:8px 11px;font-size:12px}
    .decision-card{padding:11px 12px;margin-bottom:8px}
    .decision-card .dc-head{margin-bottom:6px}
    .decision-card .dc-line{font-size:12.5px;line-height:1.4;margin-bottom:4px}
    .decision-card .dc-row{margin-bottom:6px}
    .ficha-memoria{margin:0 0 10px;padding:10px 11px}
    .ficha-memoria .fm-actions .fm-visited{display:none}
    .ficha-memoria .fm-head{margin-bottom:7px}
    .ficha-memoria .fm-note{min-height:50px}
    .ficha-section-title{margin:0 0 8px;padding:9px 11px}
    .ficha-mkt-head{padding:9px 12px}
    .ficha-mkt-head .name{font-size:13px}
    .ficha-mkt-head .stats{gap:5px;font-size:11px}
    .ficha-mkt-head .stats .pill{padding:2px 7px;font-size:11px}
    /* En mobile la tabla DEBE entrar en el viewport — sin scroll lateral.
       Sacamos el min-width:440px (que la forzaba más ancha que la pantalla del iPhone),
       y dejamos que el browser reparta el ancho entre Producto (texto, wrappable) y
       las 4 columnas numéricas (rnk/%MS por trim y mes). */
    .ficha-prod-table{font-size:12px;min-width:0;table-layout:auto}
    .ficha-prod-table th,.ficha-prod-table td{padding:5px 5px}
    .ficha-prod-table th.num,.ficha-prod-table td.num{padding:6px 4px;font-size:12px}
    .ficha-prod-table td:first-child{word-break:break-word;line-height:1.3;font-size:12.5px}
    .ficha-prod-table th:first-child{padding-left:8px}
    .ficha-prod-table th.grp{font-size:10px;letter-spacing:0}
    .oppo-grid{grid-template-columns:1fr}
    .oppo-toolbar{padding:10px 12px;gap:8px}
    .oppo-toolbar label{font-size:11px}
    /* Toolbar global en mobile: UNA sola fila compacta (scope + región) que scrollea horizontal.
       Alto constante (~44px) en TODAS las solapas → el contenido no salta y no queda hueco en Giras.
       El contador se oculta en mobile (cada solapa ya muestra su propio encabezado/conteo). */
    .toolbar{padding:8px 12px;font-size:12px;gap:10px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;align-items:center}
    .toolbar::-webkit-scrollbar{display:none}
    /* "Mi cartera | Todos" queda fijo a la izquierda: aunque la franja de regiones
       scrollee, el toggle de cartera no desaparece de la vista. */
    .toolbar .scope-toggle{flex-shrink:0;position:sticky;left:0;z-index:2;box-shadow:8px 0 8px -6px rgba(15,23,42,.10)}
    .toolbar .result-count{display:none}
    .toolbar .geo-toggle{flex-shrink:0;width:auto;max-width:none;overflow:visible}
    .geo-toggle{gap:4px}
    .geo-toggle button,.scope-toggle button{padding:4px 9px;font-size:11.5px}
    .medico-grid{grid-template-columns:1fr;padding:10px;gap:8px}
    .table-wrap{max-height:none}
    /* Generic table polish in mobile: tighter padding + sticky first col so
       médico name stays visible while user scrolls horizontally. */
    .table-wrap table{font-size:12px}
    .table-wrap th,.table-wrap td{padding:6px 8px}
    .table-wrap th:first-child,.table-wrap td:first-child{
      position:sticky;left:0;background:#fff;z-index:1;box-shadow:1px 0 0 var(--line);
    }
    .table-wrap thead th:first-child{background:var(--bg-warm);z-index:2}
  }

  /* === Fase 1: Resumen Ejecutivo === */
  #resumen-ejecutivo{grid-column:1/-1;margin-bottom:8px}
  .re-card{background:linear-gradient(160deg,#111c30,#0f172a);color:#fff;border:1px solid rgba(148,163,184,.16);border-radius:var(--radius-lg);padding:13px 18px;box-shadow:0 10px 30px -16px rgba(15,23,42,.5)}
  /* Colapsable: por defecto solo se ve la barra del header; el body se expande al tap. */
  .re-header{display:flex;justify-content:space-between;align-items:center;gap:8px;cursor:pointer;user-select:none}
  .re-body{display:none;margin-top:14px;padding-top:14px;border-top:1px solid rgba(148,163,184,.14)}
  .re-card.open .re-body{display:block}
  .re-chevron{transition:transform .15s ease;color:#94a3b8;flex-shrink:0}
  .re-card.open .re-chevron{transform:rotate(180deg)}
  .re-header-right{display:flex;align-items:center;gap:10px}
  .re-title{font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#f1f5f9;display:inline-flex;align-items:center}
  .re-title .ic{color:#93c5fd}
  .re-date{font-size:11px;color:#94a3b8;text-transform:capitalize}
  .re-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:10px;margin-bottom:12px}
  .re-metric{background:rgba(255,255,255,.05);border:1px solid rgba(148,163,184,.14);border-radius:var(--radius);padding:9px 11px;min-height:62px;display:flex;flex-direction:column;justify-content:center}
  .re-num{font-size:22px;font-weight:700;line-height:1;margin-bottom:3px;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
  .re-num-txt{font-size:13.5px;font-weight:600;letter-spacing:-.005em;color:#e2e8f0;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
  .re-lbl{font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-weight:600;line-height:1.2}
  .re-insight{background:rgba(147,197,253,.08);border-left:2px solid #93c5fd;border-radius:8px;padding:11px 14px;font-size:13px;line-height:1.55;color:#e2e8f0}
  .re-insight strong{color:#fff;font-weight:600}
  .re-actions{display:flex;flex-direction:column;gap:7px;margin-top:10px}
  .re-action{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;line-height:1.45;color:#e2e8f0;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:9px 12px}
  .re-action .ic{flex-shrink:0;margin-top:1px}
  .re-action strong{color:#fff;font-weight:700}
  .re-action.prio{cursor:pointer}
  .re-action.prio:hover{background:rgba(255,255,255,.09)}
  .re-action.prio .ic{color:#fca5a5}
  .re-action.grow .ic{color:#86efac}
  .re-action.gap .ic{color:#fcd34d}
  .re-actions-h{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8;margin:12px 0 2px}
  .re-empty{background:#f8fafc;border:1px dashed var(--line);border-radius:var(--radius);padding:18px;text-align:center;color:var(--ink-soft);font-size:13px;font-style:italic}
  @media (max-width:1280px){.re-grid{grid-template-columns:repeat(4,1fr)}}
  @media (max-width:768px){.re-grid{grid-template-columns:repeat(2,1fr)} .re-num{font-size:18px} .re-card{padding:11px 14px} .re-date{display:none} .re-title{font-size:12px}}

  /* === Mobile chrome cleanup (2026-05) === En pantalla de teléfono el chrome de arriba
     (resumen ejecutivo colapsado + intro Ganá rápido + insight + exports) come ~250 px
     antes del primer médico. Lo escondemos en mobile y queda intacto en desktop. */
  #result-count:empty{display:none}
  @media (max-width:780px){
    /* La Dynamic Island es una pill negra encima del status bar. El padding-top:env(safe-area-inset-top)
       lo empuja el header debajo, pero como ambos son negros, visualmente se "tocan" sin separación.
       Le sumamos 10px extra para que la pill y el header tengan respiro visible. */
    .header{padding-top:calc(env(safe-area-inset-top) + 10px) !important}
    #resumen-ejecutivo{display:none}
    .tc-intro{display:none}
    .gr-insight{display:none !important}
    .tc-exports{display:none}
    .md-hero .md-greet, .md-hero h2, .md-hero > p{display:none}
    /* Hero compacto: es el panel para programar el día/semana, no debe comer media pantalla. */
    .md-hero{padding:9px 11px;margin-bottom:8px;border-radius:12px}
    .md-daynav{margin:0}
    .md-daynav-btn{width:30px;height:30px}
    .md-ciclo{margin:8px 0 0}
    .md-ciclo-txt{margin-top:5px;font-size:11.5px;gap:3px}
    .md-ciclo-meta{display:none}
    .md-hood{margin-top:8px;gap:6px}
    .md-gira-note{margin-top:8px;font-size:11.5px}
    .md-hero-actions{gap:6px;margin-top:2px}
    .md-hero-actions .md-jump,
    .md-hero-actions .md-hoy,
    .md-hero-actions .md-export,
    .md-hero-actions .md-vdone{margin-top:8px;padding:5px 10px 5px 8px;font-size:11.5px}
    .geo-toggle button{padding:4px 7px;font-size:11px}
    .geo-toggle{gap:2px}
    .ficha-search-compact{padding:2px 0;border:none;background:transparent}
    .ficha-search-compact .search-toggle{background:transparent;border:none;padding:4px 2px;color:var(--ink-soft);font-size:12px;font-weight:500}
    .ficha-search-compact .search-toggle:hover{color:var(--brand)}
  }

  /* === Vista Gerente === Audit: kill violet rainbow, mono navy chrome */
  .vg-intro{padding:14px 20px;background:#fff;border-bottom:1px solid var(--line)}
  .vg-intro h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}
  .vg-intro h3 .ic{color:var(--ink-soft)}
  .vg-intro div{font-size:13px;color:var(--ink-soft)}
  .vg-alerts{background:#fff;padding:12px 16px;border-bottom:1px solid var(--line)}
  .vg-alerts-title{font-size:10.5px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:inline-flex;align-items:center;gap:6px}
  .vg-alert{padding:8px 12px;border-radius:var(--radius-sm);font-size:12.5px;margin-bottom:4px;font-weight:500;display:inline-flex;align-items:center;gap:6px}
  .vg-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:8px}
  .vg-toolbar button{padding:7px 12px;border:1px solid var(--line);border-radius:7px;color:var(--ink);background:#fff;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
  .vg-toolbar button:hover{border-color:var(--line-strong);color:var(--brand)}
  .vg-list{padding:8px}
  .vg-rep-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;box-shadow:var(--shadow)}
  .vg-rep-head{display:grid;grid-template-columns:48px 1fr auto;gap:12px;padding:12px 16px;align-items:center;background:var(--bg-warm);border-bottom:1px solid var(--line)}
  .vg-rep-rank{font-size:22px;font-weight:600;color:var(--navy);text-align:center;font-variant-numeric:tabular-nums;letter-spacing:-.02em}
  .vg-rep-name{font-size:15px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:6px}
  .vg-rep-meta{font-size:11.5px;color:var(--ink-soft);margin-top:2px}
  .vg-rep-cats{display:flex;gap:6px;flex-wrap:wrap}
  .vg-cat-pill{padding:3px 9px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums}
  .vg-rep-detail{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;padding:12px 16px}
  .vg-detail-col{}
  .vg-detail-label{font-size:10.5px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;border-bottom:1px solid var(--line-2);padding-bottom:5px}
  .vg-detail-item{font-size:12.5px;padding:4px 0;color:var(--ink);display:flex;align-items:center;gap:6px}
  .vg-detail-item[data-medico-id]:hover{background:var(--bg-warm);border-radius:5px;padding-left:6px;padding-right:6px;cursor:pointer}
  @media (max-width:900px){.vg-rep-detail{grid-template-columns:1fr}.vg-rep-head{grid-template-columns:36px 1fr}.vg-rep-cats{grid-column:1/-1;margin-top:6px}}


  /* === Priority badge inline === */
  .prio-badge{display:inline-block;padding:2px 7px;border-radius:5px;font-size:10px;font-weight:600;white-space:nowrap;vertical-align:middle}

  /* === Por Obra Social === */
  /* === Por Obra Social === Audit: flat chrome, mono navy, neutral table */
  .po-intro{padding:14px 20px;background:#fff;border-bottom:1px solid var(--line)}
  .po-intro h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}
  .po-intro h3 .ic{color:var(--ink-soft)}
  .po-intro div{font-size:13px;color:var(--ink-soft)}
  .po-alerts{background:#fff;padding:10px 16px;border-bottom:1px solid var(--line)}
  .po-subfilters{display:flex;gap:8px;padding:10px 16px;background:var(--bg-warm);border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center}
  .po-subfilters .input-search{min-width:220px;flex:1;max-width:320px}
  .po-subfilters select{padding:7px 10px;border:1px solid var(--line);border-radius:7px;background:#fff;font:13px/1 var(--font);color:var(--ink);cursor:pointer;height:36px}
  .po-subfilters select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .po-summary{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}
  .po-type-chip{padding:3px 9px;border-radius:var(--radius-pill);font-size:11px;font-weight:500;white-space:nowrap;font-variant-numeric:tabular-nums}
  .po-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#fff;border-bottom:1px solid var(--line);flex-wrap:wrap;gap:8px}
  .po-toolbar button{padding:7px 12px;border:1px solid var(--line);border-radius:7px;background:#fff;color:var(--ink);font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px}
  .po-toolbar button:hover{border-color:var(--line-strong);color:var(--brand)}
  .po-table-wrap{overflow-x:auto;max-height:calc(100vh - 400px)}
  .po-table{width:100%;border-collapse:collapse;font-size:12.5px}
  .po-table th{background:var(--bg-warm);color:var(--ink-soft);padding:10px 9px;text-align:left;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;position:sticky;top:0;z-index:2;border-bottom:1px solid var(--line-strong);white-space:nowrap}
  .po-table td{padding:9px;border-bottom:1px solid var(--line-2);vertical-align:middle}
  .po-table tr:hover td{background:var(--bg-warm)}
  /* PAMI strategic foco — flat with navy accent stripe instead of blue gradient */
  .po-pami-block{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:14px 18px;margin:12px 16px;overflow:hidden}
  .po-pami-block::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--navy)}
  .po-pami-title{font-size:11px;font-weight:600;color:var(--ink-faint);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:6px}
  .po-pami-text{font-size:13px;color:var(--ink);line-height:1.5}

  /* === Por OSS mobile · tabla 11-col → cards apilables. Columnas visibles:
     OOSS, Tipo, Médicos+Recetas (combinadas), %. Las demás (Top mercados,
     Top marcas, Top APMs, Productos OK/barrera) se ocultan en la card y siguen
     accesibles vía la fila expandible de detalle. */
  @media (max-width:780px){
    .po-table-wrap{max-height:none;overflow-x:visible}
    .po-table,
    .po-table thead,
    .po-table tbody,
    .po-table tr,
    .po-table td{display:block;width:100%}
    .po-table thead{display:none}
    .po-table tr.po-oss-row{
      background:#fff;border:1px solid var(--line);border-radius:var(--radius);
      padding:12px 14px;margin:0 12px 8px;box-shadow:var(--shadow);cursor:pointer;
    }
    .po-table tr.po-oss-row td{padding:0;border:none;font-size:13px}
    /* Hide: TopMercados (7), TopMarcas (8), TopAPMs (9), ProductosOK (10), ProductosBarrera (11) */
    .po-table tr.po-oss-row td:nth-child(7),
    .po-table tr.po-oss-row td:nth-child(8),
    .po-table tr.po-oss-row td:nth-child(9),
    .po-table tr.po-oss-row td:nth-child(10),
    .po-table tr.po-oss-row td:nth-child(11){display:none}
    /* Hero: # + OOSS name on same line */
    .po-table tr.po-oss-row td:nth-child(1){
      display:inline-block;width:auto;color:var(--ink-faint);margin-right:8px;
    }
    .po-table tr.po-oss-row td:nth-child(2){
      display:inline-block;width:auto;font-weight:600;font-size:15px;color:var(--ink);
    }
    .po-table tr.po-oss-row td:nth-child(3){  /* Tipo */
      margin-top:6px;font-size:12px;
    }
    .po-table tr.po-oss-row td:nth-child(4),  /* Médicos */
    .po-table tr.po-oss-row td:nth-child(5),  /* Recetas */
    .po-table tr.po-oss-row td:nth-child(6){  /* % */
      display:inline-flex;align-items:baseline;gap:5px;margin-right:14px;
      font-size:12.5px;color:var(--ink);font-variant-numeric:tabular-nums;
    }
    .po-table tr.po-oss-row td:nth-child(4)::before{content:'Médicos:';color:var(--ink-faint);font-weight:500}
    .po-table tr.po-oss-row td:nth-child(5)::before{content:'Recetas:';color:var(--ink-faint);font-weight:500}
    .po-table tr.po-oss-row td:nth-child(6)::before{content:'';display:none}
    /* Detail row (expanded médicos) — full width, no padding margins */
    .po-table tr.po-meds-row{margin:0 12px 8px;border-radius:var(--radius);padding:12px}
    .po-table tr.po-meds-row td{padding:0;border:none}
  }

    /* === Vista Gerente coverage + portfolio === Audit: neutral section heads,
     mono navy bars, semantic accent only on alerts/insights. */
  .vg-coverage{background:#fff;border-bottom:1px solid var(--line);padding:14px 16px}
  .vg-coverage-head,.vg-portfolio-head{font-size:11px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:inline-flex;align-items:center;gap:6px}
  .vg-coverage-grid{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:18px}
  @media (max-width:900px){.vg-coverage-grid{grid-template-columns:1fr}}
  .vg-coverage-sub{font-size:10.5px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;border-bottom:1px solid var(--line-2);padding-bottom:5px}
  .vg-cov-row{display:grid;grid-template-columns:90px 1fr 55px;gap:8px;align-items:center;margin-bottom:6px}
  .vg-cov-lbl{font-size:11px;color:var(--ink)}
  .vg-cov-bar{background:var(--line-2);height:5px;border-radius:var(--radius-pill);overflow:hidden}
  .vg-cov-bar > div{height:100%;border-radius:var(--radius-pill)}
  .vg-cov-val{font-size:11.5px;font-weight:600;text-align:right;font-variant-numeric:tabular-nums;color:var(--ink)}
  .vg-cov-oss{font-size:11.5px;padding:3px 0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
  .vg-coverage-insight{background:var(--brand-soft);border-left:3px solid var(--brand);border-radius:var(--radius-sm);padding:9px 12px;margin-top:10px;font-size:12px;color:var(--brand-dark);line-height:1.5;display:flex;align-items:center;gap:8px}
  .vg-coverage-insight strong{color:var(--ink)}
  .vg-portfolio{background:#fff;border-bottom:1px solid var(--line);padding:14px 16px}
  .vg-portfolio-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}
  @media (max-width:1100px){.vg-portfolio-grid{grid-template-columns:repeat(3,1fr)}}
  @media (max-width:600px){.vg-portfolio-grid{grid-template-columns:repeat(2,1fr)}}
  .vg-port-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:10px 12px;text-align:center;min-height:74px;display:flex;flex-direction:column;justify-content:center}
  .vg-port-success{border-left:3px solid var(--good)}
  .vg-port-danger{border-left:3px solid var(--bad);background:var(--bad-tint)}
  .vg-port-warn{border-left:3px solid var(--warn);background:var(--warn-tint)}
  .vg-port-info{border-left:3px solid var(--brand);background:var(--brand-soft)}
  .vg-port-num{font-size:20px;font-weight:600;color:var(--ink);line-height:1;margin-bottom:4px;font-variant-numeric:tabular-nums;letter-spacing:-.015em}
  .vg-port-lbl{font-size:10.5px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;font-weight:600;line-height:1.2}
  .vg-portfolio-insight{background:var(--warn-tint);border-left:3px solid var(--warn);border-radius:var(--radius-sm);padding:9px 12px;margin-top:10px;font-size:12px;color:var(--warn-ink);line-height:1.5;display:flex;align-items:flex-start;gap:8px}

  /* === Decisión 30 segundos === Refined to match the audit's frozen palette:
     no gradients, solid surfaces, 3px accent stripe on the left, monochrome
     hierarchy. The variant classes (critical/medium/low) keep their semantic
     role; default state is now neutral (navy stripe) instead of amber. */
  .decision-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:14px;box-shadow:var(--shadow);overflow:hidden}
  .decision-card::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:var(--navy)}
  .decision-card.critical{background:#fff;border-color:var(--line)}
  .decision-card.critical::before{background:var(--bad)}
  .decision-card.medium{background:#fff;border-color:var(--line)}
  .decision-card.medium::before{background:var(--brand)}
  .decision-card.low{background:var(--bg-warm);border-color:var(--line)}
  .decision-card.low::before{background:var(--ink-faint)}
  /* Audit-faithful: amber accent reserved for "producto foco / propias" cells only */
  .decision-card.foco::before{background:var(--warn)}
  .dc-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:10px}
  .dc-label{font-size:10.5px;font-weight:600;color:var(--ink-faint);letter-spacing:.08em;text-transform:uppercase}
  .decision-card.critical .dc-label{color:var(--brand)}
  .decision-card.medium .dc-label{color:var(--brand)}
  .decision-card.low .dc-label{color:var(--ink-faint)}
  .dc-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:8px}
  .dc-line{font-size:13.5px;color:var(--ink);line-height:1.5;margin-bottom:5px;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
  .dc-line strong{color:var(--ink);font-weight:600}
  .dc-line .ic{color:var(--ink-soft);flex-shrink:0}
  /* Barrera de acceso — antes era una caja roja gigante (border-left 3px + padding 10px + font 12.5).
     Ahora un strip sobrio: border-left fino, padding apretado, fuente más chica. La info queda
     completa, baja el volumen visual. */
  .dc-alerta{margin-top:8px;padding:6px 10px;background:#fff;border-left:2px solid var(--bad);color:var(--bad-ink);font-size:11.5px;font-weight:500;border-radius:0 4px 4px 0;display:flex;align-items:flex-start;gap:6px;line-height:1.35}
  .dc-alerta .ic{color:var(--bad);flex-shrink:0;margin-top:1px}
  .dc-alerta strong{font-weight:600}
  .dc-producto{font-size:13.5px;font-weight:600;padding:3px 10px;border-radius:7px;background:var(--brand-soft);color:var(--brand-dark);border:1px solid #cfe0ff;font-variant-numeric:tabular-nums}
  .dc-producto.oltux{background:var(--navy);color:#fff;border-color:var(--navy)}
  /* Acción CORTA imperativa — protagonista, legible en 2 segundos. La explicación larga va en "Por qué". */
  .dc-accion-short{display:flex;align-items:center;gap:7px;font-size:15.5px;font-weight:800;color:var(--ink);line-height:1.25;margin:6px 0 4px;letter-spacing:-.01em}
  .dc-accion-short .ic{color:var(--brand);flex:none;width:16px;height:16px}
  .dc-why{margin:2px 0 5px}
  .dc-why>summary{list-style:none;cursor:pointer;font-size:11.5px;font-weight:700;color:var(--ink-mute);display:inline-flex;align-items:center;gap:5px;-webkit-tap-highlight-color:transparent}
  .dc-why>summary::-webkit-details-marker{display:none}
  .dc-why>summary::after{content:"";width:6px;height:6px;border-right:2px solid var(--ink-mute);border-bottom:2px solid var(--ink-mute);transform:rotate(45deg);transition:transform .15s}
  .dc-why[open]>summary::after{transform:rotate(-135deg)}
  .dc-why-body{font-size:12.5px;color:var(--ink-soft);line-height:1.45;margin-top:5px}

  /* Ficha head — cleaner panel with chip line under title. */
  .ficha-detail .head{border:1px solid var(--line);border-radius:var(--radius);padding:16px 18px;margin-bottom:14px;background:#fff;box-shadow:var(--shadow)}
  .ficha-detail .head h2{margin:0 0 8px;font-size:22px;font-weight:600;letter-spacing:-.015em;color:var(--ink)}
  .ficha-detail .head .row{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;margin-bottom:5px;align-items:baseline}
  .ficha-detail .head .row .lbl{font-weight:500;color:var(--ink-faint);min-width:120px;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em}
  /* Action buttons in ficha head — kill the rainbow (was red PDF, green WhatsApp,
     cyan Resumen). Single ghost style + one primary "Compartir". */
  .pdf-btn{background:#fff;color:var(--ink);border:1px solid var(--line);padding:7px 12px;border-radius:7px;font-size:12.5px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:6px;flex-shrink:0}
  .pdf-btn:hover{border-color:var(--line-strong);color:var(--brand)}
  .pdf-btn.primary{background:var(--brand);color:#fff;border-color:var(--brand)}
  .pdf-btn.primary:hover{background:var(--brand-dark);color:#fff}
  .pdf-btn .ic{color:currentColor}
  /* Sort pill toggle — flatter, navy active */
  .pill-toggle{display:inline-flex;background:#eef2f7;border:none;border-radius:9px;padding:3px;gap:2px}
  .ficha-sort-btn{padding:5px 14px;background:transparent;border:none;color:var(--ink-mute);border-radius:7px;font-size:12.5px;font-weight:600;cursor:pointer;transition:color var(--duration-fast) ease-out}
  .ficha-sort-btn:hover{color:var(--ink)}
  .ficha-sort-btn.active,.ficha-sort-btn.active:hover{background:#fff;color:var(--navy);box-shadow:0 1px 3px rgba(15,23,42,.12),0 1px 1px rgba(15,23,42,.04);font-weight:600}

  /* Ficha search header — match the audit's "best input" pattern */
  .ficha-search{padding:14px 20px;background:#fff;border-bottom:1px solid var(--line)}
  .ficha-search .input-search{max-width:560px}
  .ficha-search-compact{padding:10px 18px;background:var(--bg-warm);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;font-size:13px}
  .ficha-search-compact .info{color:var(--ink-soft);display:inline-flex;align-items:center;gap:6px}
  .ficha-search-compact .info strong{color:var(--ink);font-weight:600}
  .search-toggle{background:transparent;border:none;color:var(--brand);font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:5px;padding:4px 8px;border-radius:var(--radius-sm)}
  .search-toggle:hover{background:var(--brand-soft)}

  /* === Ficha rediseñada: hero con anillo de score === */
  .ficha-hero{background:linear-gradient(155deg,#1e293b,#0f172a 72%);border:1px solid rgba(148,163,184,.12);border-radius:16px;padding:16px 18px;color:#fff;margin-bottom:12px;position:relative;overflow:hidden}
  .ficha-hero::after{content:"";position:absolute;right:-46px;top:-46px;width:150px;height:150px;background:radial-gradient(circle,rgba(37,99,235,.20),transparent 70%);pointer-events:none}
  .ficha-hero .fh-top{display:flex;gap:14px;align-items:center;position:relative}
  .ficha-hero .fh-ring{position:relative;width:84px;height:84px;flex:0 0 auto}
  .ficha-hero .fh-num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
  .ficha-hero .fh-num b{font-size:27px;font-weight:700;line-height:1;letter-spacing:-.03em;color:#fff}
  .ficha-hero .fh-num span{font-size:9px;color:#cbd5e1;font-weight:700;letter-spacing:.08em;margin-top:2px}
  .ficha-hero h2{font-size:20px;font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0 0 4px;color:#fff;border:none;padding:0}
  .ficha-hero .fh-meta{font-size:12.5px;color:#cbd5e1;line-height:1.5}
  .ficha-hero .fh-meta b{color:#fff;font-weight:600}
  .ficha-hero .fh-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:13px;position:relative}
  /* Dirección tocable (Cómo llegar) */
  .ficha-addr-link{color:inherit;text-decoration:none;display:inline-flex;align-items:flex-start;gap:5px}
  .ficha-addr-link:hover .addr-go{text-decoration:underline}
  .ficha-addr-link .addr-go{color:var(--brand);font-weight:600;font-size:11.5px;margin-left:4px;white-space:nowrap}
  /* Dirección editable (override local "por si se muda") */
  /* === Hoja modal "Datos del médico" ===
     Mobile: bottom sheet que sube de abajo (patrón iOS). Desktop: modal centrado.
     refresh() re-renderea la ficha entera; el flag _fichaDatosOpen restaura la clase .open. */
  .fdm-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:1000;opacity:0;pointer-events:none;transition:opacity .22s ease}
  .fdm-overlay.open{opacity:1;pointer-events:auto}
  .fdm-sheet{position:fixed;left:0;right:0;bottom:0;z-index:1001;background:#fff;border-radius:18px 18px 0 0;max-height:88vh;overflow-y:auto;transform:translateY(100%);transition:transform .28s cubic-bezier(.32,.72,0,1);box-shadow:0 -10px 40px rgba(15,23,42,.22);padding:0 16px max(20px,env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}
  .fdm-sheet.open{transform:translateY(0)}
  .fdm-grip{width:38px;height:4px;background:#cbd5e1;border-radius:2px;margin:9px auto 12px;cursor:pointer}
  .fdm-head{display:flex;align-items:center;justify-content:space-between;margin:0 0 12px;padding-bottom:10px;border-bottom:1px solid var(--line)}
  .fdm-head h3{margin:0;font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
  .fdm-close{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--ink-soft);border-radius:8px;display:inline-flex;align-items:center;justify-content:center}
  .fdm-close:hover{background:var(--bg-warm);color:var(--ink)}
  .fdm-body{padding:4px 0 8px}
  .fdm-section{padding:10px 0}
  .fdm-section + .fdm-section{border-top:1px solid var(--line-2)}
  .fdm-section .ficha-addr-row{display:flex;flex-direction:column;gap:8px;font-size:14px}
  .fdm-section .ficha-addr-row .lbl{font-size:10.5px;font-weight:600;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;min-width:0}
  .fdm-section .fa-display{width:100%;gap:10px 12px}
  .fdm-section .fa-text{font-size:14.5px;line-height:1.4;max-width:100%}
  .fdm-section .fa-txt{word-break:break-word}
  body.fdm-locked{overflow:hidden}
  @media (min-width:781px){
    /* Desktop: centramos como modal */
    .fdm-sheet{left:50%;right:auto;bottom:auto;top:50%;transform:translate(-50%,-46%) scale(.96);max-width:520px;width:92vw;border-radius:var(--radius-lg);max-height:80vh;opacity:0;padding:0 20px 20px}
    .fdm-sheet.open{transform:translate(-50%,-50%) scale(1);opacity:1}
    .fdm-grip{display:none}
    .fdm-head{margin-top:18px}
  }
  .fa-display{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px 10px}
  .fa-text{display:inline-flex;align-items:flex-start;gap:6px;background:none;border:none;padding:0;margin:0;cursor:pointer;color:var(--ink);font:inherit;font-size:13px;text-align:left;line-height:1.4}
  .fa-text .fa-txt{border-bottom:1px dashed var(--line-strong)}
  .fa-text:hover .fa-txt{border-bottom-color:var(--brand);color:var(--brand-dark)}
  .fa-text .fa-pencil{color:var(--ink-faint);flex-shrink:0;margin-top:1px}
  .fa-text:hover .fa-pencil{color:var(--brand)}
  .fa-edited{font-size:10px;font-weight:600;color:var(--ink-mute);background:var(--bg-warm);border:1px solid var(--line);border-radius:var(--radius-pill);padding:1px 8px;text-transform:uppercase;letter-spacing:.04em}
  .fa-go{display:inline-flex;align-items:center;gap:4px;color:var(--brand);font-weight:600;font-size:11.5px;text-decoration:none;white-space:nowrap}
  .fa-go:hover{text-decoration:underline}
  .fa-go .ic{width:13px;height:13px}
  .fa-add{display:inline-flex;align-items:center;gap:6px;background:var(--bg-warm);border:1px dashed var(--line-strong);color:var(--ink-soft);border-radius:8px;padding:7px 12px;font-size:12.5px;font-weight:600;cursor:pointer}
  .fa-add:hover{border-color:var(--brand);color:var(--brand)}
  .fa-add .ic{color:var(--ink-soft)}
  .fa-add:hover .ic{color:var(--brand)}
  .fa-form{display:flex;flex-direction:column;gap:8px;width:100%;max-width:420px}
  .fa-form input{width:100%;border:1px solid var(--line-strong);border-radius:8px;padding:9px 11px;font:inherit;font-size:14px;color:var(--ink);background:#fff;outline:none}
  .fa-form input:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
  .fa-row2{display:flex;gap:8px}
  .fa-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
  .fa-save{display:inline-flex;align-items:center;gap:6px;background:var(--brand);color:#fff;border:1px solid transparent;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}
  .fa-save:hover{background:var(--brand-dark)}
  .fa-save .ic{color:#fff}
  .fa-cancel{background:#fff;border:1px solid var(--line-strong);color:var(--ink-soft);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;cursor:pointer}
  .fa-cancel:hover{border-color:var(--ink-faint);color:var(--ink)}
  .fa-restore{background:none;border:none;color:var(--ink-mute);font-size:12px;font-weight:500;cursor:pointer;text-decoration:underline;margin-left:auto;padding:8px 4px}
  .fa-restore:hover{color:var(--bad)}
  /* === Memoria privada del APM (notas + visitado hoy) — sobre la ficha === */
  .ficha-memoria{background:var(--bg-warm);border:1px solid var(--line);border-radius:var(--radius-lg);padding:13px 14px;margin:0 14px 12px}
  /* Colapsable (<details>): si no hay notas/visitas arranca cerrada → no gasta espacio. */
  .ficha-memoria>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;-webkit-tap-highlight-color:transparent}
  .ficha-memoria>summary::-webkit-details-marker{display:none}
  .ficha-memoria>summary .fm-last{margin-left:auto}
  .ficha-memoria>summary::after{content:"";width:7px;height:7px;border-right:2px solid var(--ink-mute);border-bottom:2px solid var(--ink-mute);transform:rotate(45deg);transition:transform .15s;flex:none}
  .ficha-memoria[open]>summary{margin-bottom:10px}
  .ficha-memoria[open]>summary::after{transform:rotate(-135deg)}
  .ficha-memoria .fm-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:9px;flex-wrap:wrap}
  .ficha-memoria .fm-title{font-size:11.5px;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:5px}
  .ficha-memoria .fm-title svg{color:var(--ink-mute);width:13px;height:13px}
  .ficha-memoria .fm-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  .ficha-memoria .fm-visited{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--line-strong);color:var(--ink-soft);padding:6px 11px;border-radius:8px;font-size:12.5px;font-weight:600;cursor:pointer;line-height:1}
  .ficha-memoria .fm-visited:hover{border-color:var(--brand);color:var(--brand)}
  .ficha-memoria .fm-visited.on{background:var(--good-soft);color:#065f46;border-color:#6ee7b7}
  .ficha-memoria .fm-visited svg{width:13px;height:13px}
  .ficha-memoria .fm-last{font-size:11.5px;color:var(--ink-soft);font-weight:500}
  /* font-size 16px = mínimo que iOS Safari respeta sin auto-zoomear al focar el textarea */
  .ficha-memoria .fm-note{width:100%;min-height:64px;border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-size:16px;font-family:inherit;color:var(--ink);background:#fff;resize:vertical;box-sizing:border-box;line-height:1.4}
  /* Safety net global: cualquier input/textarea/select en táctil ≥16px para evitar el auto-zoom de iOS */
  @media (hover:none) and (pointer:coarse){
    input[type="text"], input[type="search"], input[type="password"], input[type="email"], input[type="number"], textarea, select { font-size:16px !important }
  }
  .ficha-memoria .fm-note:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-soft)}
  .ficha-memoria .fm-note::placeholder{color:var(--ink-faint)}
  /* Pin "✓ hoy" para listas (Top 100 / Plan Semanal) */
  .visited-chip{display:inline-flex;align-items:center;gap:3px;background:var(--good-soft);color:#065f46;border:1px solid #a7f3d0;font-size:10.5px;font-weight:700;padding:1px 6px;border-radius:var(--radius-pill);line-height:1.3;margin-left:4px}
  .visited-chip svg{width:10px;height:10px}
  /* Al abrir un médico, ocultamos la antesala global (resumen + toolbar) para entrar directo al hero */
  body.ficha-zoom #resumen-ejecutivo,
  body.ficha-zoom .toolbar{display:none}
  /* PDF/Excel demotados al pie de la ficha */
  .ficha-foot-tools{display:flex;gap:8px;justify-content:center;margin-top:6px}
  .ficha-foot-tools .pdf-btn{background:var(--brand-soft);border:1px solid transparent;color:var(--brand-dark);font-size:12.5px;font-weight:600;box-shadow:none;padding:8px 16px;border-radius:8px;min-height:36px}
  .ficha-foot-tools .pdf-btn:hover{background:#d7e5ff;border-color:transparent;color:var(--brand-dark)}
  @media (max-width:780px){
    .ficha-hero .fh-ring{
      width:64px !important;
      height:64px !important;
      flex:0 0 64px;
    }
    .ficha-hero .fh-ring svg{
      display:block;
      width:64px !important;
      height:64px !important;
    }
    .ficha-hero .fh-num{
      width:64px;
      height:64px;
      inset:0;
    }
    .ficha-hero .fh-num b{font-size:21px}
    .ficha-hero .fh-num span{font-size:8px;margin-top:1px}
    .ficha-detail .head{padding:11px 12px;margin-bottom:9px}
    .ficha-detail .head h2{font-size:19px}
    .ficha-detail .head .row{flex-direction:column;gap:2px;margin-bottom:8px}
    .ficha-detail .head .row .lbl{min-width:0;font-size:11px}
    .ficha-detail .head .row.ficha-meta-row,
    .ficha-detail .head .ficha-foot-tools{display:none !important}
    .ficha-detail .head .row.ficha-summary-row{margin-top:0 !important;padding-top:0 !important;border-top:none !important}
    .ficha-detail .head .row.ficha-sort-row{gap:6px}
    .ficha-detail .head .row.ficha-sort-row .lbl{display:none}
    .ficha-detail .head .row.ficha-sort-row .pill-toggle{width:100%;display:grid;grid-template-columns:1fr 1fr}
    .ficha-detail .head .row.ficha-sort-row .pill-toggle button{width:100%;justify-content:center}
    .decision-card{padding:11px 12px;margin-bottom:8px}
    .decision-card .dc-head{margin-bottom:6px}
    .decision-card .dc-row{margin-bottom:6px}
    .decision-card .dc-line{font-size:12.5px;line-height:1.4;margin-bottom:4px}
    .decision-card .dc-cobertura{font-size:12px;color:var(--ink-soft)}
    .decision-card .dc-motivo,
    .decision-card .dc-proximo,
    .decision-card .dc-inconcluyente{display:none}
  }
  /* === Solapa Método === */
  .metodo{max-width:900px;margin:0 auto;padding:2px 2px 48px;color:var(--ink)}
  .metodo .m-hero{background:var(--brand-dark,#1e3a8a);color:#fff;border-radius:16px;padding:24px 28px;margin-bottom:6px}
  .metodo .m-hero h2{font-size:24px;font-weight:800;margin:0 0 6px;letter-spacing:-.01em}
  .metodo .m-hero p{font-size:15.5px;line-height:1.55;color:#dbeafe;margin:0}
  .metodo .m-st{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);font-weight:700;margin:30px 0 12px;display:flex;align-items:center;gap:10px}
  .metodo .m-st::before{content:"";width:24px;height:3px;background:var(--brand);border-radius:2px}
  .metodo p{font-size:15px;line-height:1.6;color:var(--ink-soft);margin:8px 0}
  .metodo b{color:var(--ink);font-weight:700}
  .metodo .m-three{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:12px 0}
  .metodo .m-ing{border:1px solid var(--line);border-radius:12px;padding:15px}
  .metodo .m-ing .m-n{width:28px;height:28px;border-radius:8px;background:var(--brand-soft);color:var(--brand);font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:9px}
  .metodo .m-ing strong{display:block;font-size:16px;margin-bottom:3px;color:var(--ink)}
  .metodo .m-ing span{font-size:13.5px;color:var(--ink-soft);line-height:1.45}
  .metodo .m-ing.flag{background:var(--brand-soft);border-color:#bfd4ff}
  .metodo .m-vs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
  .metodo .m-doc{border-radius:12px;padding:16px 18px;border:2px solid}
  .metodo .m-doc.a{background:#fef2f2;border-color:#fecaca}
  .metodo .m-doc.b{background:#ecfdf5;border-color:#bbf7d0}
  .metodo .m-doc .tag{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
  .metodo .m-doc.a .tag{color:#991b1b}
  .metodo .m-doc.b .tag{color:#166534}
  .metodo .m-doc strong{display:block;font-size:15.5px;margin:7px 0 4px;color:var(--ink)}
  .metodo .m-doc span{font-size:13.5px;color:var(--ink-soft);line-height:1.45}
  .metodo .m-hook{background:var(--brand-dark,#1e3a8a);color:#fff;border-radius:12px;padding:16px 20px;text-align:center;font-size:19px;font-weight:800;margin:14px 0;line-height:1.35}
  .metodo .m-hook .g{color:#86efac}
  .metodo .m-hook .r{color:#fca5a5}
  .metodo .m-trust{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:16px 22px;background:#fff}
  .metodo .m-trust .big{font-size:42px;font-weight:800;color:var(--good,#16a34a);line-height:1;white-space:nowrap;text-align:center}
  .metodo .m-trust .big small{display:block;font-size:13px;color:var(--ink-soft);font-weight:600;margin-top:4px}
  .metodo .m-trust .tx{font-size:15px;line-height:1.55;color:var(--ink-soft)}
  .metodo ul.m-list{margin:8px 0;padding-left:0;list-style:none}
  .metodo ul.m-list li{font-size:14.5px;line-height:1.5;color:var(--ink-soft);margin-bottom:8px;padding-left:0}
  .metodo ul.m-list li b{color:var(--ink)}
  .metodo pre{background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:12px 16px;font-size:13px;font-family:var(--font-mono,ui-monospace,monospace);color:var(--ink);overflow-x:auto;line-height:1.5;margin:10px 0}
  .metodo code{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-family:var(--font-mono,ui-monospace,monospace);font-size:13px;color:var(--ink)}
  .metodo .m-note,.prec .p-note{background:var(--brand-soft);border:1px solid #bfd4ff;border-left:3px solid var(--brand);border-radius:8px;padding:13px 16px;font-size:14px;line-height:1.55;color:var(--brand-dark);margin-top:12px}
  @media(max-width:780px){.metodo .m-three,.metodo .m-vs,.metodo .m-trust{grid-template-columns:1fr}.metodo .m-trust .big{text-align:left}}
  /* === Solapa "Mi día" — la primera pantalla del APM === */
  .midia{padding:2px 14px 32px;max-width:760px;margin:0 auto}
  .md-entry{background:#fff;border:1px solid var(--line);border-radius:16px;padding:14px;margin:6px 0 12px;box-shadow:var(--shadow)}
  /* Slim: el buscador va debajo del plan del día, sin chrome de card, para no robar protagonismo a la lista de médicos. */
  .md-entry-slim{background:transparent;border:none;box-shadow:none;padding:0;margin:0 0 10px}
  .md-entry-slim .md-entry-search{margin-bottom:0}
  .md-entry-kicker{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
  .md-entry-title{font-size:18px;font-weight:800;letter-spacing:-.02em;color:var(--ink);margin:0 0 10px;line-height:1.15}
  .md-entry-search{margin-bottom:8px}
  .md-entry-search input{height:46px;font-size:15px;border-radius:12px}
  .md-quick-results{display:none;border:1px solid var(--line);border-radius:12px;overflow:hidden;margin:8px 0 10px;background:#fff}
  .md-quick-results.open{display:block}
  .md-quick-item{width:100%;border:0;border-bottom:1px solid var(--line-2);background:#fff;text-align:left;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer;color:var(--ink)}
  .md-quick-item:last-child{border-bottom:0}
  .md-quick-item:active{background:var(--brand-soft)}
  .md-quick-name{font-size:13.5px;font-weight:750;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .md-quick-meta{font-size:11.5px;color:var(--ink-soft);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .md-quick-go{font-size:11px;font-weight:800;color:var(--brand-dark);white-space:nowrap}
  .md-quick-empty{padding:11px 12px;font-size:12.5px;color:var(--ink-soft)}
  .md-next-brief{border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:14px;padding:12px;background:linear-gradient(180deg,#fff,var(--bg-warm));cursor:pointer}
  .md-next-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
  .md-next-label{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:4px}
  .md-next-name{font-size:15px;font-weight:800;color:var(--ink);line-height:1.2}
  .md-next-meta{font-size:11.5px;color:var(--ink-soft);margin-top:3px}
  .md-next-cta{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 13px;border-radius:10px;background:var(--navy);color:#fff;font-size:12px;font-weight:800;white-space:nowrap}
  .md-next-play{margin-top:10px;font-size:12.5px;line-height:1.35;color:var(--ink-soft)}
  .md-next-play b{color:var(--brand-dark)}
  .md-hero{background:linear-gradient(150deg,#0c4a6e,#0e6ba8);border:1px solid rgba(255,255,255,.12);color:#fff;border-radius:16px;padding:20px 22px;margin:6px 0 14px;position:relative;overflow:hidden}
  .md-hero::after{content:"";position:absolute;right:-40px;top:-40px;width:140px;height:140px;background:radial-gradient(circle,rgba(37,99,235,.2),transparent 70%);pointer-events:none}
  .md-greet{font-size:13px;color:rgba(255,255,255,.9);font-weight:700;letter-spacing:.05em;text-transform:uppercase;position:relative}
  .md-date{font-size:11.5px;color:#94a3b8;font-weight:500;margin-top:3px;position:relative;text-transform:capitalize}
  .md-hero h2{font-size:26px;font-weight:700;margin:10px 0 8px;letter-spacing:-.02em;position:relative;color:#fff;border:none;padding:0}
  .md-hero p{font-size:13.5px;color:rgba(255,255,255,.92);line-height:1.55;margin:0;position:relative}
  .md-hero p b{color:#fff;font-weight:700}
  /* Mi día — navegador de día (plan rotativo) */
  .md-daynav{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;position:relative}
  .md-daynav-btn{width:34px;height:34px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);color:#fff;border-radius:9px;cursor:pointer;transition:background var(--duration-fast) ease-out}
  .md-daynav-btn:hover:not(:disabled){background:rgba(255,255,255,.2)}
  .md-daynav-btn:disabled{opacity:.32;cursor:default}
  .md-daynav-btn .ic{width:18px;height:18px}
  .md-daynav-mid{flex:1;text-align:center;line-height:1.15}
  .md-daynav-rel{display:block;font-size:11px;font-weight:800;letter-spacing:.08em;color:rgba(255,255,255,.85)}
  .md-daynav-date{display:block;font-size:13.5px;font-weight:600;color:#fff;text-transform:capitalize}
  .md-hero-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
  .md-hoy{display:inline-flex;align-items:center;gap:4px;margin-top:12px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;font-size:12px;font-weight:600;padding:6px 12px 6px 9px;border-radius:8px;cursor:pointer;position:relative;transition:background var(--duration-fast) ease-out}
  /* Salto directo principal ⇄ giras (la gira se planifica como semana aparte). */
  .md-jump{display:inline-flex;align-items:center;gap:5px;margin-top:12px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;font-weight:700;padding:6px 12px 6px 9px;border-radius:8px;cursor:pointer;position:relative;transition:background var(--duration-fast) ease-out}
  .md-jump:hover{background:rgba(255,255,255,.26)}
  .md-jump .ic{width:13px;height:13px}
  .md-hoy:hover{background:rgba(255,255,255,.22)}
  .md-hood{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-top:12px;position:relative}
  .md-hood-pin{display:inline-flex;color:#bfdbfe;flex:0 0 auto}
  .md-hood-pin svg{width:15px;height:15px}
  .md-hood-name{font-size:13px;font-weight:700;color:#fff;letter-spacing:.01em}
  .md-hood-ref{font-size:11.5px;color:#cbd5e1;text-transform:capitalize}
  /* Chip "GIRA" + nota: marca el bloque de giras (no-principal) que va aparte, 2ª semana. */
  .md-gira-chip{display:inline-flex;align-items:center;gap:4px;background:#0e6ba8;color:#fff;font-size:10px;font-weight:600;letter-spacing:.06em;padding:3px 9px 3px 7px;border-radius:7px;flex:0 0 auto}
  .md-gira-chip .ic{width:12px;height:12px}
  /* === Chips unificados · forma canónica (un solo radio/peso/tamaño por familia; cada chip conserva su color y padding) ===
     Borra el desorden de radios 3/4/5/6/7px, fuentes 10–11.5 y pesos 500/600/700.
     Etiquetas = rect suave (--radius-sm); estados/categorías/filtros = pill (999px). */
  .esp-tag,.marca-tag,.merc-flag,.gir-mkt-chip,.prio-badge,.md-gira-chip{border-radius:var(--radius-sm);font-size:11px;font-weight:600;vertical-align:middle}
  .trend-chip,.active-chip,.vg-cat-pill,.po-type-chip,.visited-chip{border-radius:var(--radius-pill);font-size:11px;font-weight:600;vertical-align:middle}
  .md-gira-note{margin-top:10px;background:rgba(37,99,235,.16);border:1px solid rgba(37,99,235,.35);color:#dbeafe;font-size:11.5px;line-height:1.45;padding:8px 11px;border-radius:9px}
  .md-gira-note b{color:#fff;font-weight:700}
  .md-maps{margin-left:auto;display:inline-flex;align-items:center;gap:6px;background:#fff;color:#0f172a;text-decoration:none;font-size:12.5px;font-weight:700;padding:7px 13px;border-radius:9px;border:0;cursor:pointer;transition:transform var(--duration-fast) ease-out,box-shadow var(--duration-fast) ease-out}
  .md-maps:hover{box-shadow:0 6px 16px -8px rgba(0,0,0,.5);transform:translateY(-1px)}
  .md-maps svg{width:15px;height:15px;color:var(--brand)}
  .md-list{display:flex;flex-direction:column;gap:9px}
  .md-card{display:flex;align-items:flex-start;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:13px 14px;cursor:pointer;box-shadow:0 1px 2px rgba(15,23,42,.03);transition:box-shadow .14s ease,border-color .14s ease,transform .14s ease}
  .md-card:hover{border-color:var(--line-strong);box-shadow:0 8px 20px -12px rgba(15,23,42,.22);transform:translateY(-1px)}
  .md-rank{flex:0 0 auto;width:30px;height:30px;border-radius:8px;background:var(--navy);border:1px solid var(--navy);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;font-variant-numeric:tabular-nums}
  .md-info{flex:1;min-width:0}
  .md-nm{font-weight:700;font-size:15px;color:var(--ink);line-height:1.2;letter-spacing:-.01em;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
  /* Horario de HOY para armar la vuelta (verde = atiende ahora; gris = cerrado hoy). */
  .md-hora{flex:0 0 auto;background:var(--good-soft);color:var(--good);font-weight:600;font-size:10.5px;padding:2px 8px;border-radius:var(--radius-pill);letter-spacing:.01em;white-space:nowrap;font-variant-numeric:tabular-nums}
  .md-hora-cerr{background:#f1f5f9;color:var(--ink-mute)}
  .md-card-cerr{opacity:.62}
  .md-card-cerr:hover{opacity:1}
  .md-sub2{font-size:11.5px;color:var(--ink-soft);margin-top:3px;line-height:1.4}
  .md-vis{color:var(--good);font-weight:600}
  .md-play{margin-top:10px;font-size:12.5px;color:var(--ink-soft);border-left:2px solid var(--brand);padding:4px 0 4px 11px;line-height:1.35}
  .md-play b{color:var(--brand-dark);font-weight:700}
  .md-addr{font-size:11.5px;color:var(--ink-soft);margin-top:4px;display:flex;align-items:center;gap:4px;line-height:1.35;overflow:hidden}
  .md-addr svg{color:var(--brand);flex:0 0 auto;width:12px;height:12px}
  .md-addr-txt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 auto}
  /* "Cómo llegar" en la MISMA fila que la dirección (compacto, a la derecha) → menos densidad. */
  .md-go{display:inline-flex;align-items:center;gap:4px;margin-top:0;margin-left:auto;flex:0 0 auto;background:var(--brand-soft);color:var(--brand-dark);border:1px solid #bfd4ff;border-radius:var(--radius-pill);padding:4px 10px;font-size:11px;font-weight:600;text-decoration:none;-webkit-tap-highlight-color:transparent;white-space:nowrap}
  .md-go svg{width:12px;height:12px}
  .md-go:active{background:#d8e6ff}
  /* === Productos: ranking de prescriptores por share === */
  .prod-view{padding:14px}
  .prod-intro h3{margin:0 0 4px;font-size:16px;font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:8px;letter-spacing:-.01em}
  .prod-intro h3 .ic{color:var(--ink-soft)}
  .prod-intro .sub{font-size:13px;color:var(--ink-soft);line-height:1.45;margin-bottom:12px}
  .prod-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
  .prod-select{flex:1 1 200px;min-width:0}
  .prod-period{flex:0 0 auto}
  .prod-count{font-size:12px;color:var(--ink-soft);margin-bottom:12px;font-variant-numeric:tabular-nums}
  .prod-count b{color:var(--ink);font-weight:700}
  .prod-nolter{display:inline-block;background:var(--brand-soft);color:var(--brand-dark);font-size:10px;font-weight:700;padding:1px 7px;border-radius:var(--radius-pill);letter-spacing:.02em;vertical-align:middle}
  .prod-rnk{color:var(--ink-faint)}
  .prod-mode{flex:0 0 auto}
  /* Métrica a la derecha de cada prescriptor: la CATEGORÍA (volumen real del médico),
     no el share — un categoría-1 receta mucho más que un categoría-5 al 100%. */
  .prod-metric{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:54px}
  .prod-metric .prod-cat .badge{font-size:15px;font-weight:800;min-width:30px;padding:5px 0;border-radius:9px;display:inline-flex;align-items:center;justify-content:center}
  .prod-metric-lbl{font-size:9.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-faint)}
  .md-zona{flex:0 0 auto;background:#eef2ff;color:#3730a3;font-weight:600;font-size:10px;padding:2px 7px;border-radius:var(--radius-sm);letter-spacing:.02em;white-space:nowrap}
  .md-fill-tag{color:var(--ink-faint);font-style:italic}
  .md-card-fill{border-style:dashed}
  .md-empty{padding:36px 22px;text-align:center;color:var(--ink-soft);font-size:14px;line-height:1.55;background:#fff;border:1px solid var(--line);border-radius:12px}
  .md-empty b{color:var(--ink)}
  @media(max-width:780px){
    .midia{padding:10px 10px calc(92px + env(safe-area-inset-bottom))}
    .md-entry{margin-top:0}
    .md-hero{padding:15px 16px;border-radius:14px;margin-bottom:10px}
    .md-hero h2{font-size:22px;margin:8px 0 6px}
    .md-hero p{font-size:13px}
    .md-next-top{align-items:stretch}
    .md-next-cta{min-height:44px;align-self:center}
  }
  /* === Solapa Precisión del score (loop de resultados) === */
  .prec{max-width:760px;margin:0 auto;padding:2px 2px 48px}
  .prec .p-hero{background:linear-gradient(155deg,#047857,#064e3b 78%);color:#fff;border-radius:18px;padding:24px 24px;text-align:center;margin-bottom:6px;position:relative;overflow:hidden}
  .prec .p-hero::after{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;background:radial-gradient(circle,rgba(52,211,153,.3),transparent 70%);pointer-events:none}
  .prec .p-hero .big{font-size:46px;font-weight:800;letter-spacing:-.02em;line-height:1;position:relative}
  .prec .p-hero .big small{font-size:18px;color:#a7f3d0;font-weight:700}
  .prec .p-hero p{font-size:15px;color:#d1fae5;margin-top:10px;line-height:1.5;position:relative}
  .prec .p-sub{text-align:center;font-size:13px;color:var(--ink-soft);margin:12px 0 8px;line-height:1.5}
  .prec .p-sub b{color:var(--ink)}
  .prec .p-st{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);font-weight:700;margin:26px 0 12px;display:flex;align-items:center;gap:10px}
  .prec .p-st::before{content:"";width:24px;height:3px;background:var(--brand);border-radius:2px}
  .prec .p-bars{display:flex;align-items:flex-end;gap:5px;height:150px;padding:0 2px}
  .prec .p-bars .b{flex:1;background:linear-gradient(180deg,#93c5fd,#1d6094);border-radius:5px 5px 0 0;min-height:3px}
  .prec .p-bars .b.top{background:linear-gradient(180deg,#34d399,#059669)}
  .prec .p-xaxis{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-faint);margin-top:7px;border-top:2px solid var(--line);padding-top:6px}
  .prec .p-cmp{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
  .prec .p-cmp .c{border:1px solid var(--line);border-radius:12px;padding:15px 8px;text-align:center}
  .prec .p-cmp .c .n{font-size:25px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
  .prec .p-cmp .c .l{font-size:11.5px;color:var(--ink-soft);margin-top:5px;font-weight:600;line-height:1.3}
  .prec .p-cmp .c.win{border-color:#6ee7b7;background:#ecfdf5}
  .prec .p-cmp .c.win .n{color:var(--good)}
  .prec .p-note{margin-top:24px}
  .prec .p-note b{font-weight:700}
  .prec .p-empty{text-align:center;padding:44px 24px;color:var(--ink-soft);line-height:1.55}
  /* === Modal "Cómo se calcula" === */
  .doc-modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:1000;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto;backdrop-filter:blur(2px)}
  .doc-modal-overlay.open{display:flex}
  .doc-modal{background:#fff;border-radius:var(--radius-lg);max-width:780px;width:100%;box-shadow:0 25px 50px rgba(15,23,42,.25);overflow:hidden;animation:docFadeIn .2s ease}
  @keyframes docFadeIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
  .doc-modal-head{padding:20px 24px;background:#0f172a;color:#fff;display:flex;justify-content:space-between;align-items:center}
  .doc-modal-head h2{margin:0;font-size:18px;font-weight:600}
  .doc-modal-close{background:transparent;border:1px solid #475569;color:#cbd5e1;padding:5px 12px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px}
  .doc-modal-close:hover{background:#1e293b}
  .doc-modal-body{padding:24px 28px;max-height:calc(100vh - 200px);overflow-y:auto}
    .doc-modal-body h3{margin:18px 0 8px;font-size:11.5px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);padding-bottom:6px}
  .doc-modal-body h3:first-child{margin-top:0}
  .doc-modal-body p{margin:6px 0;font-size:13px;line-height:1.55;color:var(--ink-soft)}
  .doc-modal-body pre{background:var(--bg-warm);border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;font-family:var(--font-mono);color:var(--ink);overflow-x:auto;line-height:1.5}
  .doc-modal-body ul{margin:6px 0;padding-left:22px;font-size:13px;line-height:1.6;color:var(--ink-soft)}
  .doc-modal-body ul li{margin-bottom:4px}
  .doc-modal-body code{background:var(--bg-warm);padding:1px 5px;border-radius:3px;font-family:var(--font-mono);font-size:11.5px;color:var(--ink)}
  .doc-modal-body .disclaimer{background:var(--brand-soft);border:1px solid #bfd4ff;border-left:3px solid var(--brand);border-radius:var(--radius-sm);padding:10px 14px;margin-top:14px;font-size:12.5px;color:var(--brand-dark);line-height:1.55;display:flex;align-items:flex-start;gap:8px}


  /* === Mobile: botones de Ficha === */
  @media (max-width:600px){
    .ficha-head-row{flex-direction:column !important;align-items:stretch !important;gap:10px !important}
    .ficha-head-actions{width:100%;flex-wrap:nowrap !important;gap:5px !important;display:flex !important}
    .ficha-head-actions .pdf-btn{flex:1 1 0;min-width:0;justify-content:center;padding:10px 4px;font-size:11.5px}
  }

  /* QA guardrail final: estas reglas viven al cierre para que ninguna cascada
     anterior vuelva a descentrar el score o ensanchar la ficha en mobile. */
  @media (max-width:780px){
    .ficha-hero .fh-ring{
      position:relative;
      width:64px !important;
      height:64px !important;
      flex:0 0 64px !important;
    }
    .ficha-hero .fh-ring svg{
      display:block !important;
      width:64px !important;
      height:64px !important;
    }
    .ficha-hero .fh-num{
      position:absolute;
      inset:0 !important;
      width:64px !important;
      height:64px !important;
      display:flex;
      align-items:center;
      justify-content:center;
      text-align:center;
    }
    .ficha-hero .fh-num b{
      font-size:21px !important;
      line-height:1 !important;
    }
    .ficha-hero .fh-num span{
      font-size:8px !important;
      line-height:1.1 !important;
      margin-top:1px !important;
    }
    .ficha-detail,
    .ficha-detail *{max-width:100%}
    .ficha-prod-table{min-width:0 !important}
  }

.fqa-pdf{background:var(--brand-soft);color:var(--brand);font-weight:600}
.fqa-pdf .ic{color:currentColor}

.evol-view{padding:4px 0}
.ev-headrow{margin:2px 0 12px}
.ev-title{font-size:18px;font-weight:700;color:var(--ink);margin:0}
.ev-subt{font-size:12.5px;color:var(--ink-mute);margin-top:3px}
.ev-note{font-size:11px;color:var(--ink-mute);background:var(--bg-warm);border:1px solid var(--line);border-radius:8px;padding:8px 11px;margin-bottom:14px;line-height:1.5}
.ev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.ev-card{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff}
.ev-mkt{font-size:13px;font-weight:700;color:var(--ink)}
.ev-brand{font-size:11px;color:var(--brand);font-weight:600;margin-top:1px}
.ev-share{font-size:26px;font-weight:800;color:var(--ink);margin-top:8px;line-height:1;display:flex;align-items:baseline}
.ev-pct{font-size:14px;font-weight:600;color:var(--ink-mute);margin-left:1px}
.ev-delta{font-size:13px;font-weight:700;margin-left:8px}
.ev-pen{font-size:11.5px;color:var(--ink-soft);margin-top:8px}

.colab-ov{position:fixed;inset:0;z-index:9000;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;padding:20px}
.colab-card{background:#fff;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.3);padding:22px;width:100%;max-width:380px}
.colab-h{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-mute)}
.colab-name{font-size:18px;font-weight:700;color:var(--ink);margin:4px 0 10px}
.colab-state{font-size:12px;color:var(--brand-dark);background:var(--brand-soft);border-radius:7px;padding:6px 9px;margin-bottom:10px}
.colab-lbl{font-size:11px;font-weight:600;color:var(--ink-mute);display:block;margin-bottom:4px}
.colab-inp{width:100%;box-sizing:border-box;border:1px solid var(--line-strong);border-radius:9px;padding:10px 12px;font-size:14px;color:var(--ink)}
.colab-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:16px;flex-wrap:wrap}
.colab-b{border:none;border-radius:8px;padding:9px 14px;font-size:13px;font-weight:600;cursor:pointer}
.colab-cancel{background:var(--bg-warm);color:var(--ink-soft)}
.colab-rm{background:#fef2f2;color:#dc2626}
.colab-ok{background:var(--brand);color:#fff}
.colab-view{padding:4px 0}
.cv-head{margin:2px 0 12px}
.cv-empty{text-align:center;color:var(--ink-mute);font-size:13px;line-height:1.7;padding:40px 20px;border:1px dashed var(--line-strong);border-radius:12px;background:var(--bg-warm)}
.cv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px}
.cv-card{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff;cursor:pointer}
.cv-card:hover{border-color:var(--line-strong)}
.cv-top{display:flex;align-items:center;justify-content:space-between;gap:8px}
.cv-name{font-size:14px;font-weight:700;color:var(--ink)}
.cv-badge{font-size:10.5px;font-weight:700;border-radius:999px;padding:2px 9px;white-space:nowrap}
.cv-meta{font-size:11px;color:var(--ink-mute);margin-top:4px}
.cv-ev{font-size:12px;color:var(--ink-soft);margin-top:8px}
.cv-conv{color:#16a34a;font-weight:700}
.cv-lost{font-size:11.5px;color:#b91c1c;margin-top:6px;line-height:1.55;padding-top:6px;border-top:1px dashed #fecaca}
.cv-lost b{font-weight:700}
.cv-lost-serie{display:inline-block;margin-top:2px;color:#7f1d1d;font-variant-numeric:tabular-nums}
.fm-link{color:#0c4a6e;font-weight:700;cursor:pointer;white-space:nowrap}
.fm-link:hover{text-decoration:underline}
.fm-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}
.fm-modal{background:#fff;border-radius:14px;max-width:780px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.fm-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line,#e5e7eb);position:sticky;top:0;background:#fff;z-index:1}
.fm-mkt{font-size:16px;font-weight:800;color:var(--ink,#0f172a)}
.fm-medname{font-size:12.5px;color:var(--ink-soft,#475569);margin-top:2px}
.fm-close{border:none;background:#f1f5f9;color:#475569;font-size:15px;width:30px;height:30px;border-radius:8px;cursor:pointer;flex:none}
.fm-close:hover{background:#e2e8f0}
.fm-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px}
@media(max-width:600px){.fm-cols{grid-template-columns:1fr}}
.fm-col{border:1px solid var(--line,#e5e7eb);border-radius:10px;overflow:hidden}
.fm-th{font-size:12px;font-weight:700;color:#fff;background:var(--ink-soft,#475569);padding:7px 10px}
.fm-med{font-size:11.5px;color:var(--ink-soft,#475569);padding:8px 10px;background:#f8fafc;line-height:1.5;border-bottom:1px solid var(--line,#e5e7eb)}
.fm-empty{padding:18px 10px;font-size:12px;color:var(--ink-mute,#94a3b8);text-align:center}
.fm-tbl{width:100%;border-collapse:collapse;font-size:11px;font-variant-numeric:tabular-nums}
.fm-tbl th{background:#f1f5f9;color:var(--ink-soft,#475569);font-weight:700;padding:4px 6px;text-align:center;border-bottom:1px solid var(--line,#e5e7eb)}
.fm-tbl th:first-child{text-align:left}
.fm-tbl .fm-sub th{font-size:10px;background:#f8fafc;padding:2px 6px}
.fm-tbl td{padding:4px 6px;text-align:center;border-bottom:1px solid #f1f5f9}
.fm-tbl td:first-child{text-align:left;color:var(--ink,#0f172a)}
.fm-tbl tr.fm-nol{background:#eff6fc}
.fm-tbl tr.fm-nol td:first-child{font-weight:700;color:#0c4a6e}
.fmm-chips{display:flex;flex-wrap:wrap;gap:6px;padding:12px 14px 4px}
.fmm-chip{border:1px solid var(--line,#e5e7eb);background:#fff;color:var(--ink-soft,#475569);font-size:11.5px;font-weight:600;padding:5px 10px;border-radius:999px;cursor:pointer}
.fmm-chip.on{background:#0c4a6e;border-color:#0c4a6e;color:#fff}
.cv-fichalink{margin-top:8px;padding-top:7px;border-top:1px dashed #e5e7eb}
.cv-warn{margin-top:9px;font-size:12px;line-height:1.5;color:#7c2d12;background:#fff7ed;border:1.5px solid #fb923c;border-left:4px solid #ea580c;border-radius:8px;padding:9px 11px}
.cv-warn b{font-weight:800;color:#9a3412}
.cv-warn-h{font-size:12.5px;font-weight:800;color:#c2410e;margin-bottom:3px;letter-spacing:.2px}
.cv-warn-cta{margin-top:5px;font-weight:700;color:#c2410e}
/* tarjeta con caída del mes: borde de acento para que salte en la lista */
.cv-card-warn{border-color:#fb923c;box-shadow:0 0 0 1px #fed7aa, 0 2px 8px rgba(234,88,12,.12)}
.cv-badges{display:flex;flex-wrap:wrap;gap:5px;justify-content:flex-end}
.cv-badge-warn{color:#fff;background:#ea580c}
/* barra de alerta global arriba de la solapa */
.cv-alertbar{margin-top:8px;font-size:12.5px;line-height:1.45;color:#7c2d12;background:#fff7ed;border:1.5px solid #fb923c;border-radius:9px;padding:9px 12px}
.cv-alertbar b{font-weight:800;color:#c2410e}
.fqa-colab{background:var(--bg-warm);color:var(--ink-soft)}
.fqa-colab .ic{color:currentColor}

.ck-view{padding:4px 0}
.ck-tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:12px}
.ck-table{width:100%;border-collapse:collapse;font-size:13px;min-width:480px}
.ck-table thead th{text-align:left;padding:10px 12px;font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-mute);background:var(--bg-warm);border-bottom:2px solid var(--line);white-space:nowrap}
.ck-table thead th:not(:first-child){text-align:right}
.ck-table tbody td{padding:10px 12px;border-bottom:1px solid var(--line)}
.ck-table tbody tr:last-child td{border-bottom:none}
.ck-name{font-weight:600;color:var(--ink);white-space:nowrap}
.ck-num{text-align:right;color:var(--ink-soft);font-variant-numeric:tabular-nums;white-space:nowrap}
.ck-num b{color:var(--ink)}
.ck-pct{font-size:11.5px;font-weight:700;margin-left:2px}
.ck-opp{color:#0c4a6e;font-weight:700}
/* celdas clickeables del cockpit (drill-down a la lista de médicos) */
.ck-click{cursor:pointer;position:relative;transition:background .12s}
.ck-click:hover{background:var(--brand-soft,#eff6fc)}
.ck-table tbody tr:hover .ck-name.ck-click{color:var(--brand,#0c4a6e)}
.ck-name.ck-click{text-decoration:underline;text-decoration-color:transparent}
.ck-name.ck-click:hover{text-decoration-color:currentColor}
/* lista de médicos del drill-down (reusa .fm-overlay/.fm-modal) */
.ckl-list{padding:6px 6px 10px}
.ckl-row{padding:10px 12px;border-bottom:1px solid #f1f5f9;cursor:pointer;border-radius:8px;transition:background .12s}
.ckl-row:hover{background:#f8fafc}
.ckl-row:last-child{border-bottom:none}
.ckl-main{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.ckl-nm{font-weight:700;color:var(--ink,#0f172a);font-size:13.5px}
.ckl-esp{font-size:11px;color:var(--ink-mute,#94a3b8);background:#f1f5f9;padding:1px 6px;border-radius:999px;font-weight:600}
.ckl-ctx{font-size:11.5px;color:var(--ink-soft,#475569);margin-top:3px;line-height:1.4}

.ev-chg{font-size:12px;font-weight:600;margin-top:7px;line-height:1.4}
.ev-chg b{font-weight:800}
.ev-chg-first{color:var(--ink-mute);font-weight:400;font-style:italic}

.evt-view{padding:4px 0}
.evt-head{margin:2px 0 4px}
.evt-title{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em;margin:0}
.evt-subt{font-size:12px;color:var(--ink-mute);margin-top:3px}
.evt-note{font-size:11.5px;line-height:1.6;color:var(--ink-soft);background:var(--bg-warm);border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin:10px 0 14px}
.evt-empty{text-align:center;color:var(--ink-mute);font-size:13px;line-height:1.7;padding:40px 20px;border:1px dashed var(--line-strong);border-radius:12px;background:var(--bg-warm)}
.evt-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}
.evt-card{border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px 16px 12px;background:#fff;display:flex;flex-direction:column}
.evt-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.evt-mkt{display:flex;flex-direction:column;min-width:0}
.evt-name{font-size:13.5px;font-weight:700;color:var(--ink);line-height:1.2;letter-spacing:-.01em}
.evt-brand{font-size:11px;color:var(--ink-mute);margin-top:1px}
.evt-now{font-size:22px;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums;white-space:nowrap}
.evt-pct{font-size:13px;font-weight:600;color:var(--ink-mute);margin-left:1px}
.evt-sparkwrap{margin:10px 0 2px;height:40px}
.evt-svg{width:100%;height:40px;display:block}
.evt-axis{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-faint);letter-spacing:.02em;text-transform:uppercase;margin-bottom:8px}
.evt-foot{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--line);padding-top:9px;margin-top:auto}
.evt-delta{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums}
.evt-rel{font-weight:600;opacity:.8}
.evt-pen{font-size:11px;color:var(--ink-soft);line-height:1.4}
.evt-pen b{color:var(--ink);font-weight:700}


/* === Mi Día · ciclo mensual (vueltas) === */
.md-ciclo{margin:12px 0 2px}
.md-ciclo-bar{height:6px;border-radius:999px;background:rgba(148,163,184,.25);overflow:hidden}
.md-ciclo-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#34d399,#10b981);transition:width .3s ease}
.md-ciclo-txt{margin-top:7px;font-size:12.5px;color:rgba(255,255,255,.85);display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.md-ciclo-txt b{color:#fff}
/* "pendientes" (antes "atrasadas"): chip secundario, ya no rojo de deuda sino neutro sobre el hero. */
.md-atras-chip{border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.16);color:#fff;border-radius:999px;padding:2px 10px;font-size:11.5px;font-weight:700;cursor:pointer;letter-spacing:.2px}
.md-atras-chip:hover{background:rgba(255,255,255,.26)}
/* Chip chico "atrasada" al lado del relativo, sin dramatismo. */
.md-late-chip{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.2);color:rgba(255,255,255,.92);border-radius:5px;padding:1px 6px;vertical-align:middle;margin-left:2px}
.md-vdone.on{background:rgba(16,185,129,.22);border-color:rgba(16,185,129,.55);color:#a7f3d0}
.md-daynav-rel{white-space:nowrap}

/* === Mi día · tarjeta con rol + potencial (ganar/retener) === */
.md-cardhead{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.md-score-sello{flex:0 0 auto;font-size:12px;font-weight:700;color:var(--ink-mute);font-variant-numeric:tabular-nums;letter-spacing:.02em;white-space:nowrap}
.md-score-sello small{font-size:9px;font-weight:600;color:var(--ink-faint)}
.md-pot{margin-top:9px}
.md-pot-head{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.md-role{flex:0 0 auto;font-size:10.5px;font-weight:700;padding:2px 9px;border-radius:var(--radius-pill);letter-spacing:.02em}
.md-role-win{background:var(--brand-soft);color:var(--brand-dark)}
.md-role-grow{background:#fef3c7;color:#92400e}
.md-role-keep{background:var(--good-soft);color:var(--good)}
.md-role-follow{background:#f1f5f9;color:#64748b}
.md-pot-cap{font-size:11px;color:var(--ink-soft);line-height:1.3;min-width:0}
.md-bar{height:8px;border-radius:var(--radius-pill);background:#eef2f7;overflow:hidden}
.md-bar-fill{height:100%;border-radius:var(--radius-pill);background:var(--navy);transition:width .3s ease}
.md-bar-keep{background:var(--good)}
.md-play-why{color:var(--ink-faint);font-weight:500}

/* Solapas de Análisis (Evolución/Colaborados/Cockpit): vistas globales → sin sidebar de cartera ni toolbar de geo, contenido a ancho completo centrado */
body.analysis-tab .toolbar{display:none}
@media (min-width:781px){ body.analysis-tab .container{grid-template-columns:1fr} }
body.analysis-tab .sidebar{display:none}
.cv-delta{font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}
.cv-ev-new{color:var(--brand-dark);font-style:italic}
.ver-stamp{font-size:10px;font-weight:700;color:#fff;background:#94a3b8;padding:1px 6px;border-radius:999px;vertical-align:middle;margin-left:6px;letter-spacing:.3px}

/* === Affordance táctil — feedback al tocar (clave en iPad, sin hover) + lo clickeable se ve clickeable === */
.cv-card,.md-card,.tc-row,.oppo-item,.ckl-row,.ficha-medico-item,.ck-click,.cv-fichalink .fm-link,.fm-link,.search-toggle,.fmm-chip,.fm-close{-webkit-tap-highlight-color:transparent}
/* la tarjeta de colaborado no tenía transición ni hover */
.cv-card{transition:transform .1s ease,box-shadow .14s ease,border-color .14s ease}
.cv-card:hover{box-shadow:0 2px 12px rgba(15,23,42,.08);border-color:#cbd5e1}
/* feedback al apretar: leve hundido, se siente el toque */
.cv-card:active,.md-card:active,.tc-row:active,.oppo-item:active,.ficha-medico-item:active{transform:scale(.988)}
.ckl-row:active{background:#eef2ff}
.ck-click:active{background:var(--brand-soft,#eff6fc)}
.search-toggle:active{transform:scale(.96)}
/* chevron "entrar →" en las filas de lista que llevan a la ficha del médico */
.ckl-row{position:relative;padding-right:30px}
.ckl-row::after{content:"";position:absolute;right:13px;top:50%;width:7px;height:7px;border-right:2px solid #cbd5e1;border-top:2px solid #cbd5e1;transform:translateY(-50%) rotate(45deg);transition:border-color .12s}
.ckl-row:hover::after{border-color:var(--brand,#0c4a6e)}

/* === Mi día · logro de share del padrón (hero cálido) === */
.md-achieve{display:flex;align-items:center;gap:13px;border-radius:18px;padding:14px 16px;margin-bottom:14px;color:#fff}
.md-achieve.up{background:linear-gradient(135deg,#0e6ba8,#3b8fc4);box-shadow:0 8px 22px rgba(14, 107, 168,.30)}
.md-achieve.down{background:linear-gradient(135deg,#d97706,#f59e0b);box-shadow:0 8px 22px rgba(217,119,6,.28)}
.md-achieve.flat{background:linear-gradient(135deg,#64748b,#94a3b8);box-shadow:0 8px 20px rgba(15,23,42,.16)}
.md-achieve-ic{font-size:27px;flex:none;line-height:1}
.md-achieve-t{font-size:15px;font-weight:800;line-height:1.25;letter-spacing:-.01em}
.md-achieve-s{font-size:12px;opacity:.95;margin-top:3px}
.md-achieve-s b{font-weight:800}

/* ===================== Pantalla de INICIO (home cálido, look V2) ===================== */
.inicio{max-width:560px;margin:0 auto;padding-bottom:24px}
.ini-hero{background:linear-gradient(155deg,#0e6ba8 0%,#1d6094 60%,#3b8fc4 100%);padding:20px 20px 26px;color:#fff;position:relative;border-radius:0 0 28px 28px}
.ini-av-top{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.22);border:2px solid rgba(255,255,255,.55);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:15px}
.ini-hi{font-size:21px;font-weight:900;letter-spacing:-.02em}
.ini-date{font-size:12.5px;color:#e0f0fb;margin-top:2px}
.ini-stats{display:flex;gap:9px;margin-top:16px}
.ini-st{flex:1;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.22);border-radius:16px;padding:11px 8px;text-align:center}
.ini-st b{font-size:21px;font-weight:900;display:block;line-height:1}
.ini-st span{font-size:9.5px;color:#e0f0fb;font-weight:700;text-transform:uppercase;letter-spacing:.3px;display:block;margin-top:4px}
.ini-logro{display:flex;align-items:center;gap:10px;margin-top:14px;background:rgba(255,255,255,.17);border:1px solid rgba(255,255,255,.30);border-radius:14px;padding:11px 13px;font-size:13px;font-weight:700;line-height:1.35}
/* Tarjeta de ACCIÓN ("Con estos la rompés") — un poco más brillante que la de estado, para que se lea como CTA. */
.ini-fire{background:rgba(255,255,255,.23);border-color:rgba(255,255,255,.40)}
.ini-logro-ic{font-size:18px;flex:none}
.ini-logro-tx{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.ini-logro-t{font-size:13px;font-weight:800;line-height:1.25}
.ini-logro-s{font-size:11.5px;font-weight:600;opacity:.92}
.ini-logro-s b{font-weight:800}
.ini-body{padding:18px 16px 6px;margin-top:-14px}
.ini-next{background:#fff;border-radius:22px;padding:17px;box-shadow:0 10px 28px rgba(14, 107, 168,.14);border:1px solid #e0f0fb;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s}
.ini-next:active{transform:scale(.99)}
.ini-next-k{font-size:10px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;color:#0e6ba8}
.ini-next-nm{font-size:18px;font-weight:800;color:#0c2a43;margin:5px 0 2px}
.ini-next-meta{font-size:11.5px;color:#9f7681}
.ini-next-why{font-size:12.5px;color:#1e3a4f;margin-top:10px;line-height:1.5;background:#eff6fc;border-radius:12px;padding:10px 12px}
.ini-next-why b{color:#0c4a6e}
.ini-next-cta{margin-top:13px;display:flex;gap:9px}
.ini-go{flex:1;text-align:center;background:linear-gradient(135deg,#0e6ba8,#1d6094);color:#fff;font-weight:800;font-size:13px;padding:11px 12px;border-radius:13px;box-shadow:0 6px 16px rgba(14, 107, 168,.35)}
.ini-map{flex:1;text-align:center;background:#e0f0fb;color:#0c4a6e;font-weight:800;font-size:13px;padding:11px 12px;border-radius:13px}
.ini-map:active{transform:scale(.98)}
.ini-sec{font-size:12px;font-weight:800;color:var(--ink-soft,#475569);margin:20px 4px 11px;display:flex;align-items:center;gap:7px}
.ini-cnt{background:#e0f0fb;color:#0c4a6e;font-size:10px;padding:1px 8px;border-radius:99px}
/* Contador del recorrido en Inicio: secundario y descriptivo, no un número-hero. */
.ini-cnt-sub{font-size:10.5px;font-weight:600;color:var(--ink-faint,#94a3b8);letter-spacing:0}
.ini-card{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid #eef2f7;border-radius:18px;padding:12px 13px;margin-bottom:10px;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s,box-shadow .12s}
.ini-card:active{transform:scale(.97);border-color:#bfdcf0}
.ini-card:hover{box-shadow:0 4px 14px rgba(15,23,42,.07);border-color:#bfdcf0}
.ini-card:hover .ini-chev,.ini-card:active .ini-chev{border-color:#0e6ba8}
.ini-ava{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:13px;flex:none}
/* Avatares de colores VIVOS y distintos por médico → identificación rápida (interactivo + útil). */
.ini-ava.a1{background:#f97316}.ini-ava.a2{background:#14b8a6}.ini-ava.a3{background:#6366f1}.ini-ava.a4{background:#ec4899}.ini-ava.a5{background:#0ea5e9}
.ini-cmid{min-width:0;flex:1}
.ini-cnm{font-size:14px;font-weight:800;color:#1e293b}
.ini-csub{font-size:11px;color:#64748b;margin-top:2px}
.ini-pill{font-size:9.5px;font-weight:800;padding:2px 8px;border-radius:99px;margin-left:6px;white-space:nowrap}
.ini-pill.grow{background:#fef3c7;color:#92400e}.ini-pill.keep{background:#d1fae5;color:#065f46}.ini-pill.win{background:#e0f0fb;color:#0c4a6e}
.ini-chev{margin-left:auto;width:9px;height:9px;border-right:2px solid #cbd5e1;border-top:2px solid #cbd5e1;transform:rotate(45deg);flex:none;transition:border-color .12s}
.ini-verall{display:block;text-align:center;margin:8px 0 4px;color:#0e6ba8;font-weight:800;font-size:13px;cursor:pointer;padding:11px}
.ini-empty{background:#fff;border-radius:18px;padding:26px 18px;text-align:center;color:var(--ink-soft,#475569);font-size:13.5px;line-height:1.55;border:1px solid #eef2f7}

/* Buscador del Inicio (reemplaza los stats: buscar un médico del padrón antes de entrar) */
.ini-search{position:relative;margin-top:0}
.ini-search>svg{position:absolute;left:16px;top:18px;width:21px;height:21px;color:#0e6ba8;opacity:.9;pointer-events:none}
/* font-size 16px = clave: abajo de 16, iOS Safari hace zoom al enfocar el input (molesto en iPad). */
.ini-search input{width:100%;border:2px solid #fff;border-radius:16px;padding:16px 16px 16px 50px;font-size:16px;font-weight:500;background:#fff;color:#1e293b;box-shadow:0 12px 30px rgba(0,0,0,.24);outline:none;transition:box-shadow .15s,border-color .15s}
.ini-search input:focus{border-color:#bfdcf0;box-shadow:0 14px 34px rgba(0,0,0,.28)}
.ini-search input::placeholder{color:#9aa7b8;font-weight:400}
.ini-search-results{display:none;position:absolute;left:0;right:0;top:calc(100% + 7px);background:#fff;border-radius:14px;box-shadow:0 14px 36px rgba(0,0,0,.26);overflow:hidden;z-index:30;max-height:320px;overflow-y:auto}
.ini-search-results.open{display:block}
.ini-qi{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;text-align:left;background:#fff;border:none;border-bottom:1px solid #f1f5f9;padding:11px 14px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ini-qi:last-child{border-bottom:none}
.ini-qi:hover,.ini-qi:active{background:#eff6fc}
.ini-qi-nm{font-size:13.5px;font-weight:700;color:#1e293b}
.ini-qi-meta{font-size:11px;color:#64748b}
.ini-qi-empty{padding:15px;font-size:12.5px;color:#64748b;text-align:center}

/* "Con estos la rompés 🔥" — card de targets de conquista en el Inicio */

/* Buscador del Inicio — encabezado con presencia (es lo primordial de la app) */
.ini-searchblock{margin-top:22px}
.ini-search-lbl{display:flex;align-items:center;gap:7px;font-size:13.5px;font-weight:800;color:#fff;letter-spacing:.2px;margin-bottom:9px}
.ini-search-lbl svg{width:16px;height:16px;opacity:.95}

/* "Con estos la rompés" — botón/franja simple debajo del share (mismo tamaño) */
.ini-fire{margin:12px 0 6px;background:linear-gradient(135deg,#f97316,#0e6ba8);border-radius:14px;padding:12px 14px;color:#fff;font-size:13.5px;font-weight:800;cursor:pointer;display:flex;align-items:center;gap:8px;box-shadow:0 8px 20px rgba(234,88,12,.30);-webkit-tap-highlight-color:transparent;transition:transform .1s}
.ini-fire:active{transform:scale(.99)}
.ini-fire-ic{font-size:18px;flex:none;line-height:1}
.ini-fire b{font-weight:900}
.ini-fire-arr{margin-left:auto;font-weight:900;font-size:16px;opacity:.85}
/* mensaje motivador arriba de la lista de targets */
.tgt-intro{margin:10px 12px 4px;background:linear-gradient(135deg,#fff7ed,#e0f0fb);border:1px solid #fed7aa;border-radius:12px;padding:11px 13px;font-size:12.5px;line-height:1.5;color:#7c2d12}
.tgt-intro b{font-weight:800;color:#9a3412}

/* Botón "Con estos la rompés" con el MISMO formato que la franja de share (.ini-logro) */
.ini-logro-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .1s;margin-top:8px}
.ini-logro-btn:active{transform:scale(.99)}

/* Modal "de dónde viene el crecimiento/caída" del share */

/* Modal "de dónde viene el crecimiento/caída" — con peso por mercado */

/* Modal "de dónde viene" — apilado, delta corto a la derecha (no se corta en mobile) */

/* Modal "de dónde viene" — fila vertical: nombre + delta arriba, sub + barra debajo */

/* Modal "de dónde viene" — todo en texto block (no se corta nunca) */
.shd-note{font-size:11px;color:#64748b;padding:10px 14px 4px;line-height:1.4}
.shd-list{padding:4px 6px 12px}
.shd-row{padding:11px 14px;border-bottom:1px solid #f1f5f9}
.shd-row:last-child{border-bottom:none}
.shd-mkt{font-size:13px;font-weight:700;color:#1e293b}
.shd-sub{font-size:11.5px;color:#64748b;margin-top:3px;line-height:1.4;font-variant-numeric:tabular-nums}
.shd-sub b{font-weight:800}
.shd-bar{height:4px;background:#eef2f7;border-radius:99px;margin-top:6px;max-width:200px;overflow:hidden}
.shd-bar i{display:block;height:100%;background:linear-gradient(90deg,#fb923c,#0e6ba8);border-radius:99px}

/* ===== Asistente local (chatbot IA en el dispositivo) ===== */
/* El FAB de Nolta aparece SOLO en Inicio (body.home-tab) para no molestar en ficha/otras vistas. */
.ai-fab{display:none;position:fixed;right:16px;bottom:calc(74px + env(safe-area-inset-bottom));z-index:60;width:56px;height:56px;border-radius:18px;border:none;background:linear-gradient(145deg,#0e6ba8,#0c4a6e);color:#fff;box-shadow:0 10px 26px rgba(14, 107, 168,.42);cursor:pointer;align-items:center;justify-content:center;transition:transform .12s ease-out;-webkit-tap-highlight-color:transparent}
body.home-tab .ai-fab{display:flex}
.ai-fab:active{transform:scale(.93)}
.ai-fab-spark{font-size:25px;line-height:1}
@media(min-width:781px){ .ai-fab{bottom:24px;right:24px;width:58px;height:58px} }
/* z-index 120: por ENCIMA del bottom-nav (z90) — si no, el menú inferior tapa la barra de escribir/audio en el cel. */
.ai-overlay{position:fixed;inset:0;z-index:120;background:rgba(15,23,42,.45);display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(2px)}
@media(min-width:781px){ .ai-overlay{align-items:center} }
.ai-panel{background:#fff;width:100%;max-width:560px;height:88vh;max-height:780px;border-radius:22px 22px 0 0;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -10px 40px rgba(15,23,42,.3)}
@media(min-width:781px){ .ai-panel{border-radius:20px;height:80vh} }
.ai-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;background:linear-gradient(135deg,#0c4a6e,#0e6ba8);color:#fff;flex:none}
.ai-head-l{display:flex;align-items:center;gap:11px;min-width:0}
.ai-spark{font-size:21px;background:rgba(255,255,255,.18);width:38px;height:38px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex:none}
.ai-title{font-size:16px;font-weight:800;line-height:1.1}
.ai-sub{font-size:11px;opacity:.92;margin-top:2px}
.ai-x{background:rgba(255,255,255,.16);border:none;color:#fff;width:32px;height:32px;border-radius:9px;font-size:14px;cursor:pointer;flex:none}
.ai-msgs{position:relative;flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f8fafc;-webkit-overflow-scrolling:touch}
.ai-msg{display:flex;max-width:92%}
.ai-msg.ai-user{align-self:flex-end}
.ai-msg.ai-bot{align-self:flex-start;flex-direction:column;gap:8px;max-width:100%;width:100%}
.ai-bubble{padding:11px 14px;border-radius:16px;font-size:13.5px;line-height:1.45}
.ai-bubble b{font-weight:800}
.ai-user .ai-bubble{background:#0e6ba8;color:#fff;border-bottom-right-radius:5px}
.ai-bot .ai-bubble{background:#fff;color:#1e293b;border:1px solid #e8edf3;border-bottom-left-radius:5px;box-shadow:0 1px 2px rgba(15,23,42,.04)}
.ai-list{display:flex;flex-direction:column;gap:7px}
/* Filas compactas dentro del chat de Nolta (más prolijo que las fichas grandes) */
.ai-list .ckl-row{cursor:pointer;padding:7px 26px 7px 11px;background:#fff;border:1px solid #eef2f7;border-bottom:1px solid #eef2f7;border-radius:11px;box-shadow:0 1px 2px rgba(15,23,42,.03)}
.ai-list .ckl-nm{font-size:12.5px}
.ai-list .ckl-ctx{font-size:11px;margin-top:2px}
.ai-list .ckl-row::after{right:11px}
.ai-pdf{display:inline-flex;align-items:center;gap:6px;margin-top:2px;align-self:flex-start;background:#fff;border:1px solid #bfdcf0;color:#0c4a6e;border-radius:11px;padding:8px 13px;font-size:12.5px;font-weight:700;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ai-pdf:active{background:#eff6fc}
.ai-pdf .ic{width:15px;height:15px}
.ai-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 14px 10px;background:#f8fafc;flex:none}
.ai-chip{border:1px solid #bfdcf0;background:#fff;color:#0c4a6e;border-radius:999px;padding:7px 12px;font-size:12px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}
.ai-chip:active{background:#eff6fc}
.ai-inputbar{display:flex;align-items:center;gap:8px;padding:10px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid #eef2f7;background:#fff;flex:none}
.ai-input{flex:1;min-width:0;border:1px solid #e2e8f0;border-radius:13px;padding:11px 13px;font-size:14px;outline:none;color:#1e293b}
.ai-input:focus{border-color:#0e6ba8}
.ai-mic,.ai-send{flex:none;width:42px;height:42px;border-radius:12px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;-webkit-tap-highlight-color:transparent}
.ai-mic{background:#f1f5f9;color:#475569}
.ai-mic-on{background:#0e6ba8;color:#fff;animation:aipulse 1s infinite}
.ai-mic-off{opacity:.5}
.ai-send{background:linear-gradient(145deg,#0e6ba8,#0c4a6e);color:#fff;font-weight:800;font-size:19px}
@keyframes aipulse{0%,100%{box-shadow:0 0 0 0 rgba(14, 107, 168,.5)}50%{box-shadow:0 0 0 7px rgba(14, 107, 168,0)}}

/* ===== v161: reframe CUP vs Veeva + edición + impacto absoluto ===== */
.ed-tag{font-size:10.5px;color:var(--ink-faint,#94a3b8);font-weight:500;margin:12px 4px 2px;text-align:center;letter-spacing:.01em}
.ed-tag .ed-off{color:var(--warn-ink,#b45309);font-weight:700}
.ini-foco-note{font-size:11px;color:var(--ink-faint,#94a3b8);margin:0 4px 11px;line-height:1.4}
.md-foco-note{font-size:11px;color:var(--ink-soft,#64748b);margin:0 2px 11px;line-height:1.4}
/* Ficha: prioridad local + impacto absoluto (hero oscuro) */
.fh-prio{display:flex;flex-wrap:wrap;align-items:center;gap:7px;margin-top:9px}
.fh-prio-local{font-size:11.5px;font-weight:600;color:rgba(255,255,255,.9)}
.fh-prio-local b{font-weight:800;color:#fff}
.fh-prio-abs{font-size:10.5px;font-weight:800;letter-spacing:.02em;padding:2px 9px;border-radius:999px}
.fh-prio-abs.imp-alto{background:#dcfce7;color:#166534}
.fh-prio-abs.imp-medio{background:#fef3c7;color:#92400e}
.fh-prio-abs.imp-bajo{background:rgba(255,255,255,.18);color:rgba(255,255,255,.85)}
/* Gate de APM (mobile sin cartera): fondo más opaco, "Ver todos" como opción secundaria. */
.upl-overlay.apm-gate{background:rgba(15,23,42,.66)}
.apm-all.apm-all-sec{opacity:.72;font-size:12px;font-weight:500}

/* ===== Cockpit por APM — layout de cards (reemplaza la tabla) ===== */
.ck2-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:14px}
@media(min-width:640px){.ck2-grid{grid-template-columns:1fr 1fr}}
.ck2-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:14px 14px 12px;display:flex;flex-direction:column}
.ck2-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ck2-id{display:flex;align-items:baseline;gap:9px;min-width:0}
.ck2-rank{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--ink-faint);flex:0 0 auto}
.ck2-name{font-weight:600;font-size:15px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ck2-pen{font-family:var(--font-mono);font-size:13px;font-weight:600;flex:0 0 auto}
.ck2-good{color:var(--good)}
.ck2-warn{color:var(--warn)}
.ck2-mute{color:var(--ink-mute)}
.ck2-hero{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px;padding:10px 10px;border-radius:var(--radius);min-height:56px;transition:background var(--duration-fast) ease}
.ck2-hero-lbl{display:flex;flex-direction:column;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-soft);line-height:1.35}
.ck2-hero-lbl span{font-size:10px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--ink-faint)}
.ck2-hero-val{display:flex;align-items:center;gap:2px;font-family:var(--font-mono);font-size:30px;font-weight:500;color:var(--brand);line-height:1}
.ck2-chev{width:18px;height:18px;color:var(--brand);opacity:.65}
.ck2-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}
.ck2-stat{display:flex;flex-direction:column;gap:3px;border:1px solid var(--line-2);border-radius:var(--radius-sm);padding:8px 9px;min-height:44px;justify-content:center}
.ck2-stat-lbl{font-size:10px;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-mute)}
.ck2-stat-val{font-family:var(--font-mono);font-size:15px;font-weight:600;color:var(--ink)}
.ck2-stat-val em{font-style:normal;font-size:11px;font-weight:600}
.ck2-tap{cursor:pointer;-webkit-tap-highlight-color:transparent}
.ck2-tap:hover{background:var(--bg-warm)}
.ck2-hero.ck2-tap:hover{background:var(--brand-soft)}

/* ===== Vista Gerente — re-skin mobile-first (hero, portfolio, cobertura) ===== */
.vg-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px;background:#fff;border-bottom:1px solid var(--line)}
.vg-hero-main{min-width:0}
.vg-hero-title{font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-.015em;line-height:1.1}
.vg-hero-sub{font-size:12px;color:var(--ink-mute);margin-top:2px}
.vg-hero-metric{text-align:right;flex:0 0 auto}
.vg-hero-num{font-family:var(--font-mono);font-size:34px;font-weight:500;color:var(--brand);line-height:1}
.vg-hero-lbl{font-size:11px;color:var(--ink-mute);font-weight:500;margin-top:1px}
.vg-intro{padding:12px 20px}
.vg-port-card{text-align:left;align-items:flex-start;padding:14px 14px}
.vg-port-num{font-size:30px;margin-bottom:6px;letter-spacing:-.02em}
.vg-port-lbl{text-align:left}
.vg-port-success .vg-port-num{color:var(--good)}
.vg-port-danger .vg-port-num{color:var(--bad)}
.vg-port-info .vg-port-num,.vg-port-warn .vg-port-num{color:var(--ink);font-family:var(--font);letter-spacing:-.01em}
@media(max-width:600px){.vg-portfolio-grid{grid-template-columns:repeat(2,1fr)}}
.vg-cov-row{display:grid;grid-template-columns:1fr auto;grid-template-areas:"lbl val" "bar bar";gap:5px 8px;align-items:center;margin-bottom:14px}
.vg-cov-lbl{grid-area:lbl;font-weight:600;font-size:13px;color:var(--ink)}
.vg-cov-val{grid-area:val;font-family:var(--font-mono);font-weight:600;font-size:13px;text-align:right}
.vg-cov-bar{grid-area:bar;height:8px;background:var(--line-2)}
.vg-oss-item{margin-bottom:11px}
.vg-oss-line{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.vg-oss-rank{font-family:var(--font-mono);font-size:12px;color:var(--ink-faint);flex:0 0 auto}
.vg-oss-name{font-weight:600;font-size:13px;color:var(--ink);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vg-oss-rxs{font-family:var(--font-mono);font-size:11px;color:var(--ink-soft);flex:0 0 auto}
.vg-oss-bar{height:6px;background:var(--line-2);border-radius:var(--radius-pill);overflow:hidden}
.vg-oss-bar>div{height:100%;border-radius:var(--radius-pill)}

/* ===== Azul de marca (v176) — heroes/header/CTA al tono PROFUNDO (premium, tipo BI). ===== */
.header{background:linear-gradient(180deg,#13476e,#0c2a43)}
.ini-hero{background:linear-gradient(155deg,#0c2a43 0%,#13476e 60%,#1d6094 100%)}
.ini-go{background:linear-gradient(135deg,#0c4a6e,#0e6ba8);box-shadow:0 6px 16px rgba(13,71,110,.32)}

/* ===== v177 — cara APM con azul VIVO/eléctrico (Inicio/Mi Día); header + gerencia quedan navy sobrio. ===== */
:root{ --brand:#4f46e5; --brand-dark:#3730a3; --brand-soft:#eef2ff; }
.ini-hero{background:linear-gradient(150deg,#0a4f9c 0%,#1e88d8 55%,#36a6ec 100%)}
.md-hero{background:linear-gradient(150deg,#0c5aa6,#2188d6)}
.ini-go{background:linear-gradient(135deg,#0d63b8,#2188d6);box-shadow:0 6px 16px rgba(33,136,214,.32)}

/* Banda de encabezado para solapas del APM (Productos, Ganá rápido) — azul vivo, mismo lenguaje que Inicio/Mi Día. */
.apm-tabhero{background:linear-gradient(150deg,#0a4f9c 0%,#1e88d8 100%);color:#fff;border-radius:16px;padding:15px 18px;margin:0 0 14px;box-shadow:0 8px 22px rgba(13,99,184,.20)}
.apm-tabhero-t{font-size:18px;font-weight:800;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;color:#fff}
.apm-tabhero-t .ic{width:18px;height:18px;color:#fff}
.apm-tabhero-s{font-size:12.5px;color:rgba(255,255,255,.92);margin-top:4px;line-height:1.45}

/* ===== Comunicados de gerencia → campana flotante con badge + burbuja que se abre/cierra. ===== */
/* Campana SUTIL, abajo a la IZQUIERDA (no compite con el contenido ni con el FAB de Nolta). */
.av-fab{display:none;position:fixed;left:16px;bottom:calc(82px + env(safe-area-inset-bottom));z-index:60;width:44px;height:44px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.92);color:#475569;box-shadow:0 4px 14px rgba(15,23,42,.14);cursor:pointer;align-items:center;justify-content:center;transition:transform .12s ease-out;-webkit-tap-highlight-color:transparent;backdrop-filter:blur(4px)}
body.home-tab .av-fab.has-avisos{display:flex}
.av-fab:active{transform:scale(.93)}
.av-fab-ic{font-size:19px;line-height:1;opacity:.85}
.av-fab-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 5px;border-radius:10px;background:var(--bad);color:#fff;font-size:10.5px;font-weight:800;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(185,28,28,.45)}
@media(min-width:781px){ .av-fab{bottom:24px} }
.av-overlay{position:fixed;inset:0;z-index:120;background:rgba(15,23,42,.45);display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(2px)}
@media(min-width:781px){ .av-overlay{align-items:center} }
.av-panel{background:#f6f8fb;width:100%;max-width:520px;max-height:74vh;border-radius:22px 22px 0 0;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 -10px 40px rgba(15,23,42,.3)}
@media(min-width:781px){ .av-panel{border-radius:20px} }
.av-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;background:linear-gradient(150deg,#0a4f9c,#1e88d8);color:#fff}
.av-head-t{font-size:15px;font-weight:800}
.av-x{background:rgba(255,255,255,.18);border:none;color:#fff;width:30px;height:30px;border-radius:9px;font-size:14px;cursor:pointer}
.av-body{padding:14px;overflow-y:auto;display:flex;flex-direction:column;gap:11px}
.av-empty{text-align:center;color:var(--ink-mute);font-size:13px;padding:26px 12px}
.av-msg{background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:14px;padding:12px 14px;box-shadow:0 4px 14px rgba(13,99,184,.07)}
.av-msg-logro{border-left-color:#b45309}
.av-msg-head{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.av-msg-ic{font-size:17px}
.av-msg-from{font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--brand)}
.av-msg-logro .av-msg-from{color:#b45309}
.av-msg-ok{margin-left:auto;background:var(--good-soft);color:var(--good);border:none;width:26px;height:26px;border-radius:8px;font-size:14px;font-weight:800;cursor:pointer;flex:none}
.av-msg-t{font-size:15px;font-weight:800;color:var(--ink);margin-bottom:3px;letter-spacing:-.01em;line-height:1.25}
.av-msg-b{font-size:13px;color:var(--ink-soft);line-height:1.5}
.av-msg-b b{color:var(--ink);font-weight:700}

/* ===== Panel de redacción de comunicados (gerencia). ===== */
.com-panel{max-height:86vh}
.com-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px}
.com-l{display:block;font-size:11px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 5px}
.com-input{width:100%;border:1px solid var(--line-strong);border-radius:10px;padding:10px 12px;font-size:16px;font-family:inherit;color:var(--ink);background:#fff;outline:none;margin-bottom:11px}
.com-input:focus{border-color:var(--brand)}
.com-textarea{resize:vertical;line-height:1.5}
.com-row{display:flex;gap:10px}
.com-save{width:100%;background:linear-gradient(135deg,#0d63b8,#2188d6);color:#fff;border:none;border-radius:12px;padding:12px;font-size:14px;font-weight:800;cursor:pointer;-webkit-tap-highlight-color:transparent}
.com-save:active{transform:scale(.99)}
.com-hint{font-size:11.5px;color:var(--ink-mute);line-height:1.45;margin:10px 2px 0}
.com-empty{text-align:center;color:var(--ink-mute);font-size:12.5px;padding:18px 12px}
.com-item{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:11px 12px;margin-bottom:9px}
.com-item-tx{flex:1;min-width:0}
.com-item-t{font-size:14px;font-weight:800;color:var(--ink);letter-spacing:-.01em}
.com-item-meta{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--brand);margin:2px 0 4px}
.com-item-b{font-size:12.5px;color:var(--ink-soft);line-height:1.45}
.com-item-b b{color:var(--ink)}
.com-del{flex:none;background:transparent;border:none;font-size:16px;cursor:pointer;opacity:.6;padding:2px}
.com-del:hover{opacity:1}

.com-who{font-size:12px;color:var(--ink-mute);margin:0 2px 10px}
.com-who b{color:var(--ink)}
.com-who a{color:var(--brand);font-weight:700;cursor:pointer;text-decoration:underline}
.com-err{font-size:12px;color:var(--bad);margin:0 2px 8px;min-height:14px}

/* Banner "Activar avisos" (push) en Inicio — sutil, una línea, descartable al activar. */
.notif-banner{display:flex;align-items:center;gap:10px;background:#eff6fc;border:1px solid #cfe6f7;border-radius:14px;padding:11px 13px;margin-bottom:14px}
.notif-banner-ic{font-size:19px;flex:none}
.notif-banner-tx{flex:1;min-width:0;font-size:12.5px;color:#0c4a6e;font-weight:600;line-height:1.35}
.notif-banner-btn{flex:none;background:linear-gradient(135deg,#0d63b8,#2188d6);color:#fff;border:none;border-radius:10px;padding:8px 14px;font-size:13px;font-weight:800;cursor:pointer;-webkit-tap-highlight-color:transparent}
.notif-banner-btn:active{transform:scale(.96)}
