/* ══════════════════════════════════════════════════════════════════════
   qma-pnc.css — QMA Plan Nacional Ciberseguridad (PNC) + familia
   Sistema de "long-form marketing page" (lm-*).
   Carga condicional en child theme (FASE 3D, functions.php).

   Origen: extraído del CSS inline de qma.mx/socios-estrategicos/logicmonitor/
   Reusable en: PNC + descendientes, partner pages, verticales, landings serias.

   IMPORTANTE — sistema de iconos NO incluido aquí.
   .qma-ico / .qma-ico-wrap viven en WPCode 46563 (site-wide).
   No duplicar para evitar conflicto de mantenimiento.

   v1.0 · 2026-05-03 · CC · Para QMA child theme
   ══════════════════════════════════════════════════════════════════════ */

/* ──────────────────────────────────────────────
   VARIABLES DE PÁGINA
   ────────────────────────────────────────────── */
:root {
  --qma-blue:       #0B5CFF;
  --qma-navy:       #084480;
  --qma-body:       #374151;
  --qma-bg:         #FFFFFF;
  --qma-bg-light:   #F0F5FA;
  --qma-border:     rgba(0,0,0,0.12);
  --qma-slate:      #1e293b;
  --qma-gray-mid:   #D1D5DB;
  --qma-lime:       #A3E635;
  --lm-purple:      #6833CA;
  --lm-purple-soft: #EDE8FB;
  --lm-purple-mid:  #B084F5;
  /* Brand dark navy — usado como fondo de banners destacados */
  --lm-brand-dark:  #0C1635;
}

/* ──────────────────────────────────────────────
   CONTENT WRAPPER (override del global solo en pages PNC)
   ────────────────────────────────────────────── */
.qma-mssp-wrap {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}

/* ──────────────────────────────────────────────
   LAYOUT — sección estándar
   ────────────────────────────────────────────── */
.lm-section     { padding: 4.5rem 0; }
.lm-section--alt{ background: var(--qma-bg-light); }

/* ──────────────────────────────────────────────
   TIPOGRAFÍA (gobierno / lectura larga)
   ────────────────────────────────────────────── */
.lm-section h2 {
  font-size: clamp(1.5rem, 2.8vw, 2rem);
  font-weight: 700;
  color: var(--qma-navy);
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.lm-section h3 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--qma-navy);
  margin-bottom: 0.35rem;
}
.lm-section p { color: var(--qma-body); font-size: 0.92rem; line-height: 1.7; }
.lm-section-intro {
  margin-top: 0.6rem;
  margin-bottom: 2.25rem;
  color: var(--qma-body);
  max-width: 580px;
}

/* Inline content links — purple → navy on hover */
.lm-section a:not([class]) {
  color: var(--lm-purple);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
.lm-section a:not([class]):hover { color: var(--qma-navy); }

/* ──────────────────────────────────────────────
   PARTNER BADGE (pill con dot)
   Útil para tags tipo "DOF 17/12/2025", "Política APF", etc.
   ────────────────────────────────────────────── */
.lm-partner-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: var(--lm-purple-soft);
  border: 1px solid rgba(104,51,202,0.25);
  border-radius: 40px;
  padding: 0.3rem 0.9rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--lm-purple);
  margin-bottom: 1.25rem;
}
.lm-partner-badge .dot {
  width: 6px; height: 6px;
  background: var(--lm-purple);
  border-radius: 50%;
}
.lm-logo-pair {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.8rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}
.lm-logo-lm {
  background: var(--lm-purple);
  color: #fff;
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
}

/* ──────────────────────────────────────────────
   HERO (grid 2 columnas: copy + stats)
   ────────────────────────────────────────────── */
#lm-hero {
  background: var(--qma-bg);
  border-bottom: 1px solid var(--qma-border);
  padding: 5rem 0 4rem;
}
.lm-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: center;
}
.lm-hero-title {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 700;
  color: var(--qma-navy);
  line-height: 1.18;
  letter-spacing: -0.02em;
  margin-bottom: 1rem;
}
.lm-hero-title em { font-style: normal; color: var(--lm-purple); }
.lm-hero-sub {
  font-size: 1rem;
  color: var(--qma-body);
  line-height: 1.75;
  margin-bottom: 2rem;
  max-width: 500px;
}
.lm-cta-row { display: flex; gap: 0.75rem; flex-wrap: wrap; }

/* Stats cards (2x2 default) */
.lm-stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.lm-stat {
  background: var(--qma-bg-light);
  border: 1px solid var(--qma-border);
  border-top: 3px solid var(--lm-purple);
  border-radius: 12px;
  padding: 1.25rem 1rem;
  text-align: center;
}
.lm-stat .num {
  display: block;
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--qma-navy);
  line-height: 1;
  margin-bottom: 0.4rem;
}
.lm-stat .label { font-size: 0.78rem; color: var(--qma-body); line-height: 1.45; }

/* ──────────────────────────────────────────────
   STICKY NAV (in-page anchor navigation)
   ────────────────────────────────────────────── */
#lm-nav {
  position: sticky;
  top: var(--ast-header-height, 80px); /* CC fix 2026-05-03: respeta header Astra sticky */
  z-index: 35; /* menor que header del site (que usa 99+) para no taparlo */
  background: #fff;
  box-shadow: 0 1px 3px rgba(8,68,128,0.08);
  border-bottom: 2px solid var(--lm-purple);
  padding: 0.9rem 0;
}
.lm-nav-links {
  display: flex;
  gap: 1.4rem;
  overflow-x: auto;
  scrollbar-width: none;
  align-items: center;
}
.lm-nav-links::-webkit-scrollbar { display: none; }
/* Label "En esta página" prominente — guía visual para el usuario */
.lm-nav-links::before {
  content: "En esta página:";
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--lm-purple);
  white-space: nowrap;
  padding-right: 0.85rem;
  border-right: 1px solid var(--qma-border);
}
.lm-nav-links a {
  white-space: nowrap;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--qma-navy);
  text-decoration: none;
  transition: color 0.15s;
  padding: 0.15rem 0;
}
.lm-nav-links a:hover { color: var(--lm-purple); }
@media (max-width: 600px) {
  .lm-nav-links::before { display: none; } /* mobile: deja más espacio para los links */
  #lm-nav { padding: 0.6rem 0; }
}

/* ──────────────────────────────────────────────
   QUÉ ES (grid 2 cols + lista de KVs + blockquote)
   ────────────────────────────────────────────── */
.lm-que-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: start;
}
.lm-kv-list {
  list-style: none;
  margin-top: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.lm-kv-list li {
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
  font-size: 0.9rem;
  color: var(--qma-body);
  line-height: 1.6;
}
.lm-kv-list li .qma-ico-wrap { margin-top: 1px; }
.lm-blockquote {
  border-left: 3px solid var(--lm-purple);
  background: var(--lm-purple-soft);
  padding: 1.25rem 1.25rem 1.25rem 1.5rem;
  border-radius: 0 8px 8px 0;
  font-size: 0.93rem;
  color: var(--qma-slate);
  font-style: italic;
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.lm-blockquote cite {
  display: block;
  margin-top: 0.6rem;
  font-style: normal;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--lm-purple);
}

/* ──────────────────────────────────────────────
   PILARES — grid 3 cols con border-top purple
   Patrón clave para los 8 ejes APF, capacidades operativas, etc.
   ────────────────────────────────────────────── */
.lm-pilares-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.lm-pilar {
  background: var(--qma-bg);
  border: 1px solid var(--qma-border);
  border-top: 3px solid var(--lm-purple);
  border-radius: 12px;
  padding: 1.5rem;
  transition: box-shadow 0.2s;
}
.lm-pilar:hover { box-shadow: 0 4px 16px rgba(104,51,202,0.1); }
.lm-pilar .qma-ico-wrap { margin-bottom: 1rem; }
.lm-pilar p { font-size: 0.85rem; color: var(--qma-body); margin-top: 0.25rem; }

/* ──────────────────────────────────────────────
   BANNER DESTACADO (fondo navy oscuro, full-width inside section)
   Pattern del Edwin AI banner — útil para callouts importantes.
   ────────────────────────────────────────────── */
.lm-edwin-banner {
  width: 100%;
  overflow: hidden;
  border-radius: 16px;
  margin-bottom: 3rem;
  position: relative;
  background: var(--lm-brand-dark);
  padding: 2rem 2rem 0;
}
.lm-edwin-banner img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 8px 8px 0 0;
}
.lm-edwin-caption {
  padding: 1.25rem 0 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.lm-edwin-caption-text h3 {
  color: #fff;
  font-size: 1.05rem;
  margin: 0;
  line-height: 1.35;
}
.lm-edwin-caption-text p {
  color: rgba(255,255,255,0.68);
  font-size: 0.82rem;
  margin: 0.2rem 0 0;
  line-height: 1.55;
}
.lm-edwin-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: rgba(104,51,202,0.85);
  border: 1px solid rgba(176,132,245,0.4);
  border-radius: 40px;
  padding: 0.35rem 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fff;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ──────────────────────────────────────────────
   DIFERENCIADORES — grid 2x2 con icono lateral
   Bueno para "qué nos hace distintos", USPs, ventajas.
   ────────────────────────────────────────────── */
.lm-dif-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.25rem;
}
.lm-dif {
  display: flex;
  gap: 1.1rem;
  align-items: flex-start;
  padding: 1.4rem;
  border: 1px solid var(--qma-border);
  border-radius: 12px;
  background: var(--qma-bg);
}
.lm-dif-body h3 { margin-bottom: 0.3rem; }
.lm-dif-body p  { font-size: 0.85rem; color: var(--qma-body); line-height: 1.65; }

/* ──────────────────────────────────────────────
   CASOS DE USO — grid 3 cols
   Útil para sectores impactados, casos por vertical, ejemplos.
   ────────────────────────────────────────────── */
.lm-casos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.lm-caso {
  background: var(--qma-bg);
  border: 1px solid var(--qma-border);
  border-radius: 12px;
  padding: 1.4rem;
}
.lm-caso-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
}
.lm-caso-tag {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--lm-purple);
}
.lm-caso p { font-size: 0.85rem; color: var(--qma-body); line-height: 1.65; margin-top: 0.3rem; }

/* ──────────────────────────────────────────────
   PROPUESTA DE VALOR (grid 2 cols: items + certificaciones)
   ────────────────────────────────────────────── */
.lm-value-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3.5rem;
  align-items: start;
}
.lm-value-items {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  margin-top: 1.25rem;
}
.lm-value-item {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.lm-value-item h3 { margin-bottom: 0.25rem; }
.lm-value-item p  { font-size: 0.87rem; color: var(--qma-body); }

.lm-cert-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.85rem;
  margin-top: 1.25rem;
}
.lm-cert {
  border: 1px solid var(--qma-border);
  border-radius: 10px;
  padding: 0.85rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--qma-bg);
}
.lm-cert .cv {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--qma-navy);
  white-space: nowrap;
}
.lm-cert .cl {
  font-size: 0.72rem;
  color: var(--qma-body);
  line-height: 1.35;
}
.lm-stack-note {
  margin-top: 1.5rem;
  padding: 1.1rem 1.25rem;
  background: var(--lm-purple-soft);
  border: 1px solid rgba(104,51,202,0.2);
  border-radius: 8px;
  font-size: 0.87rem;
  color: var(--qma-slate);
  line-height: 1.7;
}

/* ──────────────────────────────────────────────
   FAQ — accordion limpio con +/- en lugar de iconos
   ────────────────────────────────────────────── */
.lm-faq-wrap {
  max-width: 780px;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.lm-faq-wrap details {
  background: var(--qma-bg);
  border: 1px solid var(--qma-border);
  border-radius: 10px;
  overflow: hidden;
}
.lm-faq-wrap details[open] { border-color: rgba(104,51,202,0.35); }
.lm-faq-wrap summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  font-size: 0.93rem;
  font-weight: 600;
  color: var(--qma-navy);
  user-select: none;
}
.lm-faq-wrap summary::-webkit-details-marker { display: none; }
.lm-faq-summary-inner {
  display: flex;
  align-items: center;
}
.lm-faq-wrap summary .faq-arrow {
  font-size: 1.4rem;
  font-weight: 300;
  color: var(--lm-purple);
  flex-shrink: 0;
  width: 20px;
  text-align: center;
  line-height: 1;
}
.lm-faq-wrap summary .faq-arrow::before { content: '+'; }
.lm-faq-wrap details[open] summary .faq-arrow::before { content: '−'; }
.lm-faq-wrap details div {
  padding: 0 1.25rem 1.1rem;
  font-size: 0.875rem;
  color: var(--qma-body);
  line-height: 1.75;
}

/* ──────────────────────────────────────────────
   CTA FINAL — bloque navy con botón lime
   Patrón de cierre fuerte, alta conversión.
   ────────────────────────────────────────────── */
#lm-cta {
  background: var(--qma-navy);
  padding: 4.5rem 0;
}
#lm-cta h2 { color: #FFF; font-size: clamp(1.4rem, 2.5vw, 1.9rem); margin-bottom: 0.75rem; }
#lm-cta p  { color: rgba(255,255,255,0.72); margin-bottom: 2rem; max-width: 520px; margin-left: auto; margin-right: auto; }
#lm-cta .lm-cta-row { justify-content: center; }
.btn-lm-primary {
  display: inline-block;
  background: var(--qma-lime);
  color: #050F1C;
  font-weight: 700;
  font-size: 0.9rem;
  padding: 12px 20px;
  border-radius: 8px;
  text-decoration: none;
  transition: opacity 0.15s;
}
.btn-lm-primary:hover { opacity: 0.88; text-decoration: none; }
.btn-lm-outline {
  display: inline-block;
  border: 1px solid rgba(255,255,255,0.4);
  color: #FFF;
  font-weight: 600;
  font-size: 0.9rem;
  padding: 11px 20px;
  border-radius: 8px;
  text-decoration: none;
  transition: border-color 0.15s;
}
.btn-lm-outline:hover { border-color: rgba(255,255,255,0.75); text-decoration: none; }

/* ──────────────────────────────────────────────
   RESPONSIVE
   ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .lm-hero-grid, .lm-que-grid, .lm-value-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .lm-pilares-grid, .lm-casos-grid { grid-template-columns: 1fr 1fr; }
  .lm-dif-grid { grid-template-columns: 1fr; }
  .lm-edwin-banner { padding: 1.25rem 1.25rem 0; }
}
@media (max-width: 600px) {
  .lm-pilares-grid, .lm-casos-grid, .lm-stat-grid, .lm-cert-grid { grid-template-columns: 1fr; }
  .qma-mssp-wrap { padding-left: 16px; padding-right: 16px; }
  .lm-edwin-banner { padding: 1rem 1rem 0; }
  .lm-edwin-caption { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
}


/* ══════════════════════════════════════════════════════════════════════
   FASE 3D · EXTENSIÓN sat3 indicadores-apf · grids interactivos
   Origen: extraído del inline CSS de sat3-indicadores-apf-v2.html (Opus 2026-05-03)
   ══════════════════════════════════════════════════════════════════════ */

/* Grid controls — filters + pagination */
.pnc-controls { display:flex; flex-wrap:wrap; gap:0.75rem; align-items:center; padding:1rem 0; }
.pnc-filter { padding:0.5rem 1rem; border:1px solid var(--qma-border, rgba(0,0,0,0.12)); border-radius:6px; background:var(--qma-bg, #fff); color:var(--qma-body, #374151); font-size:0.85rem; cursor:pointer; min-width:140px; }
.pnc-filter:focus { outline:2px solid var(--lm-purple, #6833CA); }
.pnc-search { flex:1; min-width:200px; padding:0.5rem 1rem; border:1px solid var(--qma-border, rgba(0,0,0,0.12)); border-radius:6px; font-size:0.85rem; background:var(--qma-bg, #fff); color:var(--qma-body, #374151); }
.pnc-search::placeholder { color:#94a3b8; }

/* Card grid */
.pnc-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr)); gap:1rem; padding:1rem 0; }
@media(max-width:700px){ .pnc-grid { grid-template-columns:1fr; } }

/* Intel card */
.pnc-card { border:1px solid var(--qma-border, rgba(0,0,0,0.12)); border-radius:8px; padding:1.25rem; background:var(--qma-bg, #fff); transition:border-color 0.2s, box-shadow 0.2s; display:flex; flex-direction:column; gap:0.5rem; }
.pnc-card:hover { border-color:var(--lm-purple, #6833CA); box-shadow:0 2px 12px rgba(104,51,202,0.08); }
.pnc-card-header { display:flex; justify-content:space-between; align-items:flex-start; gap:0.75rem; }
.pnc-card-title { font-size:0.95rem; font-weight:700; color:var(--qma-navy, #084480); line-height:1.3; margin:0; }
.pnc-card-badge { display:inline-block; padding:0.2rem 0.6rem; border-radius:100px; font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; white-space:nowrap; flex-shrink:0; }
.pnc-badge--critical { background:#fde8e8; color:#b91c1c; }
.pnc-badge--high { background:#fef3c7; color:#92400e; }
.pnc-badge--medium { background:#e0e7ff; color:#3730a3; }
.pnc-badge--low { background:#f0fdf4; color:#166534; }
.pnc-badge--grave { background:#fde8e8; color:#b91c1c; }
.pnc-badge--normal { background:#f0f5fa; color:#374151; }
.pnc-card-body { font-size:0.85rem; color:var(--qma-body, #374151); line-height:1.55; flex:1; }
.pnc-card-meta { display:flex; flex-wrap:wrap; gap:0.5rem 1rem; font-size:0.78rem; color:#64748b; border-top:1px solid rgba(0,0,0,0.06); padding-top:0.6rem; margin-top:auto; }
.pnc-card-meta strong { color:var(--qma-navy, #084480); }

/* Pagination */
.pnc-pagination { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:0.75rem; padding:1rem 0; border-top:1px solid rgba(0,0,0,0.06); }
.pnc-page-info { font-size:0.82rem; color:#64748b; }
.pnc-page-btns { display:flex; gap:0.4rem; }
.pnc-page-btn { padding:0.4rem 0.8rem; border:1px solid var(--qma-border, rgba(0,0,0,0.12)); border-radius:6px; background:var(--qma-bg, #fff); color:var(--qma-body, #374151); font-size:0.82rem; cursor:pointer; transition:all 0.15s; }
.pnc-page-btn:hover { border-color:var(--lm-purple, #6833CA); color:var(--lm-purple, #6833CA); }
.pnc-page-btn.active { background:var(--lm-purple, #6833CA); color:#fff; border-color:var(--lm-purple, #6833CA); }
.pnc-page-btn:disabled { opacity:0.4; cursor:not-allowed; }
.pnc-per-page { display:flex; align-items:center; gap:0.5rem; font-size:0.82rem; color:#64748b; }

/* Stat summary row */
.pnc-stats-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(150px,1fr)); gap:0.75rem; padding:1rem 0; }
.pnc-stat-mini { text-align:center; padding:1rem; border:1px solid var(--qma-border, rgba(0,0,0,0.12)); border-top:3px solid var(--lm-purple, #6833CA); border-radius:8px; background:var(--qma-bg, #fff); }
.pnc-stat-mini .num { font-size:1.6rem; font-weight:800; color:var(--lm-purple, #6833CA); display:block; }
.pnc-stat-mini .label { font-size:0.75rem; color:#64748b; }

/* No results */
.pnc-empty { text-align:center; padding:3rem; color:#94a3b8; font-size:0.9rem; }


/* ══════════════════════════════════════════════════════════════════════
   FASE 3D · EXTENSIÓN sat1 calculadora-exposicion · sistema roi-*
   Origen: extraído del WPCode inline de qma.mx/mssp/calculadora-roi/
   Reusable: cualquier calculadora interactiva en pages PNC + descendientes
   ══════════════════════════════════════════════════════════════════════ */

/* ── ROI Calculator: estilos adicionales (no reemplaza el global) ─────────── */
/* Solo cubre lo que qma-global NO tiene: inputs, tabs, KPIs, meter */

/* Inputs / selects */
.roi-field { margin-bottom: 14px; }
.roi-field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 5px;
}
.roi-field input[type="number"],
.roi-field select {
  width: 100%;
  padding: 9px 12px;
  border: 1px solid rgba(0,0,0,.18);
  border-radius: 8px;
  font-size: 14px;
  font-family: inherit;
  background: #fff;
  box-sizing: border-box;
  appearance: none;
  -webkit-appearance: none;
}
.roi-field input[type="number"]:focus,
.roi-field select:focus {
  outline: none;
  border-color: #0b5cff;
  box-shadow: 0 0 0 3px rgba(11,92,255,.10);
}
.roi-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23666'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 32px;
  cursor: pointer;
}
.roi-field .roi-hint {
  font-size: 12px;
  color: rgba(0,0,0,.45);
  margin-top: 3px;
}

/* Step headers dentro del formulario */
.roi-step-hd {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 0 10px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  margin-bottom: 14px;
}
.roi-step-hd:not(:first-of-type) { margin-top: 18px; }
.roi-step-num {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: #0b5cff;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.roi-step-hd h3 {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin: 0;
}

/* Tabs resultados */
.roi-tabs {
  display: flex;
  border-bottom: 2px solid rgba(0,0,0,.10);
  margin-bottom: 24px;
  flex-wrap: wrap;
  gap: 0;
}
.roi-tab-btn {
  padding: 11px 18px;
  background: none;
  border: none;
  font-size: 13px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  color: rgba(0,0,0,.50);
  line-height: 1.3;
  text-align: left;
}
.roi-tab-btn .roi-tab-role {
  display: block;
  font-size: 10px;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 2px;
  color: rgba(0,0,0,.35);
}
.roi-tab-btn.active {
  color: #0b5cff;
  border-bottom-color: #0b5cff;
}
.roi-tab-content { display: none; }
.roi-tab-content.active { display: block; }

/* KPI números grandes */
.roi-kpi-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
  margin-bottom: 20px;
}
.roi-kpi {
  padding: 14px 16px;
  border-top: 3px solid rgba(0,0,0,.10);
}
.roi-kpi.accent   { border-top-color: #0b5cff; }
.roi-kpi.positive { border-top-color: #1aa362; }
.roi-kpi.warning  { border-top-color: #d97706; }
.roi-kpi.danger   { border-top-color: #dc2626; }
.roi-kpi-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(0,0,0,.45);
  margin-bottom: 6px;
}
.roi-kpi-val {
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.roi-kpi.positive .roi-kpi-val { color: #1aa362; }
.roi-kpi.warning  .roi-kpi-val { color: #d97706; }
.roi-kpi.danger   .roi-kpi-val { color: #dc2626; }
.roi-kpi.accent   .roi-kpi-val { color: #0b5cff; }
.roi-kpi-sub {
  font-size: 12px;
  color: rgba(0,0,0,.40);
  margin-top: 3px;
}

/* Barra ROSI */
.roi-meter { margin-bottom: 20px; }
.roi-meter-label {
  font-size: 12px;
  font-weight: 600;
  color: rgba(0,0,0,.55);
  margin-bottom: 8px;
}
.roi-meter-bg {
  height: 8px;
  background: rgba(0,0,0,.08);
  border-radius: 4px;
  overflow: hidden;
}
.roi-meter-fill {
  height: 100%;
  background: #0b5cff;
  border-radius: 4px;
  transition: width 1s cubic-bezier(.22,.68,0,1.2);
  width: 0%;
}
.roi-meter-scale {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: rgba(0,0,0,.35);
  margin-top: 4px;
  font-weight: 600;
}

/* Placeholder estado vacío */
.roi-placeholder {
  padding: 48px 20px;
  text-align: center;
  color: rgba(0,0,0,.40);
}
.roi-placeholder h2 { font-size: 18px; margin-bottom: 8px; }
.roi-placeholder p  { font-size: 14px; max-width: 280px; margin: 0 auto; }

/* Layout dos columnas (formulario + resultados) */
.roi-layout {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 24px;
  align-items: start;
}
@media (max-width: 860px) {
  .roi-layout { grid-template-columns: 1fr; }
  .roi-tab-btn { padding: 10px 12px; }
  .roi-kpi-row { grid-template-columns: repeat(2, 1fr); }
}

/* Fijar formulario en scroll */
@media (min-width: 860px) {
  .roi-form-col { position: sticky; top: 24px; }
}

/* Nota al pie de supuestos */
.roi-note {
  font-size: 12px;
  color: rgba(0,0,0,.40);
  margin-top: 10px;
  font-style: italic;
}

/* Print */
@media print {
  .roi-form-col, .roi-tabs { display: none !important; }
  .roi-tab-content { display: block !important; page-break-after: always; }
  .roi-placeholder { display: none !important; }
  .roi-layout { display: block; }
}

/*
 * QMA — Calculadora ROI Backup
 * WPCode → Nuevo snippet → tipo CSS → "Load everywhere" (se cargará solo en páginas con el widget)
 * Reemplaza el <style> que estaba en el HTML widget para evitar que wpautop lo rompa
 */

  

  :root {
    --navy-950: #050D1A;
    --navy-900: #0C1635;
    --navy-800: #0F2050;
    --navy-700: #163070;
    --navy-600: #1E4090;
    --blue-500: #2563EB;
    --blue-400: #60A5FA;
    --teal-500: #0D9488;
    --teal-400: #2DD4BF;
    --green-500: #D1DF48;
    --green-600: #AEBC21;
    --white: #FFFFFF;
    --slate-50: #F8FAFC;
    --slate-100: #F1F5F9;
    --slate-200: #E2E8F0;
    --slate-400: #94A3B8;
    --slate-600: #475569;
    --slate-700: #334155;
    --red-400: #F87171;
    --orange-400: #FB923C;
    --amber-400: #FBBF24;
  }

  .qma-roi-wrap *, .qma-roi-wrap *::before, .qma-roi-wrap *::after { box-sizing: border-box; margin: 0; padding: 0; }

  .qma-roi-wrap {
    font-family: 'Inter', sans-serif;
    background: var(--navy-950);
    color: var(--white);
    min-height: 100vh;
    line-height: 1.6;
  }

  /* ─── HEADER ─────────────────────────────────── */
  .calc-header {
    background: var(--navy-900);
    border-bottom: 1px solid rgba(255,255,255,0.07);
    padding: 1.5rem 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
    position: sticky;
    top: 0;
    z-index: 100;
  }

  .calc-brand {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .brand-logo {
    width: 36px;
    height: 36px;
    background: linear-gradient(135deg, var(--blue-500), var(--teal-500));
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.85rem;
    letter-spacing: 0.05em;
    color: white;
  }

  .brand-text {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--slate-200);
  }

  .brand-subtitle {
    font-size: 0.72rem;
    color: var(--slate-400);
    font-weight: 400;
  }

  /* ─── FX BADGE ────────────────────────────────── */
  .fx-badge {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    background: rgba(13, 148, 136, 0.12);
    border: 1px solid rgba(13, 148, 136, 0.3);
    border-radius: 8px;
    padding: 0.4rem 0.8rem;
    font-size: 0.78rem;
    color: var(--teal-400);
    font-family: 'DM Mono', monospace;
    transition: all 0.3s;
  }

  .fx-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--teal-400);
    animation: pulse 2s infinite;
  }

  @keyframes pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
  }

  .fx-source {
    font-size: 0.68rem;
    color: var(--slate-400);
    font-family: 'Inter', sans-serif;
  }

  /* ─── HERO ────────────────────────────────────── */
  .calc-hero {
    padding: 3rem 2rem 2rem;
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
  }

  .hero-tag {
    display: inline-block;
    background: rgba(209, 223, 72, 0.12);
    border: 1px solid rgba(209, 223, 72, 0.3);
    color: var(--green-500);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 0.3rem 0.8rem;
    border-radius: 100px;
    margin-bottom: 1.25rem;
  }

  .hero-title {
    font-size: clamp(1.75rem, 4vw, 2.75rem);
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 1rem;
    color: var(--white);
  }

  .hero-title span {
    background: linear-gradient(90deg, var(--teal-400), var(--blue-400));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }

  .hero-sub {
    font-size: 1rem;
    color: var(--slate-400);
    max-width: 600px;
    margin: 0 auto 2rem;
  }

  /* ─── CURRENCY TOGGLE ────────────────────────── */
  .currency-toggle {
    display: inline-flex;
    background: var(--navy-900);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 10px;
    padding: 4px;
    gap: 2px;
    margin-bottom: 2rem;
  }

  .currency-btn {
    padding: 0.5rem 1.25rem;
    border-radius: 7px;
    border: none;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    background: transparent;
    color: var(--slate-400);
    font-family: 'Inter', sans-serif;
  }

  .currency-btn.active {
    background: var(--blue-500);
    color: white;
  }

  /* ─── MAIN LAYOUT ─────────────────────────────── */
  .calc-main {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 2rem 4rem;
    display: grid;
    grid-template-columns: 380px 1fr;
    gap: 2rem;
    align-items: start;
  }

  @media (max-width: 800px) {
    .calc-main { grid-template-columns: 1fr; }
  }

  /* ─── PANEL ───────────────────────────────────── */
  .panel {
    background: var(--navy-900);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 16px;
    overflow: hidden;
  }

  .panel-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    font-size: 0.8rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--slate-400);
  }

  .panel-body {
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  /* ─── FORM CONTROLS ──────────────────────────── */
  .field-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .field-label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--slate-200);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .field-value {
    font-family: 'DM Mono', monospace;
    font-size: 0.82rem;
    color: var(--teal-400);
    font-weight: 500;
  }

  input[type="range"] {
    -webkit-appearance: none;
    width: 100%;
    height: 4px;
    background: rgba(255,255,255,0.1);
    border-radius: 2px;
    outline: none;
  }

  input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--blue-500);
    cursor: pointer;
    border: 3px solid var(--navy-900);
    box-shadow: 0 0 0 2px var(--blue-500);
  }

  .seg-control {
    display: flex;
    background: rgba(255,255,255,0.05);
    border-radius: 8px;
    padding: 3px;
    gap: 2px;
  }

  .seg-btn {
    flex: 1;
    padding: 0.45rem 0.5rem;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: var(--slate-400);
    font-size: 0.78rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.18s;
    font-family: 'Inter', sans-serif;
    text-align: center;
  }

  .seg-btn.active {
    background: var(--navy-700);
    color: var(--white);
  }

  .checkbox-row {
    display: flex;
    align-items: center;
    gap: 0.6rem;
    cursor: pointer;
  }

  .checkbox-row input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--blue-500);
    cursor: pointer;
  }

  .checkbox-row span {
    font-size: 0.8rem;
    color: var(--slate-300);
  }

  .divider {
    height: 1px;
    background: rgba(255,255,255,0.06);
  }

  /* ─── ROL TOGGLE ──────────────────────────────── */
  .rol-toggle {
    display: flex;
    background: var(--navy-900);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 4px;
    gap: 3px;
    margin-bottom: 1.5rem;
  }

  .rol-btn {
    flex: 1;
    padding: 0.7rem 1rem;
    border-radius: 9px;
    border: none;
    font-size: 0.85rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s;
    background: transparent;
    color: var(--slate-400);
    font-family: 'Inter', sans-serif;
    text-align: center;
    line-height: 1.2;
  }

  .rol-btn small {
    display: block;
    font-size: 0.65rem;
    font-weight: 400;
    opacity: 0.7;
    margin-top: 1px;
  }

  .rol-btn.active-cio { background: rgba(37, 99, 235, 0.25); color: var(--blue-400); border: 1px solid rgba(37,99,235,0.4); }
  .rol-btn.active-cfo { background: rgba(13, 148, 136, 0.2); color: var(--teal-400); border: 1px solid rgba(13,148,136,0.4); }
  .rol-btn.active-ciso { background: rgba(209, 223, 72, 0.12); color: var(--green-500); border: 1px solid rgba(209,223,72,0.3); }

  /* ─── RESULTS ─────────────────────────────────── */
  .results-panel { display: none; flex-direction: column; gap: 1.25rem; }
  .results-panel.visible { display: flex; }

  .metric-card {
    background: var(--navy-900);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
    position: relative;
    overflow: hidden;
  }

  .metric-card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
  }

  .metric-card.cio::before { background: var(--blue-500); }
  .metric-card.cfo::before { background: var(--teal-500); }
  .metric-card.ciso::before { background: var(--green-500); }

  .metric-label {
    font-size: 0.73rem;
    color: var(--slate-400);
    text-transform: uppercase;
    letter-spacing: 0.07em;
    font-weight: 500;
    margin-bottom: 0.5rem;
  }

  .metric-value {
    font-size: clamp(1.5rem, 3vw, 2.1rem);
    font-weight: 700;
    font-family: 'DM Mono', monospace;
    line-height: 1.1;
    margin-bottom: 0.3rem;
  }

  .metric-value.positive { color: var(--teal-400); }
  .metric-value.warning { color: var(--amber-400); }
  .metric-value.danger { color: var(--red-400); }
  .metric-value.neutral { color: var(--blue-400); }

  .metric-sub {
    font-size: 0.78rem;
    color: var(--slate-400);
  }

  .metric-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }

  /* ─── COMPARISON BAR ──────────────────────────── */
  .compare-bar {
    background: var(--navy-900);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 12px;
    padding: 1.25rem 1.5rem;
  }

  .compare-title {
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: var(--slate-400);
    margin-bottom: 1rem;
  }

  .compare-row {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
  }

  .compare-label {
    width: 110px;
    font-size: 0.76rem;
    color: var(--slate-300);
    flex-shrink: 0;
  }

  .bar-track {
    flex: 1;
    height: 8px;
    background: rgba(255,255,255,0.07);
    border-radius: 4px;
    overflow: hidden;
  }

  .bar-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.6s ease;
  }

  .bar-fill.danger { background: linear-gradient(90deg, #EF4444, #F87171); }
  .bar-fill.good { background: linear-gradient(90deg, #0D9488, #2DD4BF); }

  .compare-val {
    font-family: 'DM Mono', monospace;
    font-size: 0.78rem;
    width: 60px;
    text-align: right;
    color: var(--slate-300);
  }

  /* ─── ROI TIMELINE ────────────────────────────── */
  .roi-timeline {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
  }

  .timeline-step {
    background: rgba(255,255,255,0.04);
    border-radius: 10px;
    padding: 1rem;
    text-align: center;
    border: 1px solid rgba(255,255,255,0.06);
  }

  .timeline-year {
    font-size: 0.68rem;
    color: var(--slate-400);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin-bottom: 0.4rem;
  }

  .timeline-val {
    font-family: 'DM Mono', monospace;
    font-size: 1rem;
    font-weight: 600;
    color: var(--teal-400);
  }

  .timeline-val.neg { color: var(--red-400); }

  /* ─── RISK MATRIX ─────────────────────────────── */
  .risk-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
  }

  .risk-tag {
    font-size: 0.72rem;
    padding: 0.25rem 0.6rem;
    border-radius: 6px;
    font-weight: 500;
  }

  .risk-tag.covered { background: rgba(13,148,136,0.2); color: var(--teal-400); border: 1px solid rgba(13,148,136,0.3); }
  .risk-tag.partial { background: rgba(251,191,36,0.15); color: var(--amber-400); border: 1px solid rgba(251,191,36,0.3); }
  .risk-tag.uncovered { background: rgba(239,68,68,0.15); color: var(--red-400); border: 1px solid rgba(239,68,68,0.3); }

  /* ─── CTA ─────────────────────────────────────── */
  .cta-block {
    background: linear-gradient(135deg, rgba(22,48,112,0.8), rgba(15,32,80,0.9));
    border: 1px solid rgba(37, 99, 235, 0.25);
    border-radius: 16px;
    padding: 2rem;
    text-align: center;
    margin-top: 0.5rem;
  }

  .cta-block h3 {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0.5rem;
    color: var(--white);
  }

  .cta-block p {
    font-size: 0.85rem;
    color: var(--slate-400);
    margin-bottom: 1.5rem;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }

  .cta-btn {
    display: inline-block;
    background: var(--green-500);
    color: var(--navy-950);
    font-weight: 700;
    font-size: 0.9rem;
    padding: 0.85rem 2rem;
    border-radius: 10px;
    text-decoration: none;
    transition: background 0.2s, transform 0.15s;
    border: none;
    cursor: pointer;
    font-family: 'Inter', sans-serif;
  }

  .cta-btn:hover { background: var(--green-600); transform: translateY(-1px); }

  /* ─── DISCLAIMER ──────────────────────────────── */
  .disclaimer {
    font-size: 0.7rem;
    color: var(--slate-600);
    text-align: center;
    max-width: 700px;
    margin: 2rem auto 0;
    line-height: 1.5;
    padding: 0 2rem;
  }

  /* ─── PARTNERS STRIP ──────────────────────────── */
  .partners-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    margin-top: 1.25rem;
    flex-wrap: wrap;
  }

  .partner-chip {
    font-size: 0.72rem;
    color: var(--slate-500);
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.07);
    padding: 0.25rem 0.6rem;
    border-radius: 6px;
  }

  .partner-label {
    font-size: 0.7rem;
    color: var(--slate-600);
  }

/* ─── FIX: Colores overrideados por Astra ──────── */
/* Checkbox labels */
.qma-roi-wrap .checkbox-row span {
  color: #CBD5E1 !important;
}
/* Disclaimer y partner-label */
.qma-roi-wrap .disclaimer {
  color: #64748B !important;
}
.qma-roi-wrap .partner-label {
  color: #64748B !important;
}
/* Links heredados */
.qma-roi-wrap a {
  color: inherit;
}


/* ══════════════════════════════════════════════════════════════════════
   CC fix 2026-05-03 — eliminar espacio entre menú principal y banner hero
   Causas: <header.entry-header> vacío + <p></p> huérfanos de wpautop +
   padding-top default del .ast-container.
   Carga solo en pages PNC (FASE 3D condicional), no afecta resto del site.
   ══════════════════════════════════════════════════════════════════════ */

#content.site-content {
  padding-top: 0 !important;
}
#content.site-content > .ast-container {
  padding-top: 0 !important;
}
.entry-header.ast-header-without-markup {
  display: none;
}
.entry-content > p:empty {
  display: none;
  margin: 0;
  padding: 0;
}
.entry-content {
  margin-top: 0 !important;
}
.qma-hero-plan-nacional {
  margin-top: 0 !important;
}

/* ══════════════════════════════════════════════════════════════════════
   HERO BANNER · canon rules (recovered 2026-05-05)
   Full-bleed wrapper escapando el container para banner edge-to-edge.
   Height fijo 400px desktop, responsive en breakpoints menores.
   Hub usa imagen default. Hermanas usan modifier --slug con cover full-width.
   ══════════════════════════════════════════════════════════════════════ */

.qma-hero-plan-nacional {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  background: linear-gradient(115deg, #060f1a 0%, #091828 20%, #0d2240 50%, #091828 80%, #060f1a 100%);
  display: flex;
  justify-content: center;
  overflow: hidden;
  line-height: 0;
}

/* Default (HUB): imagen 1240px centered, posición específica */
.qma-hero-plan-img {
  width: 1240px;
  max-width: 100%;
  height: 400px;
  background-image: url('https://qma.mx/wp-content/uploads/2026/02/plan-nacional-ciberseguridad-2025-2030-qma-zero-trust-banner-16x9-1.jpg');
  background-size: 1240px auto;
  background-position: left calc(50% + 20px);
  background-repeat: no-repeat;
}

/* Hermanas: full width con cover — respetan el mismo height */
.qma-hero-plan-img--regimen-sancionatorio,
.qma-hero-plan-img--obligaciones-y-controles,
.qma-hero-plan-img--indicadores-apf {
  width: 100%;
  max-width: 100%;
  height: 400px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* Responsive heights — uniformes para todas las pages PNC */
@media (max-width: 1240px) {
  .qma-hero-plan-img { width: 100%; height: 360px; background-size: cover; background-position: left calc(50% + 20px); }
  .qma-hero-plan-img--regimen-sancionatorio,
  .qma-hero-plan-img--obligaciones-y-controles,
  .qma-hero-plan-img--indicadores-apf { height: 360px; }
}
@media (max-width: 768px) {
  .qma-hero-plan-img,
  .qma-hero-plan-img--regimen-sancionatorio,
  .qma-hero-plan-img--obligaciones-y-controles,
  .qma-hero-plan-img--indicadores-apf { height: 260px; }
  .qma-hero-plan-img { background-position: 20% calc(50% + 10px); }
}
@media (max-width: 480px) {
  .qma-hero-plan-img,
  .qma-hero-plan-img--regimen-sancionatorio,
  .qma-hero-plan-img--obligaciones-y-controles,
  .qma-hero-plan-img--indicadores-apf { height: 180px; }
  .qma-hero-plan-img { background-position: 15% center; }
}

/* Sat banner modifiers (URL pointers) */
.qma-hero-plan-img--regimen-sancionatorio {
  background-image: url('https://qma.mx/wp-content/uploads/2026/05/regimen-sancionatorio-ciberseguridad-mexico-cnbv-2026.jpg');
}
.qma-hero-plan-img--obligaciones-y-controles {
  background-image: url('https://qma.mx/wp-content/uploads/2026/05/obligaciones-controles-ciberseguridad-apf-mexico-2026.jpg');
}
.qma-hero-plan-img--indicadores-apf {
  background-image: url('https://qma.mx/wp-content/uploads/2026/05/indicadores-apf-ciberseguridad-mexico-dashboard-2026.jpg');
}



/* ══════════════════════════════════════════════════════════════════════
   FASE 3D · sat3 form Brevo · light theme matching lm-*
   Origen: Opus form embed adaptado a paleta PNC (en lugar de dark green).
   ══════════════════════════════════════════════════════════════════════ */

.pnc-form-alertas {
  background: var(--qma-bg);
  border: 1px solid var(--qma-border);
  border-left: 3px solid var(--lm-purple);
  border-radius: 10px;
  padding: 1.5rem 1.75rem;
  max-width: 760px;
  margin: 0 auto;
}
.pnc-form-alertas h3 {
  font-size: 1.05rem;
  color: var(--qma-navy);
  font-weight: 700;
}
.pnc-form-header { margin-bottom: 1.1rem; }
.pnc-form-row {
  display: flex;
  gap: 0.75rem;
  align-items: flex-end;
  flex-wrap: wrap;
}
.pnc-field { display: flex; flex-direction: column; gap: 0.3rem; }
.pnc-field-email  { flex: 2; min-width: 220px; }
.pnc-field-nombre { flex: 1.2; min-width: 150px; }
.pnc-field-btn    { flex: 0 0 auto; }
.pnc-field label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--qma-navy);
  letter-spacing: 0.02em;
}
.pnc-input {
  background: #fff;
  border: 1px solid var(--qma-border);
  border-radius: 6px;
  padding: 0.55rem 0.75rem;
  color: var(--qma-slate);
  font-size: 0.9rem;
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
  width: 100%;
  box-sizing: border-box;
}
.pnc-input::placeholder { color: #94a3b8; }
.pnc-input:focus {
  outline: none;
  border-color: var(--lm-purple);
  box-shadow: 0 0 0 3px rgba(104,51,202,0.12);
}
.pnc-input.pnc-error { border-color: #dc2626; }
.pnc-form-alertas .btn-lm-primary {
  background: var(--lm-purple);
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 0.6rem 1.4rem;
  font-size: 0.88rem;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, transform 0.1s;
}
.pnc-form-alertas .btn-lm-primary:hover { background: #4a1f9a; }
.pnc-form-alertas .btn-lm-primary:active { transform: scale(0.97); }
.pnc-form-alertas .btn-lm-primary:disabled { opacity: 0.6; cursor: not-allowed; }
.pnc-form-message {
  margin-top: 0.85rem;
  padding: 0.6rem 0.85rem;
  border-radius: 6px;
  font-size: 0.85rem;
  line-height: 1.45;
}
.pnc-form-message.pnc-success {
  background: #f0fdf4;
  border: 1px solid #86efac;
  color: #166534;
}
.pnc-form-message.pnc-error-msg {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #b91c1c;
}
.pnc-form-disclaimer {
  margin: 1rem 0 0 0;
  font-size: 0.72rem;
  color: #64748b;
  line-height: 1.55;
}
.pnc-form-disclaimer a {
  color: var(--lm-purple);
  text-decoration: underline;
}
@media (max-width: 600px) {
  .pnc-form-alertas { padding: 1.25rem; }
  .pnc-form-row { flex-direction: column; }
  .pnc-field-btn { width: 100%; }
  .pnc-form-alertas .btn-lm-primary { width: 100%; }
}


/* ══════════════════════════════════════════════════════════════════════
   FAMILY NAV · navegación entre hub + 3 satélites PNC
   Inyectado automático vía mu-plugin qma-pnc-helpers.php (filter the_content).
   Aparece antes del contenido principal, debajo del header del site.
   ══════════════════════════════════════════════════════════════════════ */

.lm-family-nav {
  background: var(--lm-purple-soft);
  border-bottom: 1px solid rgba(104,51,202,0.18);
  padding: 0.85rem 0;
  margin: 0 0 1.5rem 0;
}
.lm-family-nav .qma-mssp-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
}
.lm-family-nav-links {
  display: flex;
  gap: 0.4rem;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
  justify-content: center;
}
.lm-family-nav-links a {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--qma-navy);
  text-decoration: none;
  padding: 0.4rem 0.85rem;
  border-radius: 6px;
  transition: all 0.15s;
  border: 1px solid transparent;
  display: inline-block;
}
.lm-family-nav-links a:hover {
  background: #fff;
  border-color: rgba(104,51,202,0.25);
  color: var(--lm-purple);
}
.lm-family-nav-links a.active {
  background: var(--lm-purple);
  color: #fff;
  border-color: var(--lm-purple);
  cursor: default;
}
.lm-family-nav-links a.active:hover {
  background: var(--lm-purple);
  color: #fff;
}
@media (max-width: 600px) {
  .lm-family-nav { padding: 0.7rem 0; }
  .lm-family-nav .qma-mssp-wrap { gap: 0.5rem; }
  .lm-family-nav-label { font-size: 0.7rem; }
  .lm-family-nav-links a { font-size: 0.8rem; padding: 0.35rem 0.7rem; }
}


/* ──────────────────────────────────────────────
   PNC CARD links a posts ZDU (sat3 amenazas grid)
   ────────────────────────────────────────────── */
.pnc-card-link {
  text-decoration: none;
  color: inherit;
  display: block;
}
.pnc-card-link:hover .pnc-card-title {
  color: var(--lm-purple);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.pnc-card-cta {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--lm-purple);
  text-decoration: none;
  margin-left: auto;
  padding: 0.2rem 0;
  white-space: nowrap;
  transition: color 0.15s;
}
.pnc-card-cta:hover { color: var(--qma-navy); text-decoration: underline; }
.pnc-card-cta-disabled {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 600;
  color: #94a3b8;
  margin-left: auto;
  white-space: nowrap;
  font-style: italic;
}
.pnc-card--unpublished {
  opacity: 0.78;
  background: #fafbfc;
}
.pnc-card-title--unpublished { color: #64748b; }


/* ──────────────────────────────────────────────
   LM-PILARES-GRID modifier · 4 columnas
   Para grids densos tipo "8 ejes 4x2" o "4 macro 4x1".
   Mantiene el border-top morado del .lm-pilar canon.
   ────────────────────────────────────────────── */
.lm-pilares-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1100px) {
  .lm-pilares-grid--4col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .lm-pilares-grid--4col { grid-template-columns: 1fr; }
}


/* ──────────────────────────────────────────────
   LM-PILARES-GRID modifier · 5 columnas (audiencias)
   ────────────────────────────────────────────── */
.lm-pilares-grid--5col {
  grid-template-columns: repeat(5, 1fr);
  gap: 1rem;
}
@media (max-width: 1200px) {
  .lm-pilares-grid--5col { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  .lm-pilares-grid--5col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .lm-pilares-grid--5col { grid-template-columns: 1fr; }
}


/* ──────────────────────────────────────────────
   COUNTDOWN SECTION · solo HUB · ATDT 15 jun 2026
   Wrapper destacado para que el timer no quede flotando entre chips y contenido.
   ────────────────────────────────────────────── */
.qma-countdown-section {
  background: var(--lm-purple-soft);
  border-top: 1px solid rgba(104,51,202,0.2);
  border-bottom: 1px solid rgba(104,51,202,0.2);
  padding: 1.5rem 0;
  margin: 1.5rem 0 2rem;
  text-align: center;
}
.qma-countdown-section-label {
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--lm-purple);
  margin: 0 0 0.85rem 0;
}
.qma-countdown-section .qma-countdown {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  flex-wrap: wrap;
  padding: 0;
}
.qma-countdown-section .qma-countdown-num {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--qma-navy);
  line-height: 1;
  margin-bottom: 0.4rem;
}
.qma-countdown-section .qma-countdown-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--qma-body);
}
@media (max-width: 600px) {
  .qma-countdown-section .qma-countdown { gap: 0.85rem; }
  .qma-countdown-section .qma-countdown-num { font-size: 1.8rem; }
}



