:root {
  --epqa-azul-profundo: #0D1B60;
  --epqa-cian: #00B8D9;
  --epqa-morado: #7B61FF;
  --epqa-dorado: #FFC107;
  --epqa-verde: #2E7D32;
  --epqa-blanco: #FFFFFF;
  --epqa-gris-claro: #F1F3F6;
  --epqa-texto: #263238;
  --epqa-radio: 22px;
  --epqa-sombra-suave: 0 16px 40px rgba(13, 27, 96, .14);
}

.epqa-logo-img { display:block; max-width:100%; height:auto; }
.epqa-card {
  border-radius: var(--epqa-radio);
  background: var(--epqa-blanco);
  box-shadow: var(--epqa-sombra-suave);
  border: 1px solid rgba(13,27,96,.08);
}
.epqa-card.dark { background: linear-gradient(135deg, #071433, #0D1B60); color: #fff; }
.epqa-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .65rem;
  border: 0; border-radius: 999px; padding: .85rem 1.35rem;
  font-weight: 700; cursor: pointer; text-decoration: none;
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.epqa-btn:hover { transform: translateY(-1px); filter: brightness(1.04); }
.epqa-btn.primary { color:#fff; background: linear-gradient(135deg, var(--epqa-cian), #097BE8); box-shadow: 0 10px 24px rgba(0,184,217,.25); }
.epqa-btn.dark { color:#fff; background: linear-gradient(135deg, #0D1B60, #06102E); box-shadow: 0 10px 24px rgba(13,27,96,.28); }
.epqa-btn.secondary { color: var(--epqa-azul-profundo); background:#fff; border:1px solid rgba(13,27,96,.12); }
.epqa-navbar {
  border-radius: 28px; padding: .75rem 1rem; display:flex; align-items:center; gap:1rem;
  background:#fff; box-shadow: var(--epqa-sombra-suave);
}
.epqa-navbar.dark { background: linear-gradient(135deg, #06102E, #0D1B60); color:#fff; }

.epqa-logo {
  display: block;
  max-height: 48px;
  width: auto;
}

.epqa-brand-link {
  align-items: center;
  display: inline-flex !important;
  min-width: 0 !important;
}

.epqa-brand-link::after {
  content: none !important;
}

.epqa-brand-link .epqa-logo {
  flex: 0 0 auto;
  object-fit: contain;
}

.epqa-nav-icon {
  display: inline-block;
  height: 28px;
  object-fit: contain;
  vertical-align: middle;
  width: 28px;
}

.epqa-card-icon {
  height: 72px;
  object-fit: contain;
  width: 72px;
}

.epqa-hero-icon {
  height: 96px;
  object-fit: contain;
  width: 96px;
}

.epqa-media {
  border-radius: 28px;
  display: block;
  height: auto;
  max-width: 100%;
}

.epqa-picture {
  display: block;
  width: 100%;
}

.epqa-brand-shadow {
  box-shadow: 0 14px 30px rgba(13, 27, 96, 0.16);
}

.epqa-soft-card {
  background: #ffffff;
  border-radius: 24px;
  box-shadow: 0 12px 28px rgba(13, 27, 96, 0.12);
}

.epqa-dark-card {
  background: #0D1B60;
  border-radius: 24px;
  box-shadow: 0 12px 28px rgba(13, 27, 96, 0.22);
  color: #ffffff;
}

.epqa-hero-media {
  margin: 0 auto 18px;
  max-width: min(100%, 960px);
}

.epqa-inline-brand {
  align-items: center;
  display: flex;
  gap: 14px;
}

.epqa-inline-brand .epqa-logo {
  max-height: 58px;
}

.epqa-visual-mark {
  align-items: center;
  display: grid;
  gap: 10px;
  justify-items: center;
  text-align: center;
}

.epqa-page-title,
.epqa-section-title {
  margin: 1.25rem auto 1rem !important;
  text-align: center !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: clamp(2rem, 4vw, 3.2rem) !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  letter-spacing: -0.04em !important;
  color: #0D1B60 !important;
  text-transform: none !important;
  max-width: min(100%, 980px) !important;
}

.epqa-page-title span,
.epqa-section-title span,
.epqa-title-accent {
  color: #00B8D9;
}

.epqa-page-title::after,
.epqa-section-title::after {
  content: "";
  display: block;
  width: 92px;
  height: 5px;
  margin: 0.75rem auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #00B8D9, #7B61FF);
}

.epqa-page-subtitle {
  max-width: 760px !important;
  margin: 0.65rem auto 1.75rem !important;
  text-align: center !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: clamp(1rem, 2vw, 1.25rem) !important;
  font-weight: 600 !important;
  line-height: 1.45 !important;
  color: #465A69 !important;
}

.epqa-page-subtitle strong,
.epqa-page-subtitle span {
  color: #00B8D9;
  font-weight: 800;
}

.resources-paths .epqa-section-title {
  display: block;
  width: fit-content;
}

body.page-recursos .section-title .epqa-section-title span {
  color: #00B8D9 !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  letter-spacing: inherit !important;
  line-height: inherit !important;
  text-transform: none !important;
}

body.page-recursos .epqa-resource-visual {
  align-items: center !important;
  display: grid !important;
  gap: clamp(1rem, 3vw, 2rem) !important;
  grid-template-columns: minmax(280px, 0.48fr) minmax(0, 1fr) !important;
  padding: clamp(1rem, 2.5vw, 1.5rem) !important;
}

body.page-recursos .epqa-resource-visual .epqa-visual-mark {
  align-content: center;
  background: linear-gradient(180deg, rgba(248, 251, 255, 0.92), rgba(255, 255, 255, 0.72));
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 22px;
  min-height: 100%;
  padding: clamp(1rem, 2.2vw, 1.35rem);
}

body.page-recursos .epqa-resource-visual .epqa-page-title {
  margin-bottom: 0 !important;
  max-width: 100% !important;
  white-space: normal !important;
}

body.page-recursos .epqa-resource-visual .epqa-picture {
  min-width: 0;
}

body.page-recursos .epqa-resource-visual .epqa-media {
  aspect-ratio: 16 / 7;
  height: auto;
  object-fit: cover;
  width: 100%;
}

.epqa-footer-impact {
  display: grid;
  gap: 0.8rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 1rem;
}

.site-footer .footer-links a {
  background: linear-gradient(135deg, rgba(0, 184, 217, 0.14), rgba(65, 246, 185, 0.12));
  border: 1px solid rgba(0, 184, 217, 0.28);
  border-radius: 999px;
  color: #0D1B60 !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-weight: 900;
  min-height: 34px;
  padding: 0.42rem 0.78rem;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}

.site-footer .footer-links a:hover,
.site-footer .footer-links a:focus-visible {
  background: linear-gradient(135deg, #00B8D9, #41F6B9);
  border-color: rgba(0, 184, 217, 0.55);
  color: #06102E !important;
  transform: translateY(-1px);
}

body.page-home .stem-road {
  height: 104px !important;
  margin: 0 auto 1.25rem !important;
  max-width: min(100%, 1380px) !important;
  overflow: visible !important;
}

body.page-home .road-stop {
  top: 26px !important;
}

body.page-home .road-stop span {
  border-width: 4px !important;
  font-size: 18px !important;
  height: 42px !important;
  width: 42px !important;
}

body.page-home .road-stop small {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(0, 184, 217, 0.22);
  border-radius: 999px;
  color: #0D1B60 !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(0.88rem, 1.6vw, 1.08rem) !important;
  font-weight: 900 !important;
  line-height: 1.12 !important;
  padding: 0.38rem 0.7rem;
  white-space: nowrap;
}

body.page-home .road-sign {
  background: linear-gradient(135deg, #00B8D9, #7B61FF) !important;
  bottom: 2px !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  padding: 0.55rem 1rem !important;
}

body:is(.page-login, .page-registro) .auth-header {
  text-align: center;
}

body:is(.page-login, .page-registro) .auth-header .epqa-inline-brand {
  gap: clamp(0.8rem, 2.2vw, 1.2rem) !important;
  justify-content: center;
  margin-bottom: 1.2rem !important;
}

body:is(.page-login, .page-registro) .auth-header .epqa-inline-brand .epqa-logo {
  max-height: clamp(58px, 7vw, 84px) !important;
  width: auto !important;
}

body:is(.page-login, .page-registro) .auth-header .epqa-inline-brand .epqa-card-icon {
  filter: drop-shadow(0 16px 26px rgba(13, 27, 96, 0.16));
  height: clamp(72px, 9vw, 112px) !important;
  width: clamp(72px, 9vw, 112px) !important;
}

body:is(.page-login, .page-registro) .auth-eyebrow {
  align-items: center;
  background: linear-gradient(135deg, rgba(0, 184, 217, 0.14), rgba(123, 97, 255, 0.12)) !important;
  border: 1px solid rgba(0, 184, 217, 0.28);
  border-radius: 999px;
  color: #0D1B60 !important;
  display: inline-flex;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: clamp(1rem, 2vw, 1.22rem) !important;
  font-weight: 900 !important;
  gap: 0.55rem;
  letter-spacing: -0.015em !important;
  margin: 0 auto 0.85rem !important;
  min-height: 42px;
  padding: 0.55rem 1rem;
  text-transform: none !important;
}

body:is(.page-login, .page-registro) .auth-eyebrow i {
  color: #00B8D9;
  font-size: 1.15em;
}

body:is(.page-login, .page-registro) .epqa-login-title {
  color: #0D1B60 !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: clamp(2.25rem, 5vw, 3.65rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.045em !important;
  line-height: 1.05 !important;
  margin: 0.75rem auto 0.85rem !important;
  max-width: 720px;
  text-align: center !important;
  text-transform: none !important;
}

body:is(.page-login, .page-registro) .epqa-login-title span {
  color: #00B8D9 !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  letter-spacing: inherit !important;
  line-height: inherit !important;
  text-transform: none !important;
}

body:is(.page-login, .page-registro) .auth-subtitle {
  color: #465A69 !important;
  font-size: clamp(1rem, 2vw, 1.18rem) !important;
  margin-bottom: 1.45rem !important;
}

.epqa-impact-card {
  background:
    linear-gradient(135deg, rgba(0, 184, 217, 0.16), rgba(65, 246, 185, 0.14)),
    #ffffff;
  border: 1px solid rgba(0, 184, 217, 0.32);
  border-radius: 18px;
  box-shadow: 0 14px 30px rgba(13, 27, 96, 0.1);
  color: #0D1B60 !important;
  display: grid;
  gap: 0.28rem;
  justify-items: end;
  min-height: 112px;
  padding: 0.95rem 1rem;
  text-align: right;
}

.epqa-impact-card--today {
  background:
    linear-gradient(135deg, rgba(65, 246, 185, 0.18), rgba(0, 184, 217, 0.18)),
    #ffffff;
}

.epqa-impact-card .counter-label {
  color: #0D1B60 !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 0.82rem;
  font-weight: 900;
  line-height: 1.15;
}

.epqa-impact-card strong {
  color: #00B8D9 !important;
  display: block;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 900;
  letter-spacing: -0.055em;
  line-height: 0.95;
  margin: 0 !important;
  opacity: 1 !important;
  text-shadow: 0 8px 22px rgba(0, 184, 217, 0.2);
}

.epqa-impact-card small {
  color: #465A69;
  font-size: 0.72rem;
  font-weight: 800;
}

@media (max-width: 768px) {
  .epqa-logo {
    max-height: 38px;
  }

  .epqa-nav-icon {
    height: 24px;
    width: 24px;
  }

  .epqa-card-icon {
    height: 56px;
    width: 56px;
  }

  .epqa-hero-icon {
    height: 72px;
    width: 72px;
  }

  .epqa-media {
    border-radius: 18px;
  }

  .epqa-page-title,
  .epqa-section-title {
    font-size: clamp(1.7rem, 8vw, 2.35rem) !important;
    letter-spacing: -0.03em !important;
  }

  .epqa-page-title::after,
  .epqa-section-title::after {
    width: 72px;
    height: 4px;
  }

  .epqa-page-subtitle {
    font-size: 1rem !important;
    padding-inline: 1rem;
  }

  body.page-recursos .epqa-resource-visual {
    grid-template-columns: 1fr !important;
  }

  body.page-recursos .epqa-resource-visual .epqa-media {
    aspect-ratio: 16 / 9;
  }

  .epqa-footer-impact {
    grid-template-columns: 1fr;
  }

  .epqa-impact-card {
    justify-items: start;
    text-align: left;
  }
}

.epqa-home-question {
  margin: 1.15rem auto 1rem;
  text-align: center;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(2rem, 4vw, 3.05rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.045em;
  color: #0D1B60;
  text-transform: none !important;
  font-style: normal;
}

.epqa-home-question span {
  color: #00B8D9;
}

.epqa-home-question::after {
  content: "";
  display: block;
  width: 92px;
  height: 5px;
  margin: 0.75rem auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, #00B8D9, #7B61FF);
}

@media (max-width: 768px) {
  .epqa-home-question {
    font-size: clamp(1.65rem, 7vw, 2.25rem);
    letter-spacing: -0.035em;
  }

  .epqa-home-question::after {
    width: 72px;
    height: 4px;
  }
}

body.epqa-modal-open {
  overflow: hidden;
}

body.page-recursos .epqa-resources-hero {
  padding: clamp(1.25rem, 3vw, 2rem) !important;
}

body.page-recursos .epqa-resources-header {
  align-items: center !important;
  display: grid !important;
  gap: 1.25rem !important;
  grid-template-columns: minmax(0, 1fr) !important;
  justify-items: center !important;
  margin-bottom: 1.15rem !important;
  text-align: center !important;
}

body.page-recursos .epqa-resources-copy {
  max-width: 820px;
}

body.page-recursos .epqa-resources-copy .epqa-section-title {
  margin-top: 0 !important;
}

body.page-recursos .epqa-resource-dynamic-title {
  color: #0D1B60 !important;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  font-size: clamp(2rem, 4vw, 3.05rem) !important;
  font-weight: 900 !important;
  letter-spacing: -0.045em !important;
  line-height: 1.05 !important;
  margin: 0 auto 0.95rem !important;
  max-width: min(100%, 980px) !important;
  text-align: center !important;
  text-transform: none !important;
}

body.page-recursos .epqa-resource-dynamic-title span {
  color: #00B8D9 !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  letter-spacing: inherit !important;
  line-height: inherit !important;
  text-transform: none !important;
}

body.page-recursos .epqa-resources-toolbar {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: center;
  width: min(100%, 760px);
}

body.page-recursos .epqa-help-button {
  align-items: center;
  background: linear-gradient(135deg, rgba(0, 184, 217, 0.12), rgba(123, 97, 255, 0.12));
  border: 1px solid rgba(0, 184, 217, 0.28);
  border-radius: 999px;
  color: #0D1B60;
  cursor: pointer;
  display: inline-flex;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 0.92rem;
  font-weight: 900;
  gap: 0.5rem;
  min-height: 46px;
  padding: 0 1.05rem;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

body.page-recursos .epqa-help-button:hover,
body.page-recursos .epqa-help-button:focus-visible {
  border-color: rgba(123, 97, 255, 0.42);
  box-shadow: 0 14px 28px rgba(13, 27, 96, 0.12);
  transform: translateY(-1px);
}

body.page-recursos .epqa-help-button .resources-inline-icon {
  height: 18px;
  width: 18px;
}

body.page-recursos .epqa-resources-search {
  flex: 1 1 320px;
  max-width: 520px;
  min-width: min(100%, 280px);
}

body.page-recursos .epqa-resources-filters {
  justify-content: center;
  margin: 1rem auto 1.35rem !important;
  padding-bottom: 0.35rem;
}

body.page-recursos .epqa-resource-card {
  gap: 0.8rem;
}

body.page-recursos .epqa-resource-card header {
  min-height: 56px;
}

body.page-recursos .epqa-resource-card h3 {
  margin-top: 0.35rem !important;
}

body.page-recursos .epqa-resource-card p {
  flex: 1 1 auto;
}

body.page-recursos .resource-badges {
  align-items: flex-start;
}

body.page-recursos .resource-action {
  min-height: 40px;
  width: 100%;
}

.epqa-auth-gate {
  align-items: center;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.94)),
    radial-gradient(circle at 92% 18%, rgba(123, 97, 255, 0.16), transparent 34%),
    radial-gradient(circle at 10% 85%, rgba(0, 184, 217, 0.16), transparent 32%);
  border: 1px solid rgba(0, 184, 217, 0.24);
  border-radius: 24px;
  box-shadow: 0 18px 44px rgba(13, 27, 96, 0.12);
  color: #0D1B60;
  display: grid;
  gap: 1rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  margin: 1.1rem auto 0;
  max-width: 980px;
  padding: clamp(1rem, 2.4vw, 1.35rem);
}

.epqa-auth-gate__icon {
  align-items: center;
  background: linear-gradient(135deg, #00B8D9, #7B61FF);
  border-radius: 20px;
  color: #ffffff;
  display: inline-flex;
  height: 64px;
  justify-content: center;
  width: 64px;
}

.epqa-auth-gate__icon svg {
  display: block;
  fill: none;
  height: 30px;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.2;
  width: 30px;
}

.epqa-auth-gate__icon .epqa-card-icon {
  height: 48px !important;
  width: 48px !important;
}

.epqa-auth-gate h3 {
  color: #0D1B60;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1.08;
  margin: 0 0 0.35rem;
}

.epqa-auth-gate p {
  color: #465A69;
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.48;
  margin: 0;
}

.epqa-auth-gate__actions {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: flex-end;
}

.epqa-auth-gate__actions a {
  align-items: center;
  border-radius: 999px;
  display: inline-flex;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-weight: 900;
  justify-content: center;
  min-height: 42px;
  padding: 0 1rem;
  text-decoration: none;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.epqa-auth-gate__primary {
  background: linear-gradient(135deg, #00B8D9, #7B61FF);
  box-shadow: 0 14px 28px rgba(13, 27, 96, 0.16);
  color: #ffffff !important;
}

.epqa-auth-gate__secondary {
  background: #ffffff;
  border: 1px solid rgba(0, 184, 217, 0.28);
  color: #0D1B60 !important;
}

.epqa-auth-gate__actions a:hover,
.epqa-auth-gate__actions a:focus-visible {
  transform: translateY(-1px);
}

body.page-recursos .epqa-resources-locked .epqa-resources-header {
  margin-bottom: 0 !important;
}

body.page-capacitaciones .epqa-training-auth-gate {
  margin-bottom: 1.25rem;
  margin-top: 1.25rem;
}

.epqa-help-modal[hidden] {
  display: none !important;
}

.epqa-help-modal {
  align-items: center;
  display: grid;
  inset: 0;
  justify-items: center;
  padding: 1.25rem;
  position: fixed;
  z-index: 1080;
}

.epqa-help-modal__overlay {
  background: rgba(6, 16, 46, 0.56);
  backdrop-filter: blur(8px);
  inset: 0;
  opacity: 0;
  position: absolute;
  transition: opacity 240ms ease;
}

.epqa-help-modal__content {
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.1);
  border-radius: 28px;
  box-shadow: 0 26px 80px rgba(13, 27, 96, 0.26);
  color: #0D1B60;
  max-height: min(88vh, 780px);
  max-width: 860px;
  opacity: 0;
  overflow: auto;
  padding: clamp(1.2rem, 3vw, 2rem);
  position: relative;
  transform: translateY(16px) scale(0.96);
  transition: opacity 260ms ease, transform 260ms cubic-bezier(0.2, 0.85, 0.25, 1);
  width: min(100%, 860px);
  z-index: 1;
}

.epqa-help-modal.is-open .epqa-help-modal__overlay,
.epqa-help-modal.is-open .epqa-help-modal__content {
  opacity: 1;
}

.epqa-help-modal.is-open .epqa-help-modal__content {
  transform: translateY(0) scale(1);
}

.epqa-help-modal__close {
  align-items: center;
  background: #F1F3F6;
  border: 0;
  border-radius: 999px;
  color: #0D1B60;
  cursor: pointer;
  display: inline-flex;
  height: 40px;
  justify-content: center;
  position: absolute;
  right: 1rem;
  top: 1rem;
  width: 40px;
}

.epqa-help-modal__header {
  margin: 0 auto 1.25rem;
  max-width: 680px;
  text-align: center;
}

.epqa-help-modal__icon {
  align-items: center;
  background: linear-gradient(135deg, rgba(0, 184, 217, 0.14), rgba(123, 97, 255, 0.14));
  border-radius: 22px;
  color: #00B8D9;
  display: inline-grid;
  height: 60px;
  margin-bottom: 0.85rem;
  place-items: center;
  width: 60px;
}

.epqa-help-modal__icon .resources-inline-icon {
  height: 30px;
  width: 30px;
}

.epqa-help-modal__header h2 {
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(1.8rem, 4vw, 2.65rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin: 0 2.25rem 0.65rem;
}

.epqa-help-modal__header p {
  color: #465A69;
  font-size: 1.02rem;
  font-weight: 650;
  line-height: 1.5;
  margin: 0;
}

.epqa-help-modal__steps {
  display: grid;
  gap: 0.9rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.epqa-help-step {
  align-items: flex-start;
  background: #F8FBFF;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 18px;
  display: flex;
  gap: 0.85rem;
  padding: 1rem;
}

.epqa-help-step > span {
  align-items: center;
  background: linear-gradient(135deg, #00B8D9, #7B61FF);
  border-radius: 999px;
  color: #ffffff;
  display: inline-flex;
  flex: 0 0 auto;
  font-weight: 900;
  height: 34px;
  justify-content: center;
  width: 34px;
}

.epqa-help-step h3 {
  color: #0D1B60;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 1rem;
  font-weight: 900;
  margin: 0 0 0.25rem;
}

.epqa-help-step p {
  color: #465A69;
  font-size: 0.92rem;
  font-weight: 650;
  line-height: 1.42;
  margin: 0;
}

.epqa-help-modal__tips {
  background: linear-gradient(135deg, rgba(46, 125, 50, 0.09), rgba(0, 184, 217, 0.09));
  border: 1px solid rgba(46, 125, 50, 0.16);
  border-radius: 20px;
  margin-top: 1rem;
  padding: 1rem 1.1rem;
}

.epqa-help-modal__tips strong {
  display: block;
  font-weight: 900;
  margin-bottom: 0.5rem;
}

.epqa-help-modal__tips ul {
  color: #465A69;
  display: grid;
  gap: 0.35rem;
  margin: 0;
  padding-left: 1.2rem;
}

.epqa-help-modal__actions {
  display: flex;
  justify-content: center;
  margin-top: 1.25rem;
}

.epqa-help-modal__primary {
  background: linear-gradient(135deg, #0D1B60, #7B61FF);
  border: 0;
  border-radius: 999px;
  color: #ffffff;
  cursor: pointer;
  font-weight: 900;
  min-height: 46px;
  padding: 0 1.25rem;
}

body.page-capacitaciones .epqa-training-card {
  align-items: stretch !important;
  gap: clamp(1.1rem, 2vw, 1.6rem) !important;
  grid-template-columns: 112px minmax(0, 1fr) !important;
  min-height: 340px !important;
}

body.page-capacitaciones .epqa-training-card__media {
  align-items: flex-start;
  align-self: start;
  display: flex;
  justify-content: center;
}

.epqa-training-card__icon-img {
  display: block;
  height: 104px;
  object-fit: contain;
  width: 104px;
}

body.page-capacitaciones .epqa-training-card__content {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

body.page-capacitaciones .epqa-training-card__title {
  margin: 0 0 0.8rem !important;
  text-align: left !important;
}

body.page-capacitaciones .epqa-training-card__title::after {
  margin-left: 0 !important;
}

body.page-capacitaciones .epqa-training-card__description {
  font-size: 0.98rem;
  line-height: 1.58 !important;
  margin: 0 !important;
}

body.page-capacitaciones .epqa-training-card__tags {
  gap: 0.55rem !important;
  margin: 1.15rem 0 1.25rem !important;
}

body.page-capacitaciones .epqa-training-card__tags span {
  align-items: center;
  min-height: 32px;
  padding: 0 0.78rem !important;
}

body.page-capacitaciones .epqa-training-card__actions {
  display: flex;
  margin-top: auto;
}

body.page-capacitaciones .epqa-training-card__actions .path-button {
  justify-content: center;
  min-height: 44px;
}

@media (max-width: 900px) {
  body.page-recursos .epqa-resources-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  body.page-recursos .epqa-help-button,
  body.page-recursos .epqa-resources-search {
    justify-content: center;
    max-width: none;
    width: 100%;
  }

  .epqa-help-modal__steps {
    grid-template-columns: 1fr;
  }

  .epqa-auth-gate {
    grid-template-columns: 1fr;
    justify-items: start;
    text-align: left;
  }

  .epqa-auth-gate__actions {
    justify-content: flex-start;
    width: 100%;
  }

  .epqa-auth-gate__actions a {
    flex: 1 1 170px;
  }

  body.page-capacitaciones .epqa-training-card {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }

  body.page-capacitaciones .epqa-training-card__media {
    height: 92px;
    justify-content: flex-start;
    width: 92px;
  }

  .epqa-training-card__icon-img {
    height: 86px;
    width: 86px;
  }
}

@media (max-width: 640px) {
  .epqa-help-modal {
    padding: 0.75rem;
  }

  .epqa-help-modal__content {
    border-radius: 22px;
    max-height: 90vh;
  }

  .epqa-help-modal__header h2 {
    margin-inline: 2rem;
  }
}

body.page-capacitaciones .epqa-training-hero-fix {
  align-items: center !important;
  display: grid !important;
  gap: clamp(1.1rem, 3vw, 2rem) !important;
  grid-template-columns: minmax(280px, 0.7fr) minmax(0, 1.3fr) !important;
  margin: 0 auto 1.4rem !important;
  overflow: hidden !important;
  padding: clamp(1rem, 2.4vw, 1.45rem) !important;
  position: relative;
}

body.page-capacitaciones .epqa-training-hero-fix::before {
  background: radial-gradient(circle, rgba(0, 184, 217, 0.16), transparent 68%);
  content: "";
  height: 220px;
  left: -90px;
  pointer-events: none;
  position: absolute;
  top: -80px;
  width: 220px;
}

body.page-capacitaciones .epqa-training-hero__content {
  align-content: center;
  background: linear-gradient(180deg, rgba(248, 251, 255, 0.92), rgba(255, 255, 255, 0.72));
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 22px;
  min-width: 0;
  padding: clamp(1rem, 2.4vw, 1.35rem);
  position: relative;
  z-index: 1;
}

body.page-capacitaciones .epqa-training-hero__title {
  margin: 0.35rem auto 0.45rem !important;
  max-width: 11ch !important;
}

body.page-capacitaciones .epqa-training-hero__subtitle {
  margin-bottom: 0 !important;
}

body.page-capacitaciones .epqa-training-hero__media {
  min-width: 0;
  position: relative;
  z-index: 1;
}

body.page-capacitaciones .epqa-training-hero__media .epqa-media {
  aspect-ratio: 16 / 7;
  height: auto;
  object-fit: cover;
  width: 100%;
}

body.page-planes .epqa-plans-page {
  padding-bottom: 1rem;
}

.epqa-plans-hero {
  align-items: center;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(248, 251, 255, 0.92)),
    radial-gradient(circle at 90% 18%, rgba(123, 97, 255, 0.16), transparent 34%),
    radial-gradient(circle at 12% 88%, rgba(0, 184, 217, 0.14), transparent 32%);
  border: 1px solid rgba(13, 27, 96, 0.1);
  border-radius: 30px;
  box-shadow: 0 20px 52px rgba(13, 27, 96, 0.12);
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
  grid-template-columns: minmax(0, 1fr) minmax(260px, 360px);
  overflow: hidden;
  padding: clamp(1.5rem, 4vw, 2.4rem);
  position: relative;
}

.epqa-plans-hero::after {
  background: linear-gradient(135deg, rgba(0, 184, 217, 0.13), rgba(123, 97, 255, 0.13));
  border-radius: 999px;
  content: "";
  height: 260px;
  pointer-events: none;
  position: absolute;
  right: -130px;
  top: -130px;
  width: 260px;
}

.epqa-plans-hero__content,
.epqa-plans-hero__aside {
  position: relative;
  z-index: 1;
}

.epqa-plans-hero__content {
  text-align: center;
}

.epqa-kicker {
  align-items: center;
  background: #ffffff;
  border: 1px solid rgba(0, 184, 217, 0.24);
  border-radius: 999px;
  color: #0D1B60;
  display: inline-flex;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 0.82rem;
  font-weight: 900;
  gap: 0.45rem;
  min-height: 34px;
  padding: 0 0.85rem;
}

.epqa-plan-question {
  font-size: clamp(2rem, 4vw, 3.05rem) !important;
  margin-top: 1.05rem !important;
  max-width: 920px;
}

.epqa-plan-question span {
  color: #00B8D9 !important;
  font-size: inherit !important;
  font-weight: inherit !important;
  letter-spacing: inherit !important;
  line-height: inherit !important;
}

.epqa-plan-subtitle {
  margin-bottom: 0 !important;
}

.epqa-plans-tip-card {
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.1);
  border-radius: 24px;
  box-shadow: 0 16px 38px rgba(13, 27, 96, 0.12);
  padding: 1.25rem;
}

.epqa-plans-tip-card__icon {
  align-items: center;
  background: linear-gradient(135deg, #00B8D9, #7B61FF);
  border-radius: 18px;
  color: #ffffff;
  display: inline-flex;
  font-size: 1.4rem;
  height: 52px;
  justify-content: center;
  margin-bottom: 0.9rem;
  width: 52px;
}

.epqa-plans-tip-card h3 {
  color: #0D1B60;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: 1.15rem;
  font-weight: 900;
  margin: 0 0 0.45rem;
}

.epqa-plans-tip-card p {
  color: #465A69;
  font-weight: 650;
  line-height: 1.48;
  margin: 0;
}

body.page-planes .epqa-plan-grid {
  display: grid;
  gap: 1.15rem !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  margin-inline: auto;
  max-width: 860px;
}

body.page-planes .epqa-plan-card {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
    radial-gradient(circle at 90% 12%, rgba(0, 184, 217, 0.14), transparent 36%);
  border: 1px solid rgba(13, 27, 96, 0.1);
  border-radius: 20px;
  box-shadow: 0 16px 42px rgba(18, 38, 85, 0.09);
  color: #0D1B60;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
  padding: 1.35rem 1.35rem 1.25rem;
  position: relative;
  transition: box-shadow 0.18s ease, transform 0.18s ease;
}

body.page-planes .epqa-plan-card:hover {
  box-shadow: 0 22px 52px rgba(18, 38, 85, 0.14);
  transform: translateY(-2px);
}

body.page-planes .epqa-plan-card .route-corner {
  background: linear-gradient(135deg, #2563ff, #1d4ed8);
  font-size: 20px;
  height: 42px;
  width: 58px;
}

body.page-planes .epqa-plan-card--featured .route-corner {
  background: linear-gradient(135deg, #7c3aed, #5b21b6);
}

body.page-planes .epqa-plan-card--featured {
  border-color: rgba(123, 97, 255, 0.42);
  box-shadow: 0 22px 54px rgba(123, 97, 255, 0.18);
  transform: translateY(-6px);
}

body.page-planes .epqa-plan-card__top {
  display: flex;
  margin: 1.4rem 0 0.95rem;
}

body.page-planes .epqa-plan-card__label {
  align-items: center;
  background: #eaf2ff;
  border-radius: 16px;
  color: #2563ff;
  display: inline-flex;
  font-size: 0.76rem;
  font-weight: 900;
  gap: 0.4rem;
  min-height: 38px;
  padding: 0.35rem 0.75rem;
  text-transform: uppercase;
}

body.page-planes .epqa-plan-card--featured .epqa-plan-card__label {
  background: #f3e8ff;
  color: #7c3aed;
}

body.page-planes .epqa-plan-card__title {
  color: #0D1B60;
  font-family: 'Nunito Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  font-weight: 900;
  letter-spacing: -0.035em;
  line-height: 1.08;
  margin: 0 0 0.55rem;
}

body.page-planes .epqa-plan-card__price {
  color: #00B8D9;
  display: block;
  font-size: clamp(1.65rem, 3vw, 2.15rem);
  font-weight: 900;
  line-height: 1;
  margin-bottom: 1.05rem;
}

body.page-planes .epqa-plan-card__features {
  display: grid;
  gap: 0.65rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

body.page-planes .epqa-plan-card__features li {
  align-items: flex-start;
  color: #465A69;
  display: flex;
  font-weight: 750;
  gap: 0.55rem;
  line-height: 1.38;
}

body.page-planes .epqa-plan-card__features i {
  color: #2E7D32;
  flex: 0 0 auto;
  margin-top: 0.1rem;
}

body.page-planes .epqa-plan-card__actions {
  margin-top: auto;
  padding-top: 1.25rem;
}

body.page-planes .epqa-plan-card__actions a {
  align-items: center;
  border: 0;
  border-radius: 11px;
  display: inline-flex;
  gap: 0.55rem;
  justify-content: space-between;
  min-height: 46px;
  padding: 0.8rem 0.95rem;
  text-decoration: none;
  width: 100%;
}

body.page-planes .epqa-plan-action {
  background: #f8fbff;
  box-shadow: none;
  color: #2563ff;
  font-weight: 900;
  transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

body.page-planes .epqa-plan-action--featured {
  background: #f5f0ff;
  color: #7c3aed;
}

body.page-planes .epqa-plan-action:hover,
body.page-planes .epqa-plan-action:focus-visible {
  background: #eaf2ff;
  color: #0D1B60;
  transform: translateY(-1px);
}

body.page-dashboard .dashboard-plan-action {
  align-items: center;
  display: inline-flex;
  gap: 0.55rem;
  justify-content: center;
  text-decoration: none;
}

body.page-mi-cuenta .account-shell {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
    radial-gradient(circle at 96% 5%, rgba(0, 184, 217, 0.16), transparent 30%),
    radial-gradient(circle at 5% 96%, rgba(123, 97, 255, 0.14), transparent 32%);
  border: 1px solid #d8e3f2;
  border-radius: 24px;
  box-shadow: 0 18px 48px rgba(18, 38, 85, 0.1);
  display: grid;
  gap: 1rem;
  overflow: hidden;
  padding: clamp(1rem, 2.5vw, 1.35rem);
}

body.page-mi-cuenta .account-shell-head {
  align-items: center;
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 20px;
  display: grid;
  gap: 1rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  padding: 1rem;
}

body.page-mi-cuenta .account-shell-head h1 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-size: clamp(1.45rem, 3vw, 2rem);
  font-weight: 950;
  line-height: 1.05;
  margin: 0;
}

body.page-mi-cuenta .account-shell-head p {
  color: #5f7393;
  font-weight: 750;
  margin: 0;
}

body.page-mi-cuenta .account-shell-avatar {
  background: #eaf2ff;
  height: 92px;
  width: 92px;
}

body.page-mi-cuenta .account-summary-grid {
  display: grid;
  gap: 0.85rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body.page-mi-cuenta .account-summary-card {
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 18px;
  display: grid;
  gap: 0.25rem;
  min-height: 86px;
  padding: 0.85rem;
  position: relative;
}

body.page-mi-cuenta .account-summary-card::before {
  border-radius: 999px;
  content: "";
  height: 4px;
  inset: 0.75rem 0.85rem auto;
  position: absolute;
}

body.page-mi-cuenta .account-summary-card strong {
  color: #10233f;
  font-size: 1rem;
  font-weight: 950;
  margin-top: 0.65rem;
  overflow-wrap: anywhere;
}

body.page-mi-cuenta .account-summary-card span {
  color: #5f7393;
  font-size: 0.82rem;
  font-weight: 850;
  text-transform: uppercase;
}

body.page-mi-cuenta .account-section-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.page-mi-cuenta .account-section {
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 20px;
  box-shadow: 0 12px 32px rgba(18, 38, 85, 0.07);
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: 1rem;
  position: relative;
}

body.page-mi-cuenta .account-section::before {
  border-radius: 999px;
  content: "";
  height: 5px;
  inset: 0 0 auto;
  position: absolute;
}

body.page-mi-cuenta .account-section-title {
  align-items: center;
  display: grid;
  gap: 0.8rem;
  grid-template-columns: auto minmax(0, 1fr);
  padding-top: 0.25rem;
}

body.page-mi-cuenta .account-section-title h3 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-size: 1.18rem;
  font-weight: 950;
  line-height: 1.1;
  margin: 0;
}

body.page-mi-cuenta .account-section-title p {
  color: #5f7393;
  font-weight: 700;
  line-height: 1.35;
  margin: 0.15rem 0 0;
}

body.page-mi-cuenta .account-form {
  gap: 0.55rem;
  margin: 0;
}

body.page-mi-cuenta .account-form label {
  color: #10233f;
  font-size: 0.82rem;
  font-weight: 900;
  margin: 0;
}

body.page-mi-cuenta .account-form input[type="text"],
body.page-mi-cuenta .account-form input[type="email"],
body.page-mi-cuenta .account-form input[type="tel"],
body.page-mi-cuenta .account-form input[type="password"] {
  background: #f8fbff;
  border: 1px solid #d8e3f2;
  border-radius: 12px;
  color: #10233f;
  font-weight: 750;
  min-height: 44px;
  padding: 0.72rem 0.85rem;
}

body.page-mi-cuenta .account-form input:focus {
  border-color: #00B8D9;
  box-shadow: 0 0 0 0.18rem rgba(0, 184, 217, 0.14);
  outline: 0;
}

body.page-mi-cuenta .account-reset-form {
  border-top: 1px solid #edf2f7;
  margin-top: 0.15rem;
  padding-top: 0.85rem;
}

body.page-mi-cuenta .account-detail-list {
  display: grid;
  gap: 0.55rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

body.page-mi-cuenta .account-detail-list li {
  align-items: center;
  background: #f8fbff;
  border-radius: 12px;
  display: flex;
  gap: 0.7rem;
  justify-content: space-between;
  padding: 0.72rem 0.8rem;
}

body.page-mi-cuenta .account-detail-list span {
  color: #5f7393;
  font-weight: 850;
}

body.page-mi-cuenta .account-detail-list strong {
  color: #10233f;
  font-weight: 950;
  text-align: right;
}

body.page-mi-cuenta .account-shell-footer {
  align-items: center;
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 18px;
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  padding: 0.9rem 1rem;
}

body.page-mi-cuenta .account-shell-footer div {
  display: grid;
  gap: 0.2rem;
}

body.page-mi-cuenta .account-shell-footer strong {
  color: #10233f;
  font-weight: 950;
}

body.page-mi-cuenta .account-shell-footer span {
  color: #5f7393;
  font-weight: 700;
}

body.page-mi-cuenta .account-card-icon {
  border-radius: 24px;
  display: grid;
  height: 82px;
  place-items: center;
  width: 82px;
}

body.page-mi-cuenta .account-card-icon .epqa-card-icon {
  height: 58px;
  width: 58px;
}

body.page-mi-cuenta .account-card--blue .account-action,
body.page-mi-cuenta .account-card--blue.account-summary-card::before,
body.page-mi-cuenta .account-section.account-card--blue::before {
  background: linear-gradient(135deg, #2563ff, #1d4ed8);
}

body.page-mi-cuenta .account-card--cyan .account-action,
body.page-mi-cuenta .account-card--cyan.account-summary-card::before,
body.page-mi-cuenta .account-section.account-card--cyan::before {
  background: linear-gradient(135deg, #0ea5e9, #00B8D9);
}

body.page-mi-cuenta .account-card--green .account-action,
body.page-mi-cuenta .account-card--green.account-summary-card::before,
body.page-mi-cuenta .account-section.account-card--green::before {
  background: linear-gradient(135deg, #16a34a, #059669);
}

body.page-mi-cuenta .account-card--purple .account-action,
body.page-mi-cuenta .account-card--purple.account-summary-card::before,
body.page-mi-cuenta .account-section.account-card--purple::before {
  background: linear-gradient(135deg, #7c3aed, #5b21b6);
}

body.page-mi-cuenta .account-card--orange .account-action,
body.page-mi-cuenta .account-card--orange.account-summary-card::before,
body.page-mi-cuenta .account-section.account-card--orange::before {
  background: linear-gradient(135deg, #f97316, #ea580c);
}

body.page-mi-cuenta .account-card--blue .account-card-icon {
  background: #eaf2ff;
}

body.page-mi-cuenta .account-card--cyan .account-card-icon {
  background: rgba(14, 165, 233, 0.12);
}

body.page-mi-cuenta .account-card--green .account-card-icon {
  background: rgba(22, 163, 74, 0.12);
}

body.page-mi-cuenta .account-card--purple .account-card-icon {
  background: #f3e8ff;
}

body.page-mi-cuenta .account-card--orange .account-card-icon {
  background: rgba(249, 115, 22, 0.13);
}

body.page-mi-cuenta .account-action {
  align-items: center;
  border: 0;
  border-radius: 11px;
  color: #ffffff;
  display: inline-flex;
  font-weight: 950;
  gap: 0.55rem;
  justify-content: center;
  min-height: 44px;
  padding: 0.75rem 0.95rem;
  text-decoration: none;
  transition: filter 0.18s ease, transform 0.18s ease;
}

body.page-mi-cuenta .account-action:hover,
body.page-mi-cuenta .account-action:focus-visible {
  color: #ffffff;
  filter: saturate(1.1);
  transform: translateY(-1px);
}

body.page-mi-cuenta .account-action--soft {
  background: #f8fbff !important;
  color: #0D1B60;
}

body.page-mi-cuenta .account-action--soft:hover,
body.page-mi-cuenta .account-action--soft:focus-visible {
  color: #2563ff;
}

body.page-mi-cuenta .account-action--plan {
  background: linear-gradient(135deg, #2563ff, #7c3aed);
  white-space: nowrap;
}

body.page-mi-cuenta .account-action--logout {
  background: linear-gradient(135deg, #0D1B60, #17233a);
}

body:is(.page-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-shell {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
    radial-gradient(circle at 96% 5%, rgba(0, 184, 217, 0.16), transparent 30%),
    radial-gradient(circle at 5% 96%, rgba(123, 97, 255, 0.14), transparent 32%);
  border: 1px solid #d8e3f2;
  border-radius: 24px;
  box-shadow: 0 18px 48px rgba(18, 38, 85, 0.1);
  display: grid;
  gap: 1rem;
  overflow: hidden;
  padding: clamp(1rem, 2.5vw, 1.35rem);
}

body.page-sinapsis .sinapsis-shell-head,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-shell .dashboard-hero,
body.page-sinapsis .sinapsis-intro,
body.page-sinapsis .sinapsis-shell-footer {
  background: #ffffff;
  border: 1px solid rgba(13, 27, 96, 0.08);
  border-radius: 20px;
  box-shadow: 0 12px 32px rgba(18, 38, 85, 0.06);
}

body.page-sinapsis .sinapsis-shell-head {
  align-items: center;
  display: grid;
  gap: 1rem;
  grid-template-columns: auto minmax(0, 1fr) auto;
  padding: 1rem;
}

body.page-sinapsis .sinapsis-shell-avatar {
  background: #eaf2ff;
  border-radius: 24px;
  display: grid;
  height: 92px;
  place-items: center;
  width: 92px;
}

body.page-sinapsis .sinapsis-shell-avatar .epqa-card-icon {
  height: 62px;
  width: 62px;
}

body.page-sinapsis .sinapsis-shell-head h1 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-size: clamp(1.65rem, 3.4vw, 2.35rem);
  font-weight: 950;
  line-height: 1.05;
  margin: 0;
}

body.page-sinapsis .sinapsis-shell-head p,
body.page-sinapsis .sinapsis-intro p,
body.page-sinapsis .sinapsis-section-title p,
body.page-sinapsis .sinapsis-shell-footer span {
  color: #5f7393;
  font-weight: 750;
  margin: 0;
}

body.page-sinapsis .sinapsis-intro,
body.page-sinapsis .sinapsis-section-block,
body.page-sinapsis .sinapsis-shell-footer {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}

body.page-sinapsis .sinapsis-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

body.page-sinapsis .sinapsis-section-title h2,
body.page-sinapsis .sinapsis-panel h2 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-weight: 950;
  line-height: 1.1;
  margin: 0;
}

body.page-sinapsis .sinapsis-card {
  border-radius: 20px;
  display: grid;
  justify-items: center;
  min-height: 250px;
  padding: 1.35rem 1rem 1rem;
  text-align: center;
}

body.page-sinapsis .sinapsis-card .route-corner {
  font-size: 20px;
  height: 42px;
  width: 58px;
}

body.page-sinapsis .sinapsis-card .route-visual {
  height: 82px;
  width: 96px;
}

body.page-sinapsis .sinapsis-card .route-visual i {
  background: transparent !important;
  color: inherit;
  font-size: 2rem;
  height: auto;
  margin: 0;
  width: auto;
}

body.page-sinapsis .sinapsis-section-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.page-sinapsis .sinapsis-panel {
  background: #ffffff;
  border: 1px solid #d8e3f2;
  border-radius: 20px;
  box-shadow: 0 16px 42px rgba(18, 38, 85, 0.09);
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
}

body.page-sinapsis .sinapsis-partnership {
  align-items: center;
  grid-template-columns: auto minmax(0, 1fr);
}

body.page-sinapsis .sinapsis-shell-footer {
  align-items: center;
  grid-template-columns: minmax(0, 1fr) auto;
}

body:is(.page-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-action {
  align-items: center;
  border: 0;
  border-radius: 11px;
  color: #ffffff;
  display: inline-flex;
  font-weight: 950;
  gap: 0.55rem;
  justify-content: center;
  min-height: 44px;
  padding: 0.75rem 0.95rem;
  text-decoration: none;
}

body:is(.page-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-action--primary {
  background: linear-gradient(135deg, #2563ff, #7c3aed);
}

body:is(.page-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-action--secondary {
  background: linear-gradient(135deg, #16a34a, #059669);
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-hero,
body.page-sinapsis .sinapsis-hero-content {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.96)),
    radial-gradient(circle at 94% 10%, rgba(0, 184, 217, 0.18), transparent 30%),
    radial-gradient(circle at 6% 92%, rgba(123, 97, 255, 0.14), transparent 32%);
  border: 1px solid #d8e3f2;
  border-radius: 24px;
  box-shadow: 0 18px 48px rgba(18, 38, 85, 0.1);
  color: #10233f;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-hero h1,
body.page-sinapsis .sinapsis-hero-content h1,
body.page-sinapsis .sinapsis-hero-content h2 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-weight: 950;
  line-height: 1.05;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-hero p,
body.page-sinapsis .sinapsis-hero-content p,
body.page-sinapsis .stem-section-head p {
  color: #5f7393;
  font-weight: 750;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card-grid,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante, .page-admin-sinapsis) .dashboard-grid {
  display: grid;
  gap: 1rem;
}

body.page-sinapsis .sinapsis-card-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body:is(.page-sinapsis-familia, .page-sinapsis-estudiante, .page-admin-sinapsis) .dashboard-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card,
body.page-sinapsis .partnership-card,
body.page-admin-sinapsis .surface-card,
body.page-admin-sinapsis .admin-table-wrap {
  background:
    linear-gradient(180deg, #ffffff, #f8fbff);
  border: 1px solid #d8e3f2;
  border-radius: 20px;
  box-shadow: 0 16px 42px rgba(18, 38, 85, 0.09);
  color: #10233f;
  overflow: hidden;
  position: relative;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card::before,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card::before,
body.page-admin-sinapsis .surface-card::before,
body.page-admin-sinapsis .admin-table-wrap::before {
  background: linear-gradient(135deg, #2563ff, #7c3aed);
  content: "";
  height: 5px;
  inset: 0 0 auto;
  position: absolute;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card:nth-child(2)::before,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card:nth-child(2)::before {
  background: linear-gradient(135deg, #16a34a, #059669);
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card:nth-child(3)::before,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card:nth-child(3)::before {
  background: linear-gradient(135deg, #0ea5e9, #00B8D9);
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card i,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card i {
  background: #eaf2ff;
  border-radius: 20px;
  color: #2563ff;
  display: inline-grid;
  font-size: 1.65rem;
  height: 64px;
  margin-bottom: 0.75rem;
  place-items: center;
  width: 64px;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card h2,
body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card h3,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card h2,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card h3,
body.page-admin-sinapsis .surface-card h2,
body.page-admin-sinapsis .admin-table-wrap h2 {
  color: #10233f;
  font-family: "Nunito", "Segoe UI", sans-serif;
  font-weight: 950;
  line-height: 1.1;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-card p,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .dashboard-card p,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .meta-line,
body.page-admin-sinapsis .surface-card p {
  color: #5f7393;
  font-weight: 700;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .stem-actions a,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .auth-actions button,
body.page-admin-sinapsis .btn-auth-primary,
body.page-admin-sinapsis .mini-button,
body.page-admin-sinapsis .sinapsis-tabs a {
  align-items: center;
  border: 0;
  border-radius: 11px;
  color: #ffffff;
  display: inline-flex;
  font-weight: 950;
  gap: 0.55rem;
  justify-content: center;
  min-height: 44px;
  padding: 0.72rem 0.95rem;
  text-decoration: none;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .stem-actions a:first-child,
body.page-admin-sinapsis .btn-auth-primary,
body.page-admin-sinapsis .sinapsis-tabs a,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .auth-actions button:last-child {
  background: linear-gradient(135deg, #2563ff, #7c3aed);
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .stem-actions a:not(:first-child),
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .auth-actions button:first-child,
body.page-admin-sinapsis .mini-button {
  background: linear-gradient(135deg, #16a34a, #059669);
}

body.page-admin-sinapsis .sinapsis-stat,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-stat {
  background: #ffffff;
  border: 1px solid #d8e3f2;
  border-radius: 18px;
  box-shadow: 0 12px 32px rgba(18, 38, 85, 0.07);
  color: #10233f;
}

body.page-admin-sinapsis .sinapsis-stat strong,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-stat strong {
  color: #2563ff;
}

body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .challenge-card,
body:is(.page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .receipt-card,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) .progress-item {
  background: #f8fbff;
  border: 1px solid #d8e3f2;
  border-radius: 14px;
  box-shadow: none;
}

body.page-admin-sinapsis .admin-table {
  color: #10233f;
  margin: 0;
}

body.page-admin-sinapsis .admin-table th {
  color: #2563ff;
}

body.page-admin-sinapsis .admin-form input,
body.page-admin-sinapsis .admin-form select,
body.page-admin-sinapsis .admin-form textarea,
body:is(.page-sinapsis-familia, .page-sinapsis-estudiante) textarea.form-control {
  background: #f8fbff;
  border: 1px solid #d8e3f2;
  border-radius: 12px;
  color: #10233f;
  font-weight: 750;
}

body:is(.page-sinapsis, .page-admin-sinapsis, .page-sinapsis-familia, .page-sinapsis-estudiante) .sinapsis-photo-card {
  border: 1px solid #d8e3f2;
  border-radius: 20px;
  box-shadow: 0 16px 42px rgba(18, 38, 85, 0.09);
}

@media (max-width: 1040px) {
  .epqa-plans-hero,
  body.page-planes .epqa-plan-grid {
    grid-template-columns: 1fr;
  }

  body.page-planes .epqa-plan-card--featured {
    transform: none;
  }

  body.page-mi-cuenta .account-shell-head,
  body.page-mi-cuenta .account-section-grid {
    grid-template-columns: 1fr;
  }

  body.page-mi-cuenta .account-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.page-mi-cuenta .account-shell-head {
    justify-items: start;
  }

  body.page-sinapsis .sinapsis-card-grid,
  body.page-sinapsis .sinapsis-section-grid,
  body:is(.page-sinapsis-familia, .page-sinapsis-estudiante, .page-admin-sinapsis) .dashboard-grid {
    grid-template-columns: 1fr;
  }

  body.page-sinapsis .sinapsis-shell-head,
  body.page-sinapsis .sinapsis-shell-footer,
  body.page-sinapsis .sinapsis-partnership {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  body.page-capacitaciones .epqa-training-hero-fix {
    grid-template-columns: 1fr !important;
  }

  body.page-capacitaciones .epqa-training-hero__title {
    max-width: 100% !important;
  }

  body.page-capacitaciones .epqa-training-hero__media .epqa-media {
    aspect-ratio: 16 / 9;
  }
}

@media (max-width: 640px) {
  .epqa-plans-hero {
    border-radius: 22px;
  }

  body.page-planes .epqa-plan-card {
    border-radius: 20px;
  }

  body.page-mi-cuenta .account-summary-grid {
    grid-template-columns: 1fr;
  }

  body.page-mi-cuenta .account-shell-footer,
  body.page-mi-cuenta .account-detail-list li {
    align-items: flex-start;
    flex-direction: column;
  }

  body.page-mi-cuenta .account-detail-list strong {
    text-align: left;
  }

  body.page-mi-cuenta .account-action {
    width: 100%;
  }

  body.page-sinapsis .sinapsis-action {
    width: 100%;
  }
}
