.pqm-section,
.pqm-section * { box-sizing: border-box; }

.pqm-section {
  --pqm-bg: #F4F6F9;
  --pqm-soft-bg: #F4F6F9;
  --pqm-navy: #0A1F44;
  --pqm-blue-secondary: #123D8D;
  --pqm-blue-glow: #1E63FF;
  --pqm-blue-light: #4D8DFF;
  --pqm-red: #C4121A;
  --pqm-red-bright: #E32028;
  --pqm-red-dark: #8F0F14;
  --pqm-line: #D9DEE8;
  --pqm-muted: #7A8599;
  --pqm-card-bg: #FFFFFF;
  --pqm-btn-1: #2D66F6;
  --pqm-btn-2: #143A86;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding: 64px 24px 72px;
  background: linear-gradient(180deg, var(--pqm-bg) 0%, color-mix(in srgb, var(--pqm-bg) 88%, #FFFFFF 12%) 100%);
  color: var(--pqm-navy);
  font-family: inherit;
}

.pqm-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
}

.pqm-layer { position: absolute; pointer-events: none; z-index: 0; }

.pqm-dots { width: 210px; height: 210px; opacity: .72; background-image: radial-gradient(circle, color-mix(in srgb, var(--pqm-blue-light) 22%, transparent) 1.4px, transparent 1.8px); background-size: 18px 18px; }
.pqm-dots--left { left: 16px; bottom: 34px; }
.pqm-dots--right { right: 24px; top: 18px; }

.pqm-curve::before,
.pqm-curve::after { content: ""; position: absolute; border-radius: 50%; border: 1px solid color-mix(in srgb, var(--pqm-line) 82%, transparent); }
.pqm-curve--left { left: 0; top: 0; width: 1px; height: 1px; }
.pqm-curve--left::before { width: 920px; height: 920px; left: -805px; top: -44px; }
.pqm-curve--left::after { width: 610px; height: 610px; left: -540px; top: 300px; }
.pqm-curve--right { right: 0; bottom: 0; width: 1px; height: 1px; }
.pqm-curve--right::before { width: 750px; height: 750px; right: -630px; bottom: -170px; }
.pqm-curve--right::after { width: 530px; height: 530px; right: -430px; bottom: 18px; }

.pqm-top-symbol { display: flex; flex-direction: column; align-items: center; gap: 18px; margin: 0 0 22px; }
.pqm-diamond { width: 34px; height: 34px; transform: rotate(45deg); border-radius: 5px; background: linear-gradient(135deg, #FFE27A 0%, #F1B622 42%, #D98B00 100%); box-shadow: 0 10px 24px rgba(217,139,0,.22), inset 0 1px 0 rgba(255,255,255,.65); position: relative; }
.pqm-diamond::before { content: ""; position: absolute; inset: 7px; border-top: 1px solid rgba(255,255,255,.66); border-left: 1px solid rgba(255,255,255,.66); }
.pqm-ornament { display: flex; align-items: center; justify-content: center; gap: 12px; }
.pqm-ornament i { display: block; width: 86px; height: 2px; border-radius: 999px; background: linear-gradient(90deg, var(--pqm-red-bright), var(--pqm-red)); }
.pqm-ornament b { display: block; width: 12px; height: 12px; border-radius: 50%; background: var(--pqm-red-bright); box-shadow: 0 0 0 8px rgba(227,32,40,.08); }

.pqm-header { max-width: 1040px; margin: 0 auto 38px; text-align: center; }
.pqm-title { margin: 0; font-size: clamp(42px, 6.1vw, 86px); line-height: .98; letter-spacing: -.045em; font-weight: 900; color: var(--pqm-navy); text-wrap: balance; }
.pqm-title-prefix { color: var(--pqm-blue-glow); margin-right: .15em; }
.pqm-title-red { display: inline; color: var(--pqm-red-bright); margin-right: .12em; }
.pqm-title-blue { display: inline; color: var(--pqm-navy); }
.pqm-subtitle { margin: 22px auto 0; max-width: 860px; color: var(--pqm-muted); font-size: clamp(18px, 2vw, 24px); line-height: 1.45; font-weight: 400; }

.pqm-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr)); gap: 28px; align-items: stretch; }
.pqm-card { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: flex-start; min-height: 330px; padding: 38px 30px 32px; text-align: center; background: linear-gradient(180deg, var(--pqm-card-bg) 0%, color-mix(in srgb, var(--pqm-card-bg) 94%, var(--pqm-soft-bg) 6%) 100%); border: 1px solid var(--pqm-line); border-radius: 24px; box-shadow: 0 18px 40px rgba(10,31,68,.08), 0 2px 8px rgba(10,31,68,.04); transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; overflow: hidden; }
.pqm-card::before { content: ""; position: absolute; inset: 0; border-radius: inherit; background: radial-gradient(circle at 50% 0%, rgba(77,141,255,.10), transparent 35%); opacity: 0; transition: opacity .35s ease; }
.pqm-card:hover { transform: translateY(-8px); border-color: color-mix(in srgb, var(--pqm-blue-light) 40%, var(--pqm-line) 60%); box-shadow: 0 26px 54px rgba(10,31,68,.13), 0 8px 18px rgba(10,31,68,.06); }
.pqm-card:hover::before { opacity: 1; }

.pqm-icon-ring { position: relative; display: grid; place-items: center; width: 114px; height: 114px; margin-bottom: 24px; border-radius: 50%; background: linear-gradient(180deg, #FFFFFF 0%, #FBFCFE 100%); border: 1px solid var(--pqm-line); box-shadow: inset 0 1px 0 rgba(255,255,255,.95), 0 10px 18px rgba(10,31,68,.05); }
.pqm-icon-orbit { position: absolute; inset: -2px; border-radius: 50%; border-top: 3px solid var(--pqm-red-bright); border-right: 3px solid transparent; border-bottom: 3px solid transparent; border-left: 3px solid transparent; transform: rotate(15deg); }
.pqm-no-icon-orbit .pqm-icon-orbit { display: none; }
.pqm-card-icon { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; color: var(--pqm-blue-glow); font-size: 44px; line-height: 1; }
.pqm-card-icon svg { width: 48px; height: 48px; fill: currentColor; }
.pqm-card-icon i { line-height: 1; }

.pqm-card-title { position: relative; z-index: 1; margin: 0; color: var(--pqm-navy); font-size: clamp(23px, 2vw, 30px); line-height: 1.1; font-weight: 800; text-wrap: balance; }
.pqm-card-divider { position: relative; z-index: 1; display: block; width: 42px; height: 4px; margin: 20px 0 18px; border-radius: 999px; background: linear-gradient(90deg, var(--pqm-red-bright), var(--pqm-red)); box-shadow: 0 8px 16px rgba(196,18,26,.14); }
.pqm-no-card-dividers .pqm-card-divider { display: none; }
.pqm-card-text { position: relative; z-index: 1; margin: 0; color: var(--pqm-muted); font-size: 16px; line-height: 1.58; font-weight: 400; overflow-wrap: anywhere; }

.pqm-cta-wrap { display: flex; justify-content: center; margin-top: 34px; }
.pqm-cta { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 14px; min-width: min(100%, 600px); min-height: 76px; padding: 18px 34px; border-radius: 14px; overflow: hidden; text-decoration: none !important; color: #fff; background: linear-gradient(90deg, var(--pqm-btn-1) 0%, #2458d8 44%, var(--pqm-btn-2) 100%); border: 1px solid rgba(255,255,255,.08); box-shadow: inset 0 1px 0 rgba(255,255,255,.10), 0 14px 28px rgba(20,58,134,.22); font-size: clamp(20px, 1.9vw, 28px); line-height: 1.1; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; transition: transform .35s ease, box-shadow .35s ease, filter .35s ease; }
.pqm-cta::before { content: ""; position: absolute; left: 50%; bottom: -18px; width: 42%; height: 30px; transform: translateX(-50%); background: radial-gradient(ellipse at center, rgba(255,255,255,.58) 0%, rgba(255,255,255,.20) 34%, rgba(255,255,255,0) 72%); filter: blur(8px); opacity: .92; pointer-events: none; }
.pqm-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(255,255,255,.12) 0%, rgba(255,255,255,0) 42%, rgba(0,0,0,.12) 100%); pointer-events: none; }
.pqm-cta:hover { transform: translateY(-2px); color: #fff; filter: saturate(1.03); box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 18px 32px rgba(20,58,134,.28); }
.pqm-cta-icon { position: relative; z-index: 1; font-size: 1.15em; line-height: 1; }
.pqm-cta-text { position: relative; z-index: 1; }

.pqm-animated .pqm-reveal { opacity: 0; transform: translateY(26px); }
.pqm-animated .pqm-reveal.is-visible { opacity: 1; transform: translateY(0); transition: opacity .72s ease, transform .72s ease; transition-delay: var(--pqm-delay, 0ms); }
.pqm-animated .pqm-diamond { animation: pqmFloat 5.5s ease-in-out infinite; }
.pqm-animated .pqm-icon-ring { animation: pqmBreath 4.4s ease-in-out infinite; }
.pqm-animated .pqm-card:nth-child(2) .pqm-icon-ring { animation-delay: .35s; }
.pqm-animated .pqm-card:nth-child(3) .pqm-icon-ring { animation-delay: .7s; }
.pqm-animated .pqm-card:nth-child(4) .pqm-icon-ring { animation-delay: 1.05s; }
.pqm-animated .pqm-icon-orbit { animation: pqmOrbit 6.5s linear infinite; }

@keyframes pqmFloat { 0%,100% { transform: rotate(45deg) translate(0,0); } 50% { transform: rotate(45deg) translate(-5px,-5px); } }
@keyframes pqmBreath { 0%,100% { transform: translateY(0) scale(1); box-shadow: inset 0 1px 0 rgba(255,255,255,.95), 0 10px 18px rgba(10,31,68,.05); } 50% { transform: translateY(-2px) scale(1.03); box-shadow: inset 0 1px 0 rgba(255,255,255,.95), 0 14px 24px rgba(30,99,255,.13); } }
@keyframes pqmOrbit { from { transform: rotate(15deg); } to { transform: rotate(375deg); } }
@keyframes pqmSheen { from { transform: translateX(-140%); } to { transform: translateX(140%); } }

@media (max-width: 1199px) {
  .pqm-section { padding: 56px 22px 64px; }
  .pqm-cards { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; }
  .pqm-title { font-size: clamp(40px, 7.6vw, 72px); }
}

@media (max-width: 767px) {
  .pqm-section { padding: 44px 18px 54px; }
  .pqm-dots { width: 128px; height: 128px; background-size: 15px 15px; }
  .pqm-dots--right { right: 4px; top: 10px; }
  .pqm-dots--left { left: 8px; bottom: 12px; }
  .pqm-top-symbol { gap: 14px; margin-bottom: 20px; }
  .pqm-ornament i { width: 62px; }
  .pqm-header { margin-bottom: 28px; }
  .pqm-title { font-size: clamp(34px, 12vw, 46px); line-height: 1.02; letter-spacing: -.035em; }
  .pqm-subtitle { margin-top: 18px; font-size: 17px; }
  .pqm-cards { grid-template-columns: 1fr; gap: 18px; }
  .pqm-card { min-height: 260px; padding: 30px 22px 26px; border-radius: 20px; }
  .pqm-icon-ring { width: 96px; height: 96px; margin-bottom: 18px; }
  .pqm-card-icon { width: 44px; height: 44px; font-size: 38px; }
  .pqm-card-icon svg { width: 40px; height: 40px; }
  .pqm-card-title { font-size: 23px; }
  .pqm-card-text { font-size: 15px; line-height: 1.55; }
  .pqm-cta-wrap { margin-top: 26px; }
  .pqm-cta { width: 100%; min-width: 0; min-height: 70px; padding: 14px 18px; border-radius: 18px; gap: 12px; font-size: 18px; }
}


/* v1.1.3 - Botón azul premium forzado tipo referencia.
   Se fuerza para evitar que colores guardados en Elementor mantengan el degradado anterior. */
.pqm-section .pqm-cta-wrap {
  display: flex !important;
  justify-content: center !important;
  margin-top: 34px !important;
}

.pqm-section .pqm-cta {
  width: auto !important;
  min-width: 264px !important;
  max-width: 100% !important;
  min-height: 76px !important;
  padding: 0 42px !important;
  gap: 0 !important;
  border: 0 !important;
  border-radius: 10px !important;
  overflow: hidden !important;
  color: #FFFFFF !important;
  background: linear-gradient(90deg, #2D66F6 0%, #2458D8 48%, #143A86 100%) !important;
  box-shadow:
    0 16px 28px rgba(20, 58, 134, .20),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
  text-decoration: none !important;
  text-transform: uppercase !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  transform: none !important;
  filter: none !important;
  transition: transform .28s ease, box-shadow .28s ease, filter .28s ease !important;
}

.pqm-section .pqm-cta::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  right: auto !important;
  top: auto !important;
  bottom: -18px !important;
  width: 46% !important;
  height: 34px !important;
  transform: translateX(-50%) !important;
  background: radial-gradient(ellipse at center, rgba(255,255,255,.60) 0%, rgba(255,255,255,.24) 34%, rgba(255,255,255,0) 74%) !important;
  filter: blur(8px) !important;
  opacity: .95 !important;
  pointer-events: none !important;
}

.pqm-section .pqm-cta::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 44%, rgba(0,0,0,.10) 100%) !important;
  transform: none !important;
  pointer-events: none !important;
}

.pqm-section .pqm-cta:hover {
  transform: translateY(-2px) !important;
  color: #FFFFFF !important;
  filter: saturate(1.04) !important;
  box-shadow:
    0 20px 34px rgba(20, 58, 134, .26),
    inset 0 1px 0 rgba(255,255,255,.14) !important;
}

.pqm-section .pqm-cta:hover::after {
  animation: none !important;
}

.pqm-section .pqm-cta-icon {
  display: none !important;
}

.pqm-section .pqm-cta-text {
  position: relative !important;
  z-index: 2 !important;
  color: #FFFFFF !important;
  white-space: nowrap !important;
}

@media (max-width: 767px) {
  .pqm-section .pqm-cta {
    min-width: 264px !important;
    min-height: 70px !important;
    padding: 0 28px !important;
    border-radius: 10px !important;
    font-size: 16px !important;
    letter-spacing: .14em !important;
  }
}

@media (max-width: 360px) {
  .pqm-section .pqm-cta {
    width: 100% !important;
    min-width: 0 !important;
  }
}
