/* Nathan Streaming — Mobile & Responsive CSS */

  /* ═══════════════════════════════════════════════════════════════════════
     0. RESET TÁCTIL Y ACCESIBILIDAD GLOBAL
     ═══════════════════════════════════════════════════════════════════════ */
  html { -webkit-tap-highlight-color: transparent; }

  button, .btn, .btn-icon, .action-btn, .nav-item, .stat-card, .platform-mini-card {
    -webkit-tap-highlight-color: rgba(0,0,0,0);
    -webkit-touch-callout: none;
  }

  .table-wrap, .modal, .modal-overlay, #sidebar, .accounts-section,
  .form-grid, .global-search-results, #mob-search-bar {
    -webkit-overflow-scrolling: touch;
  }

  body.sidebar-open { overflow: hidden; touch-action: none; }


  /* ═══════════════════════════════════════════════════════════════════════
     SELECTS REDONDEADOS Y ANIMADOS (todas las pantallas)
     ═══════════════════════════════════════════════════════════════════════ */
  select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    border-radius: 12px !important;
    /* Padding equilibrado: hace que el texto quede centrado visualmente
       compensando la flecha que ocupa la derecha */
    padding-right: 30px !important;
    text-align: center !important;
    text-align-last: center !important;
    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='%2394a3b8' 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 12px center;
    background-size: 12px 12px;
    cursor: pointer;
    transition: border-color 0.18s ease, box-shadow 0.18s ease, transform 0.12s ease;
  }
  select:hover { border-color: var(--accent3) !important; }
  select:focus {
    outline: none;
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(59,130,246,0.18);
  }
  select:active { transform: scale(0.99); }
  select option {
    background: var(--bg2);
    color: var(--text);
    padding: 10px;
    border-radius: 8px;
    text-align: center;
  }


  /* ═══════════════════════════════════════════════════════════════════════
     1. TABLET (≤ 1024px)
     ═══════════════════════════════════════════════════════════════════════ */
  @media (max-width: 1024px) {
    #sidebar { width: 230px; }
    #main { margin-left: 230px; }

    .topbar { padding: 12px 20px; }
    .page { padding: 18px 20px; }

    .stats-grid { grid-template-columns: repeat(3, 1fr); column-gap: 12px; row-gap: 16px; }
    .platform-overview-grid { grid-template-columns: repeat(3, 1fr); }

    table { font-size: 12px; }
    th { font-size: 13px; padding: 7px 8px; }
    td { padding: 10px 10px; }

    .modal { max-width: 92vw; }
    .form-grid { gap: 12px; }
  }


  /* ═══════════════════════════════════════════════════════════════════════
     2. MÓVIL (≤ 768px)
     ═══════════════════════════════════════════════════════════════════════ */
  @media (max-width: 768px) {

    body {
      padding-left:  env(safe-area-inset-left);
      padding-right: env(safe-area-inset-right);
    }

    .topbar { display: none; }

    /* ─── Mobile topbar más compacta ───────────────────────────────────── */
    .mobile-topbar {
      display: flex;
      align-items: center;
      gap: 8px;
      position: fixed;
      top: 0; left: 0; right: 0;
      height: calc(52px + env(safe-area-inset-top));
      padding-top: env(safe-area-inset-top);
      padding-left:  max(10px, env(safe-area-inset-left));
      padding-right: max(10px, env(safe-area-inset-right));
      background: var(--bg2);
      border-bottom: 1px solid var(--border);
      z-index: 250;
      box-shadow: 0 1px 3px rgba(0,0,0,0.06);
    }
    body.dark .mobile-topbar { background: var(--bg2); border-bottom-color: var(--border); }

    .mob-menu-btn {
      width: 36px; height: 36px;
      min-width: 36px;
      border-radius: 10px;
      border: 1px solid var(--border);
      background: var(--bg3);
      color: var(--text);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: background 0.15s, border-color 0.15s;
    }
    .mob-menu-btn:active {
      background: var(--surface);
      border-color: var(--border2);
    }

    .mob-search-btn { display: none !important; }
    .mob-title { display: none !important; }

    /* ─── Buscador (movido por JS a la mobile-topbar) ─── */
    .mobile-topbar .global-search-wrap {
      display: flex !important;
      flex: 1;
      max-width: 100%;
      margin: 0;
      position: relative;
    }
    .mobile-topbar .global-search-wrap input {
      width: 100%;
      background: var(--bg3);
      border: 1px solid var(--border);
      color: var(--text);
      padding: 6px 12px 6px 30px;
      border-radius: 10px;
      font-size: 16px; /* Obligatorio 16px en iOS — no se puede bajar más */
      outline: none;
      height: 36px;
      transition: border-color 0.15s, box-shadow 0.15s;
    }
    .mobile-topbar .global-search-wrap input::placeholder {
      font-size: 13px; /* el placeholder sí puede verse más pequeño */
    }
    .mobile-topbar .global-search-wrap input:focus {
      border-color: var(--accent);
      box-shadow: 0 0 0 2px rgba(59,130,246,0.15);
    }
    .mobile-topbar .global-search-wrap .gs-icon {
      left: 9px;
      top: 50%;
      transform: translateY(-50%);
      pointer-events: none;
      position: absolute;
    }
    .mobile-topbar .global-search-wrap .gs-icon svg { width: 13px !important; height: 13px !important; }
    .mobile-topbar .global-search-wrap .global-search-results {
      position: fixed;
      left: 8px;
      right: 8px;
      top: calc(52px + env(safe-area-inset-top));
      max-height: calc(100vh - 80px - env(safe-area-inset-top));
      border-radius: 12px;
      box-shadow: 0 8px 24px rgba(0,0,0,0.18);
    }

    .global-search-wrap { display: flex !important; }
    .mob-search-bar { display: none !important; }

    /* ─── Sidebar drawer ───────────────────────────────────────────────── */
    #sidebar {
      position: fixed;
      top: 0; left: 0; bottom: 0;
      width: min(82vw, 300px);
      max-width: 300px;
      transform: translateX(-100%);
      transition: transform 0.15s ease;
      z-index: 300;
      box-shadow: 4px 0 20px rgba(0,0,0,0.18);
      padding-top: env(safe-area-inset-top);
      padding-bottom: env(safe-area-inset-bottom);
      padding-left: env(safe-area-inset-left);
    }
    #sidebar.open { transform: translateX(0); }

    .mob-overlay {
      display: none;
      position: fixed;
      inset: 0;
      background: rgba(0,0,0,0.45);
      z-index: 290;
      backdrop-filter: blur(2px);
      -webkit-backdrop-filter: blur(2px);
      animation: mobOverlayIn 0.2s ease;
    }
    .mob-overlay.show, .mob-overlay.open { display: block; }
    @keyframes mobOverlayIn {
      from { opacity: 0; }
      to   { opacity: 1; }
    }

    .nav-item {
      padding: 12px 16px;
      font-size: 14.5px;
      min-height: 44px;
      margin: 2px 8px;
    }
    .nav-section-label { padding: 14px 20px 6px; }

    #main {
      margin-left: 0;
      padding-top: calc(52px + env(safe-area-inset-top));
      min-width: 0;
      width: 100%;
    }

    .page {
      padding: 14px 12px;
      padding-bottom: calc(20px + env(safe-area-inset-bottom));
      max-width: 720px;
      margin: 0 auto;
    }
    .page.active { animation: none; }

    .stats-grid {
      grid-template-columns: 1fr 1fr;
      column-gap: 10px;
      row-gap: 12px;
      margin-bottom: 18px;
      max-width: 720px;
      margin-left: auto;
      margin-right: auto;
    }
    .stat-card { padding: 12px 12px 10px; border-radius: 14px; }
    .stat-card .value { font-size: 20px; }
    .stat-card .label { font-size: 9.5px; }
    .sc-icon { width: 26px; height: 26px; margin-bottom: 8px; }

    .platform-overview-grid {
      grid-template-columns: 1fr 1fr;
      gap: 10px;
      max-width: 720px;
      margin-left: auto;
      margin-right: auto;
    }

    .table-wrap {
      overflow-x: auto;
      overflow-y: hidden;
      -webkit-overflow-scrolling: touch;
      border-radius: 12px;
      max-width: 720px;
      margin-left: auto;
      margin-right: auto;
    }
    table { min-width: 560px; font-size: 13px; }
    th { font-size: 12px; padding: 8px 10px; }
    td { padding: 11px 10px; }

    .mobile-cards table,
    .mobile-cards thead,
    .mobile-cards tbody,
    .mobile-cards th,
    .mobile-cards td,
    .mobile-cards tr { display: block; }
    .mobile-cards thead { display: none; }
    .mobile-cards table { min-width: 0; width: 100%; }
    .mobile-cards tr {
      background: var(--bg2);
      border: 1px solid var(--border);
      border-radius: 14px;
      margin-bottom: 10px;
      padding: 12px 14px;
      box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    }
    .mobile-cards td {
      border: none;
      padding: 5px 0;
      font-size: 14px;
      display: flex;
      align-items: flex-start;
      gap: 8px;
      white-space: normal;
      overflow: visible;
      text-overflow: clip;
    }
    .mobile-cards td:before {
      content: attr(data-label);
      font-size: 11px;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 0.6px;
      color: var(--text3);
      min-width: 86px;
      padding-top: 2px;
    }
    .mobile-cards td:last-child {
      margin-top: 8px;
      padding-top: 10px;
      border-top: 1px solid var(--border);
      justify-content: flex-end;
    }
    .mobile-cards td:last-child:before { display: none; }

    .btn { min-height: 40px; padding: 10px 14px; font-size: 14px; }
    .btn-sm { min-height: 34px; padding: 7px 12px; font-size: 13px; }

    .btn-icon { width: 40px; height: 40px; min-width: 40px; padding: 0; }
    .action-btn { width: 36px; height: 36px; min-width: 36px; font-size: 14px; }
    .action-btns { gap: 6px; }

    .form-grid { grid-template-columns: 1fr; gap: 14px; }
    .form-group.full { grid-column: 1; }
    .form-group label { font-size: 13px; margin-bottom: 6px; }
    .form-group input,
    .form-group select,
    .form-group textarea {
      width: 100%;
      padding: 12px 14px;
      font-size: 16px;
      min-height: 44px;
      border-radius: 12px;
    }
    .form-group textarea { min-height: 90px; }

    /* En el modal de admin: form en una columna y texto select centrado */
    #modal-admin .modal-body input,
    #modal-admin .modal-body select {
      font-size: 16px !important;
      padding: 11px 12px !important;
      min-height: 42px !important;
    }
    #modal-admin .modal-body select {
      padding-left: 14px !important;
      padding-right: 30px !important;
    }

    .modal-overlay {
      padding: 0;
      align-items: flex-end;
      justify-content: center;
    }
    .modal {
      border-radius: 20px 20px 0 0;
      max-height: 92vh;
      width: 100%;
      max-width: 100%;
      margin-left: auto;
      margin-right: auto;
      animation: modalSheetIn 0.15s ease;
      padding-bottom: env(safe-area-inset-bottom);
    }
    @keyframes modalSheetIn {
      from { transform: translateY(100%); opacity: 0.6; }
      to   { transform: translateY(0); opacity: 1; }
    }

    .modal::before {
      content: '';
      display: block;
      width: 40px; height: 4px;
      border-radius: 99px;
      background: var(--border2);
      margin: 8px auto 0;
      opacity: 0.7;
    }

    .modal-header {
      padding: 14px 18px;
      border-bottom: 1px solid var(--border);
      position: sticky;
      top: 0;
      background: var(--bg2);
      z-index: 2;
    }
    .modal-header h3 { font-size: 16px; font-weight: 700; }
    .modal-body { padding: 16px 18px; }
    .modal-footer {
      padding: 12px 16px;
      border-top: 1px solid var(--border);
      gap: 10px;
      flex-wrap: wrap;
      position: sticky;
      bottom: 0;
      background: var(--bg2);
      padding-bottom: max(12px, env(safe-area-inset-bottom));
    }
    .modal-footer .btn {
      flex: 1 1 auto;
      min-width: 0;
      justify-content: center;
    }

    .section-header {
      padding: 14px 16px;
      flex-wrap: wrap;
      gap: 10px;
    }
    .section-header h2 { font-size: 15px; }
    .section-header > div:last-child { width: 100%; }

    .accounts-section,
    .section-content {
      max-width: 720px;
      margin-left: auto;
      margin-right: auto;
    }

    .toast {
      left: 12px;
      right: 12px;
      width: auto;
      max-width: none;
      bottom: max(16px, env(safe-area-inset-bottom));
      font-size: 14px;
    }

    /* ═══════════════════════════════════════════════════════════════════════
       CHAT — FULLSCREEN en móvil
       ═══════════════════════════════════════════════════════════════════════ */

  }

  /* ═══════════════════════════════════════════════════════════════════════
     3. MÓVIL PEQUEÑO (≤ 480px)
     ═══════════════════════════════════════════════════════════════════════ */
  @media (max-width: 480px) {

    .page { padding: 10px 8px; padding-bottom: calc(16px + env(safe-area-inset-bottom)); }

    .stats-grid { grid-template-columns: 1fr; row-gap: 10px; }
    .stat-card { padding: 14px 14px 12px; }
    .stat-card .value { font-size: clamp(20px, 6vw, 24px); }

    .platform-overview-grid { grid-template-columns: 1fr; }

    .modal { max-height: 96vh; }
    .modal-header { flex-wrap: wrap; gap: 8px; }
    .modal-footer { flex-direction: column-reverse; }
    .modal-footer .btn { width: 100%; }

    .topbar-subtitle, .stat-card .sub { font-size: 11px; }

    .expiry-badge, .status-badge {
      font-size: 11px;
      padding: 3px 7px;
    }



  /* ═══════════════════════════════════════════════════════════════════════
     4. LANDSCAPE CORTO
     ═══════════════════════════════════════════════════════════════════════ */
  @media (max-height: 500px) and (orientation: landscape) {
    .mobile-topbar { height: 44px; }
    #main { padding-top: calc(44px + env(safe-area-inset-top)); }
    .modal { max-height: 96vh; }
    .modal-header { padding: 8px 14px; }
    .modal-header h3 { font-size: 14px; }
    .stat-card { padding: 10px; }
    .stat-card .value { font-size: 18px; }
  }


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


  /* ═══════════════════════════════════════════════════════════════════════
     6. iOS SAFARI fixes
    input, select, textarea { font-size: 16px; }
  }


  /* ═══════════════════════════════════════════════════════════════════════
     7. Utilidades
     ═══════════════════════════════════════════════════════════════════════ */
  .mobile-only { display: none; }
  .desktop-only { display: initial; }

  @media (max-width: 768px) {
    .mobile-only { display: initial; }
    .desktop-only { display: none !important; }
    .hidden-sm { display: none !important; }
  }


  /* ══ CENTRO INTELIGENTE ══════════════════════════════════════ */
  .ci-wrap { display:grid;grid-template-columns:1fr 1fr;gap:18px; }
  .ci-panel { background:var(--bg2);border:1px solid var(--border);border-radius:20px;padding:18px 20px 16px;position:relative;overflow:hidden;transition:box-shadow .2s,border-color .2s; }
  .ci-panel::before { content:'';position:absolute;inset:0;border-radius:20px;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(59,130,246,0.04),transparent 60%);pointer-events:none; }
  .ci-panel:hover { box-shadow:0 8px 32px rgba(0,0,0,.35);border-color:var(--border2); }
  .ci-panel-header { display:flex;align-items:center;gap:10px;margin-bottom:16px; }
  .ci-panel-icon { width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0; }
  .ci-icon-activity { background:rgba(59,130,246,0.14);border:1px solid rgba(59,130,246,0.25);color:#60a5fa; }
  .ci-icon-balance  { background:rgba(52,211,153,0.14);border:1px solid rgba(52,211,153,0.25);color:#34d399; }
  .ci-panel-title { font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.2px; }
  .ci-panel-sub   { font-size:11px;color:var(--text3);margin-top:1px; }
  .ci-live-dot { display:flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:#34d399;background:rgba(52,211,153,0.12);border:1.5px solid rgba(52,211,153,0.30);border-radius:20px;padding:4px 11px;flex-shrink:0;letter-spacing:.2px; }
  .ci-live-dot span { width:8px;height:8px;border-radius:50%;background:#34d399;animation:ciPulse 1.4s infinite;flex-shrink:0; }
  @keyframes ciPulse { 0%{opacity:1;box-shadow:0 0 0 0 rgba(52,211,153,.5);transform:scale(1)} 60%{opacity:.8;box-shadow:0 0 0 6px rgba(52,211,153,0);transform:scale(1.15)} 100%{opacity:1;box-shadow:0 0 0 0 rgba(52,211,153,0);transform:scale(1)} }
  .ci-metrics-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px; }
  .ci-metric { background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:7px 8px 6px;transition:all .18s;position:relative;overflow:hidden;min-width:0; }
  .ci-metric::before { content:"";position:absolute;top:0;left:8px;right:8px;height:2px;border-radius:0 0 3px 3px;background:var(--ci-color,var(--accent));opacity:.6;transition:opacity .18s; }
  .ci-metric:hover::before { opacity:1; }
  .ci-metric:hover { background:var(--bg4);border-color:var(--ci-color,var(--accent));transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3); }
  .ci-metric-icon { display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:rgba(0,0,0,0.2);border:1px solid rgba(255,255,255,0.08);margin-bottom:5px;flex-shrink:0;transition:transform .18s; }
  .ci-metric:hover .ci-metric-icon { transform:scale(1.12) rotate(-5deg); }
  .ci-metric-val  { font-family:'DM Sans',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.6px;line-height:1;color:var(--ci-color,var(--text)); }
  .ci-metric-lbl  { font-size:9.5px;font-weight:600;color:rgba(200,210,240,0.75);text-transform:uppercase;letter-spacing:.4px;margin-top:3px;line-height:1.3;word-break:keep-all;overflow-wrap:normal; }
  .ci-metric.ci-glow-update { animation:ciMetricGlow .5s ease; }
  @keyframes ciMetricGlow { 0%{box-shadow:0 0 0 0 var(--ci-glow,rgba(59,130,246,.4))} 50%{box-shadow:0 0 16px 4px var(--ci-glow,rgba(59,130,246,.3))} 100%{box-shadow:none} }
  .ci-val-flip { animation:ciFlip .3s ease; }
  @keyframes ciFlip { 0%{transform:rotateX(-90deg);opacity:0} 100%{transform:rotateX(0);opacity:1} }
  .ci-feed-header { font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:rgba(210,225,255,0.85);display:flex;align-items:center;justify-content:center;gap:5px;margin-bottom:4px; }
  .ci-feed-timestamp { font-size:9.5px;font-weight:500;color:rgba(160,175,210,0.5);text-align:center;margin-bottom:8px;letter-spacing:.2px;transition:opacity .3s; }
  .ci-feed-timestamp.refreshing { opacity:0; }
  @keyframes ciFeedRefresh { 0%{opacity:0;transform:translateY(-4px)} 100%{opacity:1;transform:translateY(0)} }
  .ci-feed-entering { animation:ciFeedRefresh .4s ease both; padding:9px 12px; border-bottom:1px solid rgba(255,255,255,0.05); }
  .ci-feed { flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent;padding:0 4px; }
  .ci-feed-item { display:flex;align-items:flex-start;gap:8px;padding:7px 12px;border-bottom:1px solid rgba(255,255,255,0.04);animation:ciFeedIn .35s ease; }
  .ci-feed-item:last-child { border-bottom:none; }
  @keyframes ciFeedIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
  .ci-feed-dot { width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:5px; }
  .ci-feed-text { font-size:12px;color:rgba(210,220,245,0.85);flex:1;line-height:1.35; }
  .ci-feed-time { font-size:10px;color:rgba(160,175,210,0.65);flex-shrink:0;margin-top:2px; }
  .ci-period-tabs { display:flex;gap:3px;background:rgba(255,255,255,0.04);border-radius:8px;padding:2px; }
  .ci-tab { padding:4px 10px;border-radius:6px;border:none;background:transparent;color:var(--text3);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s; }
  .ci-tab.active { background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.35); }
  .ci-scale-wrap { display:flex;justify-content:center;margin:0 0 12px; }
  .ci-scale-svg { width:200px;color:var(--text3); }
  .ci-balance-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px;max-width:600px;margin-left:auto;margin-right:auto; }
  .ci-bal-item { background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:10px;padding:6px 8px;transition:all .15s;text-align:center; }
  .ci-bal-item:hover { background:rgba(255,255,255,0.055);border-color:var(--border2);transform:translateY(-1px); }
  .ci-bal-label { font-size:8.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text3);margin-bottom:2px;text-align:center; }
  .ci-bal-val   { font-family:'DM Sans',sans-serif;font-size:14px;font-weight:800;letter-spacing:-.4px;color:var(--text);text-align:center; }
  .ci-bal-sub   { font-size:9.5px;color:var(--text3);margin-top:1px;text-align:center; }
  .ci-spark-header { font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text3);display:flex;align-items:center;gap:5px;margin-bottom:7px; }
  .ci-spark-wrap { position:relative; }
  @media (max-width:900px){ .ci-wrap { grid-template-columns:1fr; } }
  @media (max-width:600px){ .ci-metrics-grid { grid-template-columns:repeat(2,1fr); } .ci-balance-grid { grid-template-columns:1fr; } }
  /* ════════════════════════════════════════════════════════════ */

  /* ── Animaciones de toque — móvil / APK ───────────────────────── */
  @keyframes rippleGrow {
    0%   { transform: translate(-50%,-50%) scale(0); opacity: 1; }
    100% { transform: translate(-50%,-50%) scale(18); opacity: 0; }
  }

  /* Estado presionado — aplicado vía JS en touchstart */
  .tbl-btn.btn-pressed {
    transform: scale(0.87) !important;
    filter: brightness(1.45) !important;
    transition: transform 0.08s ease, filter 0.08s ease !important;
  }
  .btn.btn-pressed, .btn-icon.btn-pressed {
    transform: scale(0.93) !important;
    filter: brightness(1.3) !important;
    transition: transform 0.08s ease, filter 0.08s ease !important;
  }
  .nav-item.btn-pressed {
    background: rgba(79,142,247,0.22) !important;
    transform: scale(0.97) !important;
    transition: transform 0.08s ease, background 0.08s ease !important;
  }
  .stat-card.btn-pressed, .platform-mini-card.btn-pressed, .activos-plat-btn.btn-pressed {
    transform: scale(0.97) translateY(0px) !important;
    filter: brightness(1.15) !important;
    transition: transform 0.1s ease, filter 0.1s ease !important;
  }

  /* Ripple: overflow hidden solo en móvil via JS (ver initTouchAnimations) */
  .btn, .btn-icon, .activos-plat-btn { position: relative; }

  /* GPU acceleration para elementos que se animan frecuentemente */
  .modal, .modal-overlay, .card, .btn, .nav-item,
  .platform-card, .client-card, .accounts-section,
  .auth-card, #auth-screen, #app-screen {
    will-change: auto;
    backface-visibility: hidden;
  }

  /* contain:paint eliminado — recortaba la animación hover de las tarjetas */

  /* Scrolling nativo suave */
  * { -webkit-overflow-scrolling: touch; scroll-behavior: auto; }

  /* Eliminar outline/focus delay en botones */
  button, .btn, .nav-item, .btn-icon {
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  /* Fuentes: precalcular renderizado */
  body { text-rendering: optimizeSpeed; -webkit-font-smoothing: antialiased; }

  /* Inputs: aceleración hardware */
  input, select, textarea {
    transform: translateZ(0);
  }

  /* ── MÓVIL: Optimizaciones específicas ─────────────────── */
  @media (max-width: 768px) {
    /* Eliminar sombras costosas en móvil */
    .card, .accounts-section { box-shadow: 0 1px 3px rgba(0,0,0,0.15) !important; }
    /* Reducir blur/filter en móvil (muy costoso) */
    .modal-overlay { backdrop-filter: none !important; -webkit-backdrop-filter: none !important; }
    /* Solo acortar animaciones de entrada de modales, no los spinners */
    .modal-overlay.show .modal { animation-duration: 0.12s !important; }
    /* Transiciones de UI más rápidas */
    .btn, .btn-icon, .nav-item, .card, input, select { transition-duration: 0.1s !important; }
  }
  /* ═══════════════════════════════════════════════════════════@keyframes modalBoxIn { from { opacity:0; transform:translateY(10px) scale(.97); } to { opacity:1; transform:translateY(0) scale(1); } }
  @keyframes overlayIn  { from { opacity:0 } to { opacity:1 } }
  @keyframes overlayOut { from { opacity:1 } to { opacity:0 } }
  @keyframes modalIn    { from { opacity:0; transform:scale(0.9) translateY(20px) } to { opacity:1; transform:scale(1) translateY(0) } }
  @keyframes modalOut   { from { opacity:1; transform:scale(1) translateY(0) } to { opacity:0; transform:scale(0.9) translateY(20px) } }
  .modal {
    background: white;
  @keyframes fadeIn     { from { opacity:0 } to { opacity:1 } }
  @keyframes slideUp    { from { opacity:0; transform:translateY(16px) scale(0.97) } to { opacity:1; transform:translateY(0) scale(1) } }
    border: 1px solid var(--border);
    border-radius: 24px;
    width: 100%;
    max-width: 620px;
    max-height: 90vh;
    box-shadow: 0 20px 60px rgba(0,0,0,0.15);
    animation: modalIn 0.15s cubic-bezier(0.25,0.8,0.25,1) forwards;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }
  .modal-header {
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--border);
    display: flex;
    align-items: center;
    gap: 12px;
    flex-shrink: 0 !important;
  }
  .modal-header h3 { font-family: 'DM Sans', sans-serif; font-size: 16px; font-weight: 700; flex: 1; }
  .modal-body { padding: 20px 24px; overflow-y: auto !important; flex: 1 !important; min-height: 0 !important; }
  .modal-body::-webkit-scrollbar { width: 4px; }
  .modal-body::-webkit-scrollbar-track { background: transparent; }
  .modal-body::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 99px; }
  .modal-footer { padding: 16px 24px; border-top: 1px solid var(--border); display: flex; gap: 10px; justify-content: flex-end; flex-shrink: 0 !important; }

  .form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
  .form-group { display: flex; flex-direction: column; gap: 6px; }
  .form-group.full { grid-column: 1 / -1; }
  .form-group label { font-size: 14px; color: var(--text2); font-weight: 500; }
  .form-group input, .form-group select, .form-group textarea {
    background: var(--bg3);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 8px 12px;
    border-radius: var(--radius-sm);
    font-family: inherit;
    font-size: 14px;
    outline: none;
    transition: border-color 0.15s;
  }
  .form-group input:focus, .form-group select:focus, .form-group textarea:focus {
    border-color: var(--accent);
  }
  .form-group select option { background: var(--bg3); }
  .form-section-title {
    font-size: 14px;
    text-transform: uppercase;
    letter-spacing: 1.2px;
    color: var(--text3);
    font-weight: 500;
    grid-column: 1 / -1;
    margin-top: 6px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
  }

  /* ── Modales Agregar Cliente + Cuenta: compactos ────────────── */

  #modal-client .modal-header,
  #modal-account .modal-header { padding: 16px 20px !important; }
  #modal-client .modal-header h3,
  #modal-account .modal-header h3 { font-size: 15px !important; }
  #modal-client .modal-body { padding: 18px 20px; }
  #modal-account .modal-body { padding: 18px 20px; }
  #modal-client .modal-footer,
  #modal-account .modal-footer { padding: 12px 20px !important; }
  #modal-client .modal-footer .btn,
  #modal-account .modal-footer .btn { padding: 9px 20px !important; font-size: 13.5px !important; height: auto !important; }
  #modal-client .modal { max-width: 580px; }
  #modal-account .modal { max-width: 580px; }

  /* ── Redesigned client modal ──────────────────────────────── */
  .mc-modal { max-width: 500px !important; padding: 0 !important; border-radius: 18px !important; overflow: hidden; }
  .mc-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 18px 20px 16px;
    border-bottom: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.02);
  }
  .mc-header-left { display: flex; align-items: center; gap: 12px; }
  .mc-plat-icon {
    width: 36px; height: 36px; border-radius: 10px;
    background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.2);
    display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  }
  .mc-header-label { font-size: 10px; font-weight: 700; letter-spacing: 1.5px; color: var(--text3); text-transform: uppercase; margin-bottom: 2px; }
  .mc-header-title { font-size: 15px; font-weight: 700; margin: 0; color: var(--text); }
  .mc-close {
    width: 30px; height: 30px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.08);
    background: rgba(255,255,255,0.04); cursor: pointer; display: flex;
    align-items: center; justify-content: center; color: var(--text3);
    transition: background .15s, color .15s;
  }

  .mc-body { padding: 16px 20px; display: flex; flex-direction: column; gap: 10px; max-height: 68vh; overflow-y: auto; }
  .mc-body::-webkit-scrollbar { width: 4px; }
  .mc-body::-webkit-scrollbar-track { background: transparent; }
  .mc-body::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 4px; }
  .mc-footer {
    display: flex; align-items: center; justify-content: flex-end; gap: 8px;
    padding: 14px 20px; border-top: 1px solid rgba(255,255,255,0.06);
    background: rgba(255,255,255,0.02);
  }
  
  .mc-btn-cancel:hover { background: rgba(255,255,255,0.09); color: var(--text); }
  
  .mc-btn-save:hover { opacity: .9; transform: translateY(-1px); }
  .mc-btn-save:active { transform: translateY(0); }

  /* Form blocks */
  @keyframes mcfSlideIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
  .mcf-block {
    background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.07);
    border-radius: 12px; padding: 14px 14px 12px; display: flex; flex-direction: column; gap: 10px;
    animation: mcfSlideIn .25s ease both;
  }
  .mcf-block-label {
    font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px;
    color: var(--accent2); display: flex; align-items: center; gap: 5px; margin-bottom: 2px;
  }
  .mcf-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
  .mcf-row3 { display: grid; grid-template-columns: 72px 1fr 80px; gap: 8px; }
  .mcf-field { display: flex; flex-direction: column; gap: 4px; }
  .mcf-label { font-size: 10.5px; font-weight: 600; letter-spacing: .4px; color: var(--text3); text-transform: uppercase; }
  .mcf-input, .mcf-select {
    height: 36px; padding: 0 11px; border-radius: 9px;
    background: var(--bg4); border: 1.5px solid rgba(255,255,255,0.08);
    color: var(--text); font-size: 13px; outline: none;
    transition: border-color .15s, box-shadow .15s;
    font-family: inherit; width: 100%; box-sizing: border-box;
  }
  .mcf-input:focus, .mcf-select:focus {
    border-color: rgba(99,102,241,.5);
    box-shadow: 0 0 0 3px rgba(99,102,241,.1);
  }
  .mcf-input::placeholder { color: rgba(255,255,255,.2); }
  .mcf-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; padding-right: 28px; }

  /* Legacy section cards (keep for other modals) */
  .mc-section {
    background: rgba(255,255,255,0.025);
    border: 1px solid rgba(255,255,255,0.07);
    border-radius: 14px; padding: 14px 16px;
    display: flex; flex-direction: column; gap: 12px;
  }
  .mc-section-title {
    font-size: 10.5px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .8px; color: var(--accent2);
    display: flex; align-items: center; gap: 6px; margin-bottom: 2px;
  }
  .mc-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .mc-grid3 { display: grid; grid-template-columns: 80px 1fr 90px; gap: 10px; }
  .mc-gridfull { grid-column: 1 / -1; }
    /* ── Admin modal redesign ──────────────────────────────────── */
  .adm-modal { max-width: 680px !important; padding: 0 !important; border-radius: 18px !important; overflow: hidden; }
  .adm-header { display:flex; align-items:center; justify-content:space-between; padding:18px 20px 16px; border-bottom:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.02); }
  .adm-header-left { display:flex; align-items:center; gap:12px; }
  .adm-header-icon { width:36px; height:36px; border-radius:10px; background:rgba(99,102,241,.12); border:1px solid rgba(99,102,241,.2); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
  .adm-header-label { font-size:10px; font-weight:700; letter-spacing:1.5px; color:var(--text3); text-transform:uppercase; margin-bottom:2px; }
  .adm-header-title { font-size:15px; font-weight:700; margin:0; color:var(--text); }
  .adm-body { padding:16px 20px; display:flex; flex-direction:column; gap:12px; max-height:72vh; overflow-y:auto; }
  .adm-body::-webkit-scrollbar { width:4px; }
  .adm-body::-webkit-scrollbar-thumb { background:rgba(255,255,255,.1); border-radius:4px; }
  .adm-footer { display:flex; align-items:center; justify-content:space-between; padding:12px 20px; border-top:1px solid rgba(255,255,255,0.06); background:rgba(255,255,255,0.02); }
  .adm-create-card { background:rgba(99,102,241,.04); border:1px solid rgba(99,102,241,.12); border-radius:14px; padding:16px; }
  .adm-section-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--accent2); display:flex; align-items:center; gap:5px; margin-bottom:10px; }
  .adm-create-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }
  .adm-field { display:flex; flex-direction:column; gap:4px; }
  .adm-label { font-size:10.5px; font-weight:600; color:var(--text3); text-transform:uppercase; letter-spacing:.4px; }
  .adm-input { height:34px; padding:0 10px; border-radius:8px; background:var(--bg4); border:1.5px solid rgba(255,255,255,0.08); color:var(--text); font-size:13px; outline:none; transition:border-color .15s, box-shadow .15s; font-family:inherit; width:100%; box-sizing:border-box; }
  .adm-input:focus { border-color:rgba(99,102,241,.5); box-shadow:0 0 0 3px rgba(99,102,241,.08); }
  .adm-input::placeholder { color:rgba(255,255,255,.2); }
  .adm-select { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 8px center; padding-right:26px; }
  .adm-loading { padding:24px; text-align:center; color:var(--text3); font-size:13px; }
  /* User cards */
  @keyframes admCardIn { from { opacity:0; transform:translateY(4px); } to { opacity:1; transform:translateY(0); } }
  .adm-user-list { display:flex; flex-direction:column; gap:6px; }
  .adm-user-card { display:flex; align-items:center; gap:12px; background:rgba(255,255,255,0.025); border:1px solid rgba(255,255,255,0.07); border-radius:12px; padding:12px 14px; animation:admCardIn .2s ease both; transition:background .15s; }
  .adm-user-card:hover { background:rgba(255,255,255,0.04); }
  .adm-user-card.adm-inactive { opacity:.45; }
  .adm-avatar { width:38px; height:38px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:14px; font-weight:700; flex-shrink:0; }
  .adm-user-info { flex:1; min-width:0; }
  .adm-user-name { font-size:13px; font-weight:600; color:var(--text); display:flex; align-items:center; gap:6px; }
  .adm-user-email { font-size:11.5px; color:var(--text3); margin-top:2px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
  .adm-user-username { font-size:10.5px; color:var(--accent2); margin-top:1px; }
  .adm-role-badge { padding:2px 8px; border-radius:5px; font-size:10px; font-weight:700; letter-spacing:.3px; flex-shrink:0; }
  .adm-status-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
  .adm-last-login { font-size:11px; color:var(--text3); flex-shrink:0; min-width:64px; text-align:right; }
  .adm-actions { display:flex; gap:5px; flex-shrink:0; }
  .adm-btn { height:28px; padding:0 10px; border-radius:7px; border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.05); color:var(--text2); font-size:11px; font-weight:600; cursor:pointer; transition:all .15s; display:inline-flex; align-items:center; gap:4px; font-family:inherit; }
  .adm-btn:hover { background:rgba(255,255,255,0.1); color:var(--text); }
  .adm-btn-danger:hover { background:rgba(239,68,68,.15); color:#f87171; border-color:rgba(239,68,68,.25); }
  .adm-btn-success:hover { background:rgba(16,185,129,.15); color:#34d399; border-color:rgba(16,185,129,.25); }
  .adm-me-badge { font-size:9px; background:rgba(99,102,241,.15); color:#818cf8; border:1px solid rgba(99,102,241,.25); border-radius:4px; padding:1px 5px; font-weight:700; letter-spacing:.5px; }

</style>


/* ── Inline styles extracted from HTML ── */

/* from L1551 */

/* ── Modal post-corte: animaciones y estilos ── */
@keyframes pco-overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes pco-modal-in {
  from { opacity: 0; transform: translateY(14px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}
@keyframes pco-step-in {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0);    }
}
#modal-post-corte.show               { animation: pco-overlay-in 0.22s ease both; }
#modal-post-corte.show .modal-post-corte-inner { animation: pco-modal-in  0.3s cubic-bezier(.34,1.3,.64,1) both; }
.pco-step {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 9px 12px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 9px;
  animation: pco-step-in 0.3s cubic-bezier(.34,1.3,.64,1) both;
}
.pco-step-num {
  width: 20px; height: 20px; min-width: 20px;
  background: rgba(168,85,247,0.12);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  font-size: 10.5px; font-weight: 700; color: #a855f7;
}
.pco-step-txt {
  font-size: 12px; color: var(--text2); line-height: 1.45; padding-top: 2px;
}

/* from L6103 */

    .tag-chip {
      display:inline-flex;
      align-items:center;
      gap:4px;
      padding:5px 10px;
      background:var(--bg3);
      border:1px solid var(--border);
      border-radius:20px;
      font-size:12px;
      color:var(--text);
      animation:correosCardIn 0.2s ease;
    }
    .tag-chip-remove {
      background:none;
      border:none;
      color:var(--text3);
      cursor:pointer;
      padding:0;
      display:flex;
      align-items:center;
      transition:color 0.15s;
    }
    .tag-chip-remove:hover { color:#ef4444; }
    .filtro-plataforma-row {
      display:flex;
      align-items:center;
      gap:12px;
      padding:12px;
      background:var(--bg2);
      border:1px solid var(--border);
      border-radius:10px;
      margin-bottom:8px;
      cursor:pointer;
      transition:all 0.15s;
    }
    .filtro-plataforma-row:hover {
      border-color:var(--accent);
      background:var(--bg3);
    }
  
/* from L6297 */

      @keyframes dispSpin { to { transform: rotate(360deg); } }
      @keyframes dispFade { from { opacity:0; transform: translateY(6px); } to { opacity:1; transform: translateY(0); } }

      /* ── Separadores de sección ─────────────────────────────── */
      .disp-section-title {
        font-family: 'Syne', sans-serif;
        font-size: 12px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.8px;
        color: var(--text2);
        padding: 14px 4px 10px;
        display: flex;
        align-items: center;
        gap: 8px;
      }
      .disp-section-title.disp-section-history {
        border-top: 1px dashed var(--border);
        margin-top: 16px;
        padding-top: 18px;
        color: var(--text3);
      }
      .disp-dot {
        display: inline-block;
        width: 8px; height: 8px;
        border-radius: 50%;
        flex-shrink: 0;
      }
      .disp-dot-green { background: var(--green2); box-shadow: 0 0 0 3px rgba(16,185,129,0.18); }
      .disp-dot-gray  { background: var(--text3);  opacity: 0.6; }

      /* ── Tarjeta de dispositivo ──────────────────────────────── */
      .disp-card {
        display: grid;
        grid-template-columns: 56px 1fr auto;
        gap: 14px;
        align-items: center;
        padding: 14px 16px;
        border: 1px solid var(--border);
        border-radius: var(--radius-sm);
        background: var(--bg2);
        margin-bottom: 10px;
        animation: dispFade 0.25s ease both;
        transition: border-color 0.15s, box-shadow 0.15s, opacity 0.15s;
      }
      .disp-card:hover { border-color: var(--border2); }

      .disp-card.is-current {
        border-color: rgba(16,185,129,0.45);
        background: linear-gradient(135deg, rgba(16,185,129,0.06), rgba(16,185,129,0.02));
      }
      body.dark .disp-card.is-current {
        background: linear-gradient(135deg, rgba(16,185,129,0.10), rgba(16,185,129,0.04));
      }

      .disp-card.is-inactive {
        opacity: 0.7;
        background: var(--bg3);
      }
      .disp-card.is-inactive:hover { opacity: 0.92; }
      .disp-card.is-inactive .disp-icon { color: var(--text3); }

      /* ── Icono + bandera ─────────────────────────────────────── */
      .disp-icon {
        width: 56px; height: 56px;
        border-radius: 14px;
        display: flex; align-items: center; justify-content: center;
        background: var(--surface);
        color: var(--accent2);
        font-size: 24px;
        position: relative;
      }
      .disp-icon .disp-flag {
        position: absolute;
        right: -6px; bottom: -6px;
        line-height: 1;
        background: var(--bg2);
        border: 2px solid var(--bg2);
        border-radius: 50%;
        width: 22px; height: 22px;
        display: flex; align-items: center; justify-content: center;
        overflow: hidden;
        box-shadow: 0 1px 4px rgba(0,0,0,0.12);
      }
      .disp-icon .disp-flag-emoji  { font-size: 13px; }
      .disp-icon .disp-flag-code   {
        font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
        font-size: 8.5px;
        font-weight: 700;
        letter-spacing: 0.3px;
        color: var(--text2);
        text-transform: uppercase;
      }
      .disp-icon .disp-flag-globe  {
        color: var(--text3);
        display: flex; align-items: center; justify-content: center;
      }

      /* ── Cuerpo de la tarjeta ────────────────────────────────── */
      .disp-body { min-width: 0; }
      .disp-title {
        font-family: 'Syne', sans-serif;
        font-size: 15px;
        font-weight: 700;
        color: var(--text);
        margin: 0 0 4px;
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
      }

      /* ── Badges de estado ────────────────────────────────────── */
      .disp-badge {
        font-size: 10px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 99px;
        letter-spacing: 0.4px;
        text-transform: uppercase;
        border: 1px solid transparent;
      }
      .disp-badge-current {
        background: rgba(16,185,129,0.15);
        color: var(--green2);
        border-color: rgba(16,185,129,0.3);
      }
      .disp-badge-active {
        background: rgba(59,130,246,0.13);
        color: var(--accent2);
        border-color: rgba(59,130,246,0.3);
      }
      .disp-badge-closed {
        background: var(--surface);
        color: var(--text2);
        border-color: var(--border);
      }
      .disp-badge-expired {
        background: rgba(245,158,11,0.13);
        color: var(--amber);
        border-color: rgba(245,158,11,0.3);
      }

      /* ── Meta info ───────────────────────────────────────────── */
      .disp-meta {
        color: var(--text2);
        font-size: 12.5px;
        line-height: 1.5;
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: center;
      }
      .disp-meta span { display: inline-flex; align-items: center; gap: 4px; }
      .disp-meta .disp-ip {
        font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
        font-size: 11.5px;
        background: var(--surface);
        padding: 2px 6px;
        border-radius: 5px;
        color: var(--text);
      }

      /* ── Acciones ────────────────────────────────────────────── */
      .disp-actions { display: flex; gap: 6px; flex-shrink: 0; }
      .disp-actions .btn { padding: 7px 12px; font-size: 12px; }

      /* ── Toggle del historial (colapsable últimos 30 días) ───── */
      .disp-hist-toggle {
        display: flex;
        width: 100%;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        padding: 11px 14px;
        margin: 18px 0 10px;
        border: 1px dashed var(--border);
        border-radius: var(--radius-sm);
        background: transparent;
        color: var(--text2);
        font-family: 'Syne', sans-serif;
        font-size: 12px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.6px;
        cursor: pointer;
        transition: background 0.15s, border-color 0.15s, color 0.15s;
      }
      .disp-hist-toggle:hover {
        background: var(--surface);
        border-color: var(--border2);
        border-style: solid;
        color: var(--text);
      }
      .disp-hist-toggle:focus-visible {
        outline: 2px solid var(--accent2);
        outline-offset: 2px;
      }
      .disp-hist-toggle[aria-expanded="true"] {
        border-style: solid;
        background: var(--bg3);
        color: var(--text);
      }

      .disp-hist-toggle-left {
        display: flex;
        align-items: center;
        gap: 9px;
        min-width: 0;
        flex: 1 1 auto;
        text-align: left;
      }
      .disp-hist-toggle-left > span:nth-child(2) {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }

      .disp-hist-count {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 22px;
        height: 20px;
        padding: 0 7px;
        border-radius: 999px;
        background: var(--surface2);
        color: var(--text2);
        font-family: 'DM Sans', sans-serif;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0;
        text-transform: none;
        flex-shrink: 0;
      }
      body.dark .disp-hist-count { background: var(--surface); }

      .disp-hist-arrow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--text3);
        flex-shrink: 0;
        transition: color 0.15s;
      }
      .disp-hist-toggle:hover .disp-hist-arrow,
      .disp-hist-toggle[aria-expanded="true"] .disp-hist-arrow { color: var(--text); }

      .disp-hist-body {
        animation: dispFade 0.2s ease both;
        padding-top: 2px;
      }

      /* ── Responsive ──────────────────────────────────────────── */
      @media (max-width: 640px) {
        .disp-card {
          grid-template-columns: 48px 1fr;
          padding: 12px 13px;
          gap: 12px;
        }
        .disp-icon { width: 48px; height: 48px; font-size: 20px; }
        .disp-actions {
          grid-column: 1 / -1;
          margin-top: 4px;
          justify-content: flex-end;
        }
        .disp-hist-toggle {
          padding: 10px 12px;
          font-size: 11px;
          letter-spacing: 0.5px;
        }
        .disp-hist-count { min-width: 20px; height: 18px; font-size: 10px; }
      }
    
/* from L6574 */

      @keyframes dispSpin { to { transform: rotate(360deg); } }
      @keyframes dispFade { from { opacity:0; transform: translateY(6px); } to { opacity:1; transform: translateY(0); } }

      /* ── Separadores de sección ─────────────────────────────── */
      .disp-section-title {
        font-family: 'Syne', sans-serif;
        font-size: 12px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.8px;
        color: var(--text2);
        padding: 14px 4px 10px;
        display: flex;
        align-items: center;
        gap: 8px;
      }
      .disp-section-title.disp-section-history {
        border-top: 1px dashed var(--border);
        margin-top: 16px;
        padding-top: 18px;
        color: var(--text3);
      }
      .disp-dot {
        display: inline-block;
        width: 8px; height: 8px;
        border-radius: 50%;
        flex-shrink: 0;
      }
      .disp-dot-green { background: var(--green2); box-shadow: 0 0 0 3px rgba(16,185,129,0.18); }
      .disp-dot-gray  { background: var(--text3);  opacity: 0.6; }

      /* ── Tarjeta de dispositivo ──────────────────────────────── */
      .disp-card {
        display: grid;
        grid-template-columns: 56px 1fr auto;
        gap: 14px;
        align-items: center;
        padding: 14px 16px;
        border: 1px solid var(--border);
        border-radius: var(--radius-sm);
        background: var(--bg2);
        margin-bottom: 10px;
        animation: dispFade 0.25s ease both;
        transition: border-color 0.15s, box-shadow 0.15s, opacity 0.15s;
      }
      .disp-card:hover { border-color: var(--border2); }

      .disp-card.is-current {
        border-color: rgba(16,185,129,0.45);
        background: linear-gradient(135deg, rgba(16,185,129,0.06), rgba(16,185,129,0.02));
      }
      body.dark .disp-card.is-current {
        background: linear-gradient(135deg, rgba(16,185,129,0.10), rgba(16,185,129,0.04));
      }

      .disp-card.is-inactive {
        opacity: 0.7;
        background: var(--bg3);
      }
      .disp-card.is-inactive:hover { opacity: 0.92; }
      .disp-card.is-inactive .disp-icon { color: var(--text3); }

      /* ── Icono + bandera ─────────────────────────────────────── */
      .disp-icon {
        width: 56px; height: 56px;
        border-radius: 14px;
        display: flex; align-items: center; justify-content: center;
        background: var(--surface);
        color: var(--accent2);
        font-size: 24px;
        position: relative;
      }
      .disp-icon .disp-flag {
        position: absolute;
        right: -6px; bottom: -6px;
        line-height: 1;
        background: var(--bg2);
        border: 2px solid var(--bg2);
        border-radius: 50%;
        width: 22px; height: 22px;
        display: flex; align-items: center; justify-content: center;
        overflow: hidden;
        box-shadow: 0 1px 4px rgba(0,0,0,0.12);
      }
      .disp-icon .disp-flag-emoji  { font-size: 13px; }
      .disp-icon .disp-flag-code   {
        font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
        font-size: 8.5px;
        font-weight: 700;
        letter-spacing: 0.3px;
        color: var(--text2);
        text-transform: uppercase;
      }
      .disp-icon .disp-flag-globe  {
        color: var(--text3);
        display: flex; align-items: center; justify-content: center;
      }

      /* ── Cuerpo de la tarjeta ────────────────────────────────── */
      .disp-body { min-width: 0; }
      .disp-title {
        font-family: 'Syne', sans-serif;
        font-size: 15px;
        font-weight: 700;
        color: var(--text);
        margin: 0 0 4px;
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
      }

      /* ── Badges de estado ────────────────────────────────────── */
      .disp-badge {
        font-size: 10px;
        font-weight: 700;
        padding: 2px 8px;
        border-radius: 99px;
        letter-spacing: 0.4px;
        text-transform: uppercase;
        border: 1px solid transparent;
      }
      .disp-badge-current {
        background: rgba(16,185,129,0.15);
        color: var(--green2);
        border-color: rgba(16,185,129,0.3);
      }
      .disp-badge-active {
        background: rgba(59,130,246,0.13);
        color: var(--accent2);
        border-color: rgba(59,130,246,0.3);
      }
      .disp-badge-closed {
        background: var(--surface);
        color: var(--text2);
        border-color: var(--border);
      }
      .disp-badge-expired {
        background: rgba(245,158,11,0.13);
        color: var(--amber);
        border-color: rgba(245,158,11,0.3);
      }

      /* ── Meta info ───────────────────────────────────────────── */
      .disp-meta {
        color: var(--text2);
        font-size: 12.5px;
        line-height: 1.5;
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
        align-items: center;
      }
      .disp-meta span { display: inline-flex; align-items: center; gap: 4px; }
      .disp-meta .disp-ip {
        font-family: 'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
        font-size: 11.5px;
        background: var(--surface);
        padding: 2px 6px;
        border-radius: 5px;
        color: var(--text);
      }

      /* ── Acciones ────────────────────────────────────────────── */
      .disp-actions { display: flex; gap: 6px; flex-shrink: 0; }
      .disp-actions .btn { padding: 7px 12px; font-size: 12px; }

      /* ── Toggle del historial (colapsable últimos 30 días) ───── */
      .disp-hist-toggle {
        display: flex;
        width: 100%;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        padding: 11px 14px;
        margin: 18px 0 10px;
        border: 1px dashed var(--border);
        border-radius: var(--radius-sm);
        background: transparent;
        color: var(--text2);
        font-family: 'Syne', sans-serif;
        font-size: 12px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.6px;
        cursor: pointer;
        transition: background 0.15s, border-color 0.15s, color 0.15s;
      }
      .disp-hist-toggle:hover {
        background: var(--surface);
        border-color: var(--border2);
        border-style: solid;
        color: var(--text);
      }
      .disp-hist-toggle:focus-visible {
        outline: 2px solid var(--accent2);
        outline-offset: 2px;
      }
      .disp-hist-toggle[aria-expanded="true"] {
        border-style: solid;
        background: var(--bg3);
        color: var(--text);
      }

      .disp-hist-toggle-left {
        display: flex;
        align-items: center;
        gap: 9px;
        min-width: 0;
        flex: 1 1 auto;
        text-align: left;
      }
      .disp-hist-toggle-left > span:nth-child(2) {
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }

      .disp-hist-count {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 22px;
        height: 20px;
        padding: 0 7px;
        border-radius: 999px;
        background: var(--surface2);
        color: var(--text2);
        font-family: 'DM Sans', sans-serif;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0;
        text-transform: none;
        flex-shrink: 0;
      }
      body.dark .disp-hist-count { background: var(--surface); }

      .disp-hist-arrow {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        color: var(--text3);
        flex-shrink: 0;
        transition: color 0.15s;
      }
      .disp-hist-toggle:hover .disp-hist-arrow,
      .disp-hist-toggle[aria-expanded="true"] .disp-hist-arrow { color: var(--text); }

      .disp-hist-body {
        animation: dispFade 0.2s ease both;
        padding-top: 2px;
      }

      /* ── Responsive ──────────────────────────────────────────── */
      @media (max-width: 640px) {
        .disp-card {
          grid-template-columns: 48px 1fr;
          padding: 12px 13px;
          gap: 12px;
        }
        .disp-icon { width: 48px; height: 48px; font-size: 20px; }
        .disp-actions {
          grid-column: 1 / -1;
          margin-top: 4px;
          justify-content: flex-end;
        }
        .disp-hist-toggle {
          padding: 10px 12px;
          font-size: 11px;
          letter-spacing: 0.5px;
        }
        .disp-hist-count { min-width: 20px; height: 18px; font-size: 10px; }
      }
    