/**
 * Toque de color por programa. <html class="tm-html tm-prog-…">
 * Mapea variables que ya usan las landings (--dipav-purple, --encanto-red, etc.).
 */
html.tm-html {
  scroll-behavior: smooth;
}

html.tm-prog-institutional,
html.tm-prog-dipav {
  --tm-prog-primary: #d4af37;
  --tm-prog-secondary: #94a3b8;
  --tm-prog-glow-a: rgba(212, 175, 55, 0.28);
  --tm-prog-glow-b: rgba(148, 163, 184, 0.12);
}

html.tm-prog-talentos {
  --tm-prog-primary: var(--tm-brand-talentos);
  --tm-prog-secondary: #5eead4;
  --tm-prog-glow-a: rgba(139, 92, 246, 0.32);
  --tm-prog-glow-b: rgba(94, 234, 212, 0.18);
  --dipav-purple: var(--tm-prog-primary);
  --dipav-blue: var(--tm-prog-secondary);
  --talentos-violet: #a78bfa;
  --talentos-violet-soft: #c4b5fd;
  --talentos-teal: var(--tm-prog-secondary);
  --talentos-teal-soft: #99f6e4;
  --talentos-ink: #f5f3ff;
  --talentos-deep: #0d0820;
}

html.tm-prog-encanto {
  --tm-prog-primary: var(--tm-brand-encanto);
  --tm-prog-secondary: #c9952e;
  --tm-prog-glow-a: rgba(212, 168, 92, 0.2);
  --tm-prog-glow-b: rgba(196, 30, 58, 0.1);
  --encanto-red: var(--tm-prog-primary);
  --encanto-brown: var(--tm-prog-secondary);
  --encanto-gold: #d4a85c;
  --encanto-gold-soft: #e8c88a;
  --encanto-cream: #faf7f2;
  --encanto-rose-soft: #e8b4bc;
}

html.tm-prog-misamores {
  --tm-prog-primary: var(--tm-brand-mis-amores);
  --tm-prog-secondary: #36c9cb;
  --tm-prog-glow-a: rgba(221, 150, 175, 0.28);
  --tm-prog-glow-b: rgba(54, 201, 203, 0.2);
  --dipav-purple: var(--tm-prog-primary);
  --dipav-blue: var(--tm-prog-secondary);
}

/* Barra decorativa en contenedor blanco de marca (añade class tm-brand-strip-accent al bloque) */
html.tm-html .tm-brand-strip-accent::before {
  background: linear-gradient(90deg, var(--tm-prog-primary), var(--tm-prog-secondary));
}

/* Base oscura compartida (sobrescribe :root de landings con mayor especificidad en <html>) */
html.tm-html.tm-prog-talentos {
  --bg: var(--talentos-deep);
  --ink: var(--talentos-ink);
  --muted: color-mix(in srgb, var(--talentos-violet-soft) 75%, #94a3b8);
  --border: rgba(167, 139, 250, 0.34);
}

/* Encanto: landing oscura cálida (logo = negro + rojo + dorado; ambiente dorado, rojo en CTAs) */
html.tm-html.tm-prog-encanto {
  --bg: #14100d;
  --ink: var(--encanto-cream);
  --muted: #a89482;
  --border: rgba(212, 168, 92, 0.3);
  --tm-prog-glow-a: rgba(212, 168, 92, 0.18);
  --tm-prog-glow-b: rgba(196, 30, 58, 0.08);
}

/* Encanto: tarjetas cálidas semitransparentes (no blanco plano) */
html.tm-html.tm-prog-encanto {
  --card-bg: rgba(30, 22, 17, 0.94);
  --input-bg: rgba(255, 248, 240, 0.06);
  --input-border: rgba(212, 168, 92, 0.34);
  --shadow: 0 24px 48px -16px rgba(8, 5, 4, 0.55);
  --shadow-soft: 0 4px 14px rgba(8, 5, 4, 0.32);
}

html.tm-html.tm-prog-encanto .card {
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  color: var(--ink);
  border-color: color-mix(in srgb, var(--encanto-brown) 42%, transparent);
}

html.tm-html.tm-prog-misamores .card {
  color: var(--ink);
}

/* Mis Amores — jerarquía visual (modo claro; ver bloque :not([data-theme="light"]) para oscuro) */
html.tm-html.tm-prog-misamores[data-theme="light"] {
  --ma-field-surface: #fff;
  --input-bg: #fff;
  --input-bg-focus: #fff;
  --input-border: rgba(221, 150, 175, 0.28);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .title {
  background: linear-gradient(
    118deg,
    #2a4549 0%,
    var(--tm-brand-mis-amores) 42%,
    var(--dipav-blue) 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html.tm-html.tm-prog-misamores[data-theme="light"] .subtitle strong {
  color: var(--dipav-purple);
}

html.tm-html.tm-prog-misamores[data-theme="light"] main.grid > .card .meta {
  background: color-mix(in srgb, var(--card-bg) 90%, var(--tm-brand-mis-amores) 10%);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .progressBar {
  background: linear-gradient(90deg, var(--dipav-purple), var(--dipav-blue));
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-esquema-pago__opcion {
  background: var(--ma-field-surface, #fff);
  border-color: rgba(221, 150, 175, 0.28);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-esquema-pago__opcion:has(input:checked) {
  border-color: color-mix(in srgb, var(--dipav-purple) 55%, var(--border));
  background: rgba(221, 150, 175, 0.1);
}

html.tm-html.tm-prog-misamores[data-theme="light"] select option {
  background: #fff;
  color: var(--ink);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .ma-nd-block > label {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .checkRow:has(input:checked) {
  border-color: var(--dipav-purple);
  background: rgba(221, 150, 175, 0.08);
}

/* Mis Amores — modo oscuro (canvas profundo + acentos rosa / turquesa del logo) */
html.tm-html.tm-prog-misamores:not([data-theme="light"]) {
  color-scheme: dark;
  --ma-deep: #142428;
  --ma-surface: rgba(26, 40, 44, 0.94);
  --ma-field-surface: rgba(255, 248, 245, 0.06);
  --bg: var(--ma-deep);
  --ink: #f5f0ee;
  --muted: #9eb0b6;
  --border: rgba(221, 150, 175, 0.3);
  --card-bg: var(--ma-surface);
  --input-bg: var(--ma-field-surface);
  --input-bg-focus: rgba(255, 248, 245, 0.08);
  --input-border: rgba(221, 150, 175, 0.34);
  --shadow: 0 24px 48px -16px rgba(8, 14, 16, 0.55);
  --shadow-soft: 0 4px 14px rgba(8, 14, 16, 0.32);
  --tm-prog-glow-a: rgba(221, 150, 175, 0.14);
  --tm-prog-glow-b: rgba(54, 201, 203, 0.1);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) body {
  background:
    radial-gradient(at 10% 0%, var(--tm-prog-glow-a) 0px, transparent 50%),
    radial-gradient(at 90% 12%, var(--tm-prog-glow-b) 0px, transparent 48%),
    radial-gradient(at 50% 100%, rgba(221, 150, 175, 0.08) 0px, transparent 55%),
    var(--bg);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card {
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-color: color-mix(in srgb, var(--tm-brand-mis-amores) 38%, transparent);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .title {
  background: linear-gradient(
    118deg,
    #f5f0ee 0%,
    #f0b4c8 40%,
    #7ee8e8 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .subtitle strong {
  color: #f0b4c8;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) main.grid > .card .meta {
  background: rgba(221, 150, 175, 0.08);
  border-color: color-mix(in srgb, var(--tm-brand-mis-amores) 32%, transparent);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card .meta .k {
  color: #f0b4c8;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card .meta .v {
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card .meta .v .tm-meta-mensual-nota {
  color: var(--muted);
  opacity: 1;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .note {
  border-color: rgba(221, 150, 175, 0.28);
  background: rgba(221, 150, 175, 0.1);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .progressTrack {
  background: rgba(255, 255, 255, 0.08);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .progressBar {
  background: linear-gradient(90deg, var(--dipav-purple), var(--dipav-blue));
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-step-badge {
  color: #fff;
  background: linear-gradient(135deg, var(--dipav-purple), var(--dipav-blue));
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-esquema-pago__opcion {
  background: var(--ma-field-surface);
  border-color: var(--input-border);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-esquema-pago__opcion:has(input:checked) {
  border-color: color-mix(in srgb, var(--dipav-blue) 55%, var(--border));
  background: rgba(221, 150, 175, 0.14);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) select option {
  background: #1e3236;
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .checkRow {
  background: var(--ma-field-surface);
  border-color: var(--input-border);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .checkRow:has(input:checked) {
  border-color: color-mix(in srgb, var(--dipav-blue) 50%, var(--border));
  background: rgba(221, 150, 175, 0.12);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .ma-success-box {
  background: rgba(54, 201, 203, 0.1);
  border-color: rgba(54, 201, 203, 0.28);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-landing-gallery .ph {
  display: flex;
  flex-direction: column;
  background: rgba(20, 36, 40, 0.88);
  border-color: color-mix(in srgb, var(--tm-brand-mis-amores) 34%, transparent);
  box-shadow:
    0 1px 0 color-mix(in srgb, var(--tm-brand-mis-amores) 28%, transparent),
    var(--shadow-soft);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-landing-gallery .ph:hover {
  border-color: color-mix(in srgb, var(--dipav-blue) 45%, transparent);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-landing-gallery .ph .cap {
  color: var(--ink);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--tm-brand-mis-amores) 18%, rgba(20, 36, 40, 0.95)) 0%,
    rgba(20, 36, 40, 0.98) 100%
  );
  border-top-color: color-mix(in srgb, var(--tm-brand-mis-amores) 32%, transparent);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) button.tm-link-precios {
  color: #b8f0f0;
  background: linear-gradient(135deg, rgba(221, 150, 175, 0.22), rgba(54, 201, 203, 0.14));
  border-color: rgba(54, 201, 203, 0.35);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) button.tm-link-precios:hover {
  color: #fff;
  background: linear-gradient(135deg, var(--dipav-purple), var(--dipav-blue));
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-modal .modal-content {
  background: linear-gradient(165deg, #1e3236 0%, #142428 100%);
  border-color: rgba(221, 150, 175, 0.38);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-modal-title,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-highlight {
  color: #b8f0f0;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-lead,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-section-label,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-membresia-k,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-k {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-membresia {
  background: rgba(0, 0, 0, 0.28);
  border-color: rgba(54, 201, 203, 0.32);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-membresia-v {
  color: #f0b4c8;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-card {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(221, 150, 175, 0.28);
  box-shadow: none;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-name {
  color: #b8f0f0;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-col {
  background: rgba(0, 0, 0, 0.2);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-col--miembro {
  background: linear-gradient(145deg, rgba(221, 150, 175, 0.16), rgba(54, 201, 203, 0.12));
  border-color: rgba(54, 201, 203, 0.28);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-precios-rate-v {
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .modal-overlay:not(.tm-precios-modal) .modal-content {
  background: linear-gradient(165deg, #1e3236 0%, #142428 100%);
  border-color: rgba(221, 150, 175, 0.38);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .ma-modal-title {
  color: #b8f0f0;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .ma-tech-list li {
  color: var(--ink);
  border-color: rgba(221, 150, 175, 0.24);
  background: rgba(221, 150, 175, 0.08);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .modal-overlay:not(.tm-precios-modal) .close-modal {
  background: rgba(221, 150, 175, 0.2);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) #termsLink {
  color: #7ee8e8;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) #termsLink:hover {
  color: #f0b4c8;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .btnSecondary {
  background: rgba(221, 150, 175, 0.12);
  color: var(--ink);
  border-color: var(--border);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .btnSecondary:hover {
  background: rgba(54, 201, 203, 0.14);
  color: #b8f0f0;
  border-color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card input:not([type="checkbox"]):not([type="radio"]),
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card select,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card textarea {
  background: var(--input-bg);
  border-color: var(--input-border);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card input:not([type="checkbox"]):not([type="radio"]):-webkit-autofill,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card input:not([type="checkbox"]):not([type="radio"]):-webkit-autofill:hover,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card input:not([type="checkbox"]):not([type="radio"]):-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--input-bg) inset;
  -webkit-text-fill-color: var(--ink);
  caret-color: var(--ink);
  transition: background-color 99999s ease-out 0s;
}

html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card input:focus,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card select:focus,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .card textarea:focus {
  border-color: var(--dipav-blue);
  background: rgba(255, 248, 245, 0.08);
  box-shadow: 0 0 0 4px rgba(54, 201, 203, 0.2);
}

html.tm-html.tm-prog-encanto .card .meta {
  background: rgba(212, 168, 92, 0.06);
  border-color: color-mix(in srgb, var(--encanto-brown) 28%, transparent);
}

html.tm-html.tm-prog-encanto .card .meta .k {
  color: var(--encanto-gold-soft);
  letter-spacing: 0.1em;
}

html.tm-html.tm-prog-encanto .card .meta .v {
  color: var(--encanto-cream);
}

html.tm-html.tm-prog-encanto .card .meta:nth-child(1) .k {
  color: #f0d4b8;
}

html.tm-html.tm-prog-encanto .card .meta:nth-child(2) .k {
  color: var(--encanto-gold-soft);
}

html.tm-html.tm-prog-encanto .card .meta:nth-child(3) .k {
  color: var(--encanto-rose-soft);
}

html.tm-html.tm-prog-encanto .card .meta:nth-child(4) .k {
  color: #f5c4a8;
}

html.tm-html.tm-prog-encanto .card .meta .v #enc-precio-mensual-desde,
html.tm-html.tm-prog-encanto .card .meta .v [id$="-precio-mensual-desde"] {
  color: var(--encanto-gold);
}

/* Talentos: vidrio morado (identidad DIPAV) */
html.tm-html.tm-prog-talentos {
  --bg: var(--talentos-deep);
  --ink: var(--talentos-ink);
  --muted: color-mix(in srgb, var(--talentos-violet-soft) 70%, #94a3b8);
  --border: rgba(167, 139, 250, 0.32);
  --card-bg: rgba(28, 18, 52, 0.86);
  --input-bg: rgba(8, 4, 18, 0.45);
  --input-border: rgba(167, 139, 250, 0.24);
  --shadow:
    0 24px 48px -16px rgba(8, 4, 24, 0.6),
    0 8px 20px -8px rgba(139, 92, 246, 0.28);
  --shadow-soft: 0 4px 14px rgba(8, 4, 24, 0.45);
}

html.tm-html.tm-prog-talentos .card {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  color: var(--ink);
  border-color: color-mix(in srgb, var(--talentos-violet) 45%, transparent);
}

html.tm-html.tm-prog-talentos .card .meta {
  background: rgba(167, 139, 250, 0.06);
  border-color: color-mix(in srgb, var(--talentos-violet) 28%, transparent);
}

html.tm-html.tm-prog-talentos .card .meta .k {
  color: var(--talentos-teal);
  letter-spacing: 0.1em;
}

html.tm-html.tm-prog-talentos .card .meta .v {
  color: var(--talentos-ink);
}

html.tm-html.tm-prog-talentos .card .meta:nth-child(1) .k {
  color: var(--talentos-violet-soft);
}

html.tm-html.tm-prog-talentos .card .meta:nth-child(2) .k {
  color: var(--talentos-teal-soft);
}

html.tm-html.tm-prog-talentos .card .meta:nth-child(3) .k {
  color: var(--talentos-violet);
}

html.tm-html.tm-prog-talentos .card .meta:nth-child(4) .k {
  color: var(--talentos-teal);
}

html.tm-html.tm-prog-talentos .card .meta .v #tal-precio-mensual-desde {
  color: var(--talentos-teal-soft);
}

html.tm-html.tm-prog-talentos .card .meta .v .tm-meta-mensual-nota {
  color: color-mix(in srgb, var(--talentos-violet-soft) 88%, transparent);
}

html.tm-html.tm-prog-encanto body {
  background:
    radial-gradient(at 10% 0%, var(--tm-prog-glow-a) 0px, transparent 52%),
    radial-gradient(at 90% 14%, rgba(196, 30, 58, 0.14) 0px, transparent 46%),
    radial-gradient(at 50% 100%, rgba(120, 72, 32, 0.16) 0px, transparent 58%),
    var(--bg);
}

html.tm-html.tm-prog-talentos body {
  background:
    radial-gradient(at 12% 6%, var(--tm-prog-glow-a) 0px, transparent 52%),
    radial-gradient(at 88% 18%, var(--tm-prog-glow-b) 0px, transparent 50%),
    radial-gradient(at 50% 92%, rgba(94, 234, 212, 0.14) 0px, transparent 60%),
    radial-gradient(at 50% 50%, rgba(76, 29, 149, 0.22) 0px, transparent 70%),
    var(--bg);
}

/* Mis Amores: modo claro (default del sitio vía data-theme="light") */
html.tm-html.tm-prog-misamores[data-theme="light"] {
  color-scheme: light;
  --ma-field-surface: #ffffff;
  --bg: #faf6f4;
  --ink: #2a4549;
  --muted: #6b7c82;
  --border: rgba(221, 150, 175, 0.28);
  --card-bg: #ffffff;
  --input-bg: #ffffff;
  --input-border: rgba(221, 150, 175, 0.28);
  --shadow: 0 20px 25px -5px rgba(42, 69, 73, 0.08), 0 10px 10px -5px rgba(221, 150, 175, 0.12);
  --shadow-soft: 0 4px 6px -1px rgba(42, 69, 73, 0.06);
  --tm-prog-glow-a: rgba(221, 150, 175, 0.28);
  --tm-prog-glow-b: rgba(54, 201, 203, 0.2);
}

/**
 * Cabecera réplica DIPAV (Encanto, Mis Amores, Talentos):
 * barra blanca ancho completo, .nav-logos centrado, TMM 35/45px, logo programa 60/75px.
 */
html.tm-html.tm-prog-encanto body,
html.tm-html.tm-prog-misamores body,
html.tm-html.tm-prog-talentos body {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

html.tm-html.tm-prog-encanto body > .wrap,
html.tm-html.tm-prog-misamores body > .wrap,
html.tm-html.tm-prog-talentos body > .wrap {
  flex: 1;
  width: 100%;
}

html.tm-html.tm-prog-encanto header,
html.tm-html.tm-prog-misamores header,
html.tm-html.tm-prog-talentos header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb;
  position: relative;
  width: 100%;
  z-index: 100;
  flex-shrink: 0;
}

html.tm-html.tm-prog-encanto header .nav-logos,
html.tm-html.tm-prog-misamores header .nav-logos,
html.tm-html.tm-prog-talentos header .nav-logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  width: 100%;
}

html.tm-html.tm-prog-encanto header .nav-logos a,
html.tm-html.tm-prog-misamores header .nav-logos a,
html.tm-html.tm-prog-talentos header .nav-logos a {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  text-decoration: none !important;
  color: inherit;
}

html.tm-html.tm-prog-encanto header .nav-logos a:hover,
html.tm-html.tm-prog-misamores header .nav-logos a:hover,
html.tm-html.tm-prog-talentos header .nav-logos a:hover {
  text-decoration: none !important;
  opacity: 0.92;
}

html.tm-html.tm-prog-encanto header .nav-logos .logo-tmm,
html.tm-html.tm-prog-misamores header .nav-logos .logo-tmm,
html.tm-html.tm-prog-talentos header .nav-logos .logo-tmm {
  height: 35px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
}

html.tm-html.tm-prog-encanto header .nav-logos .logo-encanto,
html.tm-html.tm-prog-misamores header .nav-logos .logo-mis-amores,
html.tm-html.tm-prog-talentos header .nav-logos .logo-talentos {
  height: 60px;
  width: auto;
  max-width: 100%;
  object-fit: contain;
}

html.tm-html.tm-prog-encanto header .nav-separator,
html.tm-html.tm-prog-misamores header .nav-separator,
html.tm-html.tm-prog-talentos header .nav-separator {
  width: 1px;
  height: 28px;
  background: var(--tm-role-overlay-on-canvas-12);
  flex-shrink: 0;
}

@media (min-width: 768px) {
  html.tm-html.tm-prog-encanto header .nav-logos .logo-tmm,
  html.tm-html.tm-prog-misamores header .nav-logos .logo-tmm,
  html.tm-html.tm-prog-talentos header .nav-logos .logo-tmm {
    height: 45px;
  }

  html.tm-html.tm-prog-encanto header .nav-logos .logo-encanto,
  html.tm-html.tm-prog-misamores header .nav-logos .logo-mis-amores,
  html.tm-html.tm-prog-talentos header .nav-logos .logo-talentos {
    height: 75px;
  }

  html.tm-html.tm-prog-encanto header .nav-separator,
  html.tm-html.tm-prog-misamores header .nav-separator,
  html.tm-html.tm-prog-talentos header .nav-separator {
    height: 38px;
  }
}

/* Galerías landings: ratio estable (evita fotos “aplastadas” al cambiar viewport) */
html.tm-html .photos {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

html.tm-html .ph {
  min-width: 0;
  overflow: hidden;
}

html.tm-html .ph img {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  min-height: 120px;
  max-height: min(38vw, 220px);
  object-fit: cover;
  display: block;
}

@media (max-width: 980px) {
  html.tm-html .photos {
    grid-template-columns: 1fr;
  }

  html.tm-html .ph img {
    max-height: none;
    aspect-ratio: 16 / 10;
    min-height: 160px;
  }
}

/* Panel CONOCER (texto) en landings de inscripción */
html.tm-html .tm-conocer-panel {
  margin-top: 18px;
}

html.tm-html.tm-prog-dipav .authority-section .tm-conocer-panel {
  margin: 18px 0 0;
  max-width: none;
}

html.tm-html.tm-prog-talentos .cardInner .tm-conocer-panel,
html.tm-html.tm-prog-encanto .cardInner .tm-conocer-panel,
html.tm-html.tm-prog-misamores .cardInner .tm-conocer-panel {
  margin: 18px 0 0;
  max-width: none;
  width: 100%;
}

/* Tridente (Talentos, Mis Amores, Encanto): nota + enlace de precios solo en tarjeta intro (página 1) */
html.tm-html .tm-landing-precios-wrap {
  text-align: center;
  margin-top: 14px;
}

html.tm-html .tm-landing-precios-nota {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.45;
  color: var(--muted);
  max-width: 28rem;
  margin-left: auto;
  margin-right: auto;
}

html.tm-html.tm-prog-talentos button.tm-link-precios,
html.tm-html.tm-prog-encanto button.tm-link-precios,
html.tm-html.tm-prog-misamores button.tm-link-precios {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 10px;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
  font-family: inherit;
  border: 1px solid transparent;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.12);
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}

html.tm-html.tm-prog-misamores button.tm-link-precios {
  color: var(--dipav-blue);
  background: linear-gradient(135deg, rgba(221, 150, 175, 0.18), rgba(54, 201, 203, 0.14));
  border-color: rgba(54, 201, 203, 0.35);
  box-shadow: 0 4px 14px rgba(42, 69, 73, 0.06);
}
html.tm-html.tm-prog-misamores button.tm-link-precios:hover {
  color: var(--ink);
  background: linear-gradient(135deg, rgba(221, 150, 175, 0.28), rgba(54, 201, 203, 0.22));
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(221, 150, 175, 0.2);
}

html.tm-html.tm-prog-talentos button.tm-link-precios {
  color: var(--talentos-teal-soft);
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.34), rgba(94, 234, 212, 0.14));
  border-color: rgba(94, 234, 212, 0.42);
  box-shadow: 0 4px 14px rgba(8, 4, 24, 0.25);
}
html.tm-html.tm-prog-talentos button.tm-link-precios:hover {
  color: #fff;
  background: linear-gradient(135deg, rgba(139, 92, 246, 0.5), rgba(94, 234, 212, 0.24));
  border-color: var(--talentos-teal);
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(139, 92, 246, 0.28);
}

html.tm-html.tm-prog-encanto button.tm-link-precios {
  color: #fff8ef;
  background: linear-gradient(135deg, rgba(212, 168, 92, 0.32), rgba(196, 30, 58, 0.1));
  border-color: rgba(232, 200, 138, 0.48);
  box-shadow: 0 4px 14px rgba(8, 5, 4, 0.2);
}
html.tm-html.tm-prog-encanto button.tm-link-precios:hover {
  color: #fff;
  background: linear-gradient(135deg, rgba(212, 168, 92, 0.46), rgba(196, 30, 58, 0.2));
  border-color: var(--encanto-gold-soft);
  transform: translateY(-1px);
  box-shadow: 0 8px 20px rgba(196, 30, 58, 0.18);
}

html.tm-html.tm-prog-talentos .checkRow button.tm-link-precios,
html.tm-html.tm-prog-encanto .checkRow button.tm-link-precios,
html.tm-html.tm-prog-misamores .checkRow button.tm-link-precios,
html.tm-html .tm-esquema-pago button.tm-link-precios {
  margin-top: 8px;
  align-self: flex-start;
}

html.tm-html .tm-esquema-pago {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
}

html.tm-html .tm-esquema-pago__legend {
  font-weight: 800;
  font-size: 12px;
  margin: 0 0 0.25rem;
  line-height: 1.45;
  color: var(--ink);
  letter-spacing: 0.02em;
}

html.tm-html .tm-esquema-pago__footer {
  margin: 0;
  font-size: 0.9rem;
}

html.tm-html .tm-esquema-pago__modo {
  margin: 0 0 0.75rem;
}

html.tm-html .tm-esquema-pago__modo-label {
  display: block;
  margin: 0 0 6px;
  font-size: 12px;
  font-weight: 800;
  color: var(--muted);
  letter-spacing: 0.02em;
}

html.tm-html .tm-esquema-pago__modo-select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 2px solid var(--input-border, var(--border));
  background: var(--input-bg, var(--ma-field-surface, #fff));
  color: var(--ink);
  font-size: 14px;
  font-weight: 700;
  font-family: inherit;
  outline: none;
  cursor: pointer;
}

html.tm-html .tm-esquema-pago__modo .helper-text {
  display: block;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.35;
  color: var(--muted);
}

html.tm-html .tm-esquema-pago__opcion {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 12px;
  width: 100%;
  box-sizing: border-box;
  padding: 14px 16px;
  margin: 0;
  border-radius: 16px;
  border: 2px solid var(--input-border, var(--border));
  background: color-mix(in srgb, var(--ink) 4%, transparent);
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease;
}

html.tm-html .tm-esquema-pago__opcion:has(input:checked) {
  border-color: color-mix(in srgb, var(--tm-prog-primary, #8b5cf6) 55%, var(--border));
  background: color-mix(in srgb, var(--tm-prog-primary, #8b5cf6) 10%, transparent);
}

html.tm-html .tm-esquema-pago__opcion input[type="radio"] {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: var(--tm-prog-primary, #8b5cf6);
}

html.tm-html .tm-esquema-pago__opcion .label-text {
  flex: 1;
  min-width: 0;
  margin: 0;
  color: var(--ink);
  overflow-wrap: anywhere;
  word-break: break-word;
}

html.tm-html .tm-esquema-pago__opcion .label-text strong {
  color: inherit;
  font-weight: 900;
}

/* Tridente — filas checkbox (términos, imagen): checkbox alineado a la 1.ª línea */
html.tm-html.tm-prog-misamores .card .checkRow,
html.tm-html.tm-prog-talentos .card .checkRow,
html.tm-html.tm-prog-encanto .card .checkRow {
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
}

html.tm-html.tm-prog-misamores .ndGrid .checkRow,
html.tm-html.tm-prog-talentos .ndGrid .checkRow,
html.tm-html.tm-prog-encanto .ndGrid .checkRow {
  align-items: center;
  padding: 10px 14px;
  gap: 8px;
}

html.tm-html.tm-prog-misamores .card .checkRow input[type="checkbox"],
html.tm-html.tm-prog-talentos .card .checkRow input[type="checkbox"],
html.tm-html.tm-prog-encanto .card .checkRow input[type="checkbox"] {
  width: 20px;
  height: 20px;
  min-width: 20px;
  margin: 3px 0 0;
  flex-shrink: 0;
  cursor: pointer;
}

html.tm-html.tm-prog-misamores .card .checkRow > .label-text,
html.tm-html.tm-prog-talentos .card .checkRow > .label-text,
html.tm-html.tm-prog-encanto .card .checkRow > .label-text {
  flex: 1;
  min-width: 0;
  margin: 0;
  line-height: 1.45;
  text-wrap: pretty;
}

html.tm-html.tm-prog-misamores .card .checkRow .label-text a,
html.tm-html.tm-prog-talentos .card .checkRow .label-text a,
html.tm-html.tm-prog-encanto .card .checkRow .label-text a {
  white-space: nowrap;
}

html.tm-html.tm-prog-misamores .card .checkRow .label-text .tm-terms-program,
html.tm-html.tm-prog-talentos .card .checkRow .label-text .tm-terms-program,
html.tm-html.tm-prog-encanto .card .checkRow .label-text .tm-terms-program {
  white-space: nowrap;
}

html.tm-html.tm-prog-misamores .card .checkRow .label-text .helper-text,
html.tm-html.tm-prog-talentos .card .checkRow .label-text .helper-text,
html.tm-html.tm-prog-encanto .card .checkRow .label-text .helper-text {
  display: block;
  margin-top: 8px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--muted);
}

/* Tridente: selects nativos legibles (oscuro) */
html.tm-html.tm-prog-talentos select option {
  background: #1c1240;
  color: var(--talentos-ink);
}

html.tm-html.tm-prog-encanto select option {
  background: #1e1612;
  color: var(--encanto-cream);
}

html.tm-html.tm-prog-encanto .card label,
html.tm-html.tm-prog-misamores .card label {
  color: var(--muted);
}

html.tm-html.tm-prog-encanto .label-text,
html.tm-html.tm-prog-misamores .label-text,
html.tm-html.tm-prog-encanto .ndGrid .checkRow label,
html.tm-html.tm-prog-misamores .ndGrid .checkRow label {
  color: var(--ink);
}

html.tm-html button.tm-link-precios {
  max-width: 100%;
  white-space: normal;
  text-wrap: balance;
}

/* Tridente: cabecera de formulario, badge de paso, botones informativos */
html.tm-html .tm-form-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

html.tm-html .tm-step-badge {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.15;
  font-weight: 900;
  font-size: 10px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 8px 11px;
  border-radius: 14px;
  min-width: 4.25rem;
}

html.tm-html .tm-step-badge-line {
  display: block;
}

html.tm-html .tm-step-badge-num {
  white-space: nowrap;
  font-size: 12px;
  text-transform: none;
  letter-spacing: 0;
  margin-top: 2px;
}

html.tm-html.tm-prog-misamores .tm-step-badge {
  color: var(--dipav-purple);
  background: rgba(221, 150, 175, 0.15);
}

html.tm-html.tm-prog-encanto .tm-step-badge {
  color: #fff;
  background: linear-gradient(135deg, var(--encanto-red), var(--encanto-brown));
}

html.tm-html.tm-prog-talentos .tm-step-badge {
  color: #fff;
  background: var(--dipav-purple);
}

html.tm-html .tm-under-meta-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}

html.tm-html .tm-under-meta-btn {
  font-size: 12px !important;
  padding: 12px 14px !important;
  line-height: 1.35 !important;
  text-align: center;
  white-space: normal !important;
  overflow-wrap: break-word;
  word-break: normal;
  hyphens: manual;
  text-wrap: balance;
  min-height: 44px !important;
  box-sizing: border-box !important;
  align-items: center !important;
  display: inline-flex !important;
  justify-content: center !important;
}

/* Nota bajo precio mensual (tridente): mismo tamaño en desktop / tablet / móvil */
html.tm-html.tm-prog-misamores .card .meta .v .tm-meta-mensual-nota,
html.tm-html.tm-prog-talentos .card .meta .v .tm-meta-mensual-nota,
html.tm-html.tm-prog-encanto .card .meta .v .tm-meta-mensual-nota {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.35;
  opacity: 0.82;
}

html.tm-html.tm-prog-misamores .card .meta .v .tm-meta-mensual-nota {
  color: var(--muted);
  opacity: 0.88;
}

html.tm-html.tm-prog-encanto .card .meta .v .tm-meta-mensual-nota {
  color: color-mix(in srgb, var(--encanto-gold-soft) 72%, var(--muted));
  opacity: 1;
}

/* Rejilla meta: auto-fit (tablet) + 2 cols en ancho medio; 1 col la define cada landing ≤640px */
html.tm-html.tm-prog-misamores main.grid > .card .metaGrid,
html.tm-html.tm-prog-talentos main.grid > .card .metaGrid,
html.tm-html.tm-prog-encanto main.grid > .card .metaGrid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 168px), 1fr));
}

@media (min-width: 641px) and (max-width: 900px) {
  html.tm-html.tm-prog-misamores main.grid > .card .metaGrid,
  html.tm-html.tm-prog-talentos main.grid > .card .metaGrid,
  html.tm-html.tm-prog-encanto main.grid > .card .metaGrid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

html.tm-html.tm-prog-misamores main.grid > .card .meta:hover {
  border-color: var(--dipav-purple);
}

html.tm-html.tm-prog-talentos main.grid > .card .meta:hover {
  border-color: color-mix(in srgb, var(--dipav-purple) 55%, var(--border));
}

html.tm-html.tm-prog-encanto main.grid > .card .meta:hover {
  border-color: color-mix(in srgb, var(--encanto-brown) 50%, var(--border));
}

html.tm-html.tm-prog-talentos .subtitle strong {
  color: #a78bfa;
}

html.tm-html.tm-prog-encanto .progressBar {
  background: linear-gradient(90deg, var(--encanto-red), var(--encanto-brown));
}

html.tm-html.tm-prog-talentos .progressBar {
  background: linear-gradient(90deg, var(--dipav-purple), var(--dipav-blue));
}

html.tm-html.tm-prog-misamores .checkRow:focus-within,
html.tm-html.tm-prog-talentos .checkRow:focus-within {
  outline: 2px solid color-mix(in srgb, var(--dipav-blue) 70%, transparent);
  outline-offset: 2px;
}

html.tm-html.tm-prog-encanto .checkRow:focus-within {
  outline: 2px solid color-mix(in srgb, var(--encanto-brown) 75%, transparent);
  outline-offset: 2px;
}

@media (max-width: 900px) {
  html.tm-html.tm-prog-dipav header,
  html.tm-html.tm-prog-encanto header,
  html.tm-html.tm-prog-misamores header,
  html.tm-html.tm-prog-talentos header {
    padding: 0.75rem 1rem;
  }
}

@media (min-width: 768px) and (max-width: 900px) {
  html.tm-html.tm-prog-dipav header,
  html.tm-html.tm-prog-encanto header,
  html.tm-html.tm-prog-misamores header,
  html.tm-html.tm-prog-talentos header {
    padding: 0.85rem 1.25rem;
  }
}

@media (max-width: 640px) {
  html.tm-html.tm-prog-encanto body > .wrap,
  html.tm-html.tm-prog-talentos body > .wrap {
    padding: 16px 14px 32px;
  }

  html.tm-html.tm-prog-encanto .cardInner,
  html.tm-html.tm-prog-talentos .cardInner {
    padding: 22px 18px 28px;
  }

  html.tm-html.tm-prog-encanto .title,
  html.tm-html.tm-prog-talentos .title {
    font-size: clamp(26px, 6vw, 34px);
  }
}

html.tm-html .tm-step-actions {
  display: flex;
  justify-content: space-between;
  margin-top: 20px;
  gap: 10px;
}

html.tm-html .tm-step-actions.tm-step-actions--end {
  justify-content: flex-end;
}

@media (max-width: 520px) {
  html.tm-html .tm-under-meta-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  html.tm-html .tm-form-header {
    flex-direction: column;
    align-items: stretch;
  }

  html.tm-html .tm-step-badge {
    align-self: flex-start;
  }

  html.tm-html .tm-step-actions {
    flex-direction: column-reverse;
  }

  html.tm-html .tm-step-actions .btn {
    width: 100%;
  }
}

/* Modal de precios (compartido; colores por programa en el panel) */
html.tm-html .tm-precios-modal .tm-landing-precios-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 12px;
  font-size: 13px;
}

html.tm-html .tm-precios-modal .tm-landing-precios-table th,
html.tm-html .tm-precios-modal .tm-landing-precios-table td {
  padding: 10px 8px;
  text-align: left;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

html.tm-html .tm-precios-modal .tm-landing-precios-note {
  font-size: 12px;
  line-height: 1.5;
  margin: 14px 0 0;
  text-align: center;
  opacity: 0.9;
}

html.tm-html.tm-prog-misamores .tm-precios-modal .tm-landing-precios-note {
  color: var(--muted);
}

html.tm-html.tm-prog-talentos .tm-precios-modal .tm-landing-precios-note,
html.tm-html.tm-prog-encanto .tm-precios-modal .tm-landing-precios-note {
  color: rgba(255, 255, 255, 0.72);
}

html.tm-html.tm-prog-misamores .tm-precios-modal .modal-content {
  background: linear-gradient(165deg, #ffffff 0%, #faf6f4 100%);
  border-color: rgba(221, 150, 175, 0.45);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores .tm-precios-modal .tm-precios-modal-title {
  color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores .tm-precios-modal .tm-landing-precios-table th,
html.tm-html.tm-prog-misamores .tm-precios-modal .tm-landing-precios-table td {
  color: var(--ink);
  border-bottom-color: rgba(221, 150, 175, 0.22);
}

html.tm-html.tm-prog-misamores .tm-precios-modal .tm-precios-membresia-box {
  background: rgba(221, 150, 175, 0.12);
  border-color: rgba(54, 201, 203, 0.35);
}

html.tm-html.tm-prog-misamores .tm-precios-modal .tm-precios-membresia-val {
  color: var(--dipav-purple);
}

html.tm-html.tm-prog-encanto .tm-precios-modal .modal-content {
  border-color: rgba(200, 129, 34, 0.4);
}

html.tm-html.tm-prog-talentos .tm-precios-modal .modal-content {
  border-color: rgba(125, 66, 233, 0.35);
}

html.tm-html.tm-prog-encanto .tm-precios-modal .tm-precios-membresia-val {
  color: #fca5a5;
}

html.tm-html.tm-prog-talentos .tm-precios-modal .tm-precios-membresia-val {
  color: #e9d5ff;
}

html.tm-html.tm-prog-talentos .tm-precios-modal .tm-landing-precios-table th,
html.tm-html.tm-prog-talentos .tm-precios-modal .tm-landing-precios-table td,
html.tm-html.tm-prog-encanto .tm-precios-modal .tm-landing-precios-table th,
html.tm-html.tm-prog-encanto .tm-precios-modal .tm-landing-precios-table td {
  color: rgba(255, 255, 255, 0.9);
  border-bottom-color: rgba(255, 255, 255, 0.08);
}

/* Modales informativos Mis Amores (fondo claro = acorde al programa) */
html.tm-html.tm-prog-misamores .modal-overlay:not(.tm-precios-modal) .modal-content {
  background: linear-gradient(165deg, #ffffff 0%, #faf6f4 100%);
  border: 1px solid rgba(221, 150, 175, 0.4);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores .ma-modal-title {
  color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores .ma-modal-lead,
html.tm-html.tm-prog-misamores .ma-modal-list,
html.tm-html.tm-prog-misamores .ma-modal-instruments {
  color: var(--ink);
}

html.tm-html.tm-prog-misamores .ma-tech-list li {
  color: var(--ink);
  border-color: rgba(221, 150, 175, 0.28);
  background: rgba(221, 150, 175, 0.08);
}

html.tm-html.tm-prog-misamores .modal-overlay:not(.tm-precios-modal) .close-modal {
  background: rgba(221, 150, 175, 0.2);
  color: var(--ink);
}

html.tm-html.tm-prog-misamores .modal-overlay:not(.tm-precios-modal) .close-modal:hover {
  background: var(--dipav-purple);
  color: #fff;
}

/* Tridente: modal de precios — tarjetas (diseño unificado; referencia Mis Amores) */
html.tm-html .tm-precios-modal.tm-precios-sheet .modal-content.tm-precios-panel {
  max-width: 440px;
  padding: 24px 20px 22px;
}

html.tm-html .tm-precios-modal-title {
  text-align: center;
  padding-right: 28px;
  margin: 0 0 10px;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: -0.02em;
}

html.tm-html .tm-precios-lead {
  text-align: center;
  font-size: 14px;
  line-height: 1.5;
  margin: 0 0 14px;
}

html.tm-html .tm-precios-highlight {
  font-weight: 900;
}

html.tm-html .tm-precios-membresia {
  text-align: center;
  padding: 16px;
  border-radius: 18px;
  margin-bottom: 16px;
}

html.tm-html .tm-precios-membresia-k {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  margin-bottom: 6px;
}

html.tm-html .tm-precios-membresia-v {
  font-size: 1.35rem;
  font-weight: 900;
}

html.tm-html .tm-precios-section-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 10px;
}

html.tm-html .tm-precios-rates {
  display: grid;
  gap: 10px;
}

html.tm-html .tm-precios-rate-card {
  border-radius: 16px;
  padding: 14px;
}

html.tm-html .tm-precios-rate-name {
  margin: 0 0 10px;
  font-size: 15px;
  font-weight: 900;
}

html.tm-html .tm-precios-rate-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

html.tm-html .tm-precios-rate-col {
  border-radius: 12px;
  padding: 10px;
}

html.tm-html .tm-precios-rate-k {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 800;
  margin-bottom: 4px;
}

html.tm-html .tm-precios-rate-v {
  display: block;
  font-size: 15px;
  font-weight: 900;
}

/* Mis Amores — panel claro */
html.tm-html.tm-prog-misamores .tm-precios-modal-title {
  color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores .tm-precios-lead {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores .tm-precios-highlight {
  color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores .tm-precios-membresia {
  background: rgba(221, 150, 175, 0.12);
  border: 1px solid rgba(54, 201, 203, 0.35);
}

html.tm-html.tm-prog-misamores .tm-precios-membresia-k {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores .tm-precios-membresia-v {
  color: var(--dipav-purple);
}

html.tm-html.tm-prog-misamores .tm-precios-section-label {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-card {
  background: #fff;
  border: 1px solid rgba(221, 150, 175, 0.28);
  box-shadow: 0 6px 16px rgba(42, 69, 73, 0.05);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-name {
  color: var(--dipav-blue);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-col {
  background: rgba(42, 69, 73, 0.04);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-col--miembro {
  background: linear-gradient(145deg, rgba(221, 150, 175, 0.14), rgba(54, 201, 203, 0.12));
  border: 1px solid rgba(54, 201, 203, 0.25);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-k {
  color: var(--muted);
}

html.tm-html.tm-prog-misamores .tm-precios-rate-v {
  color: var(--ink);
}

/* Talentos — panel oscuro morado */
html.tm-html.tm-prog-talentos .tm-precios-modal-title {
  color: #fff;
}

html.tm-html.tm-prog-talentos .tm-precios-lead {
  color: rgba(255, 255, 255, 0.72);
}

html.tm-html.tm-prog-talentos .tm-precios-highlight {
  color: #67ddd0;
}

html.tm-html.tm-prog-talentos .tm-precios-membresia {
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(125, 66, 233, 0.35);
}

html.tm-html.tm-prog-talentos .tm-precios-membresia-k {
  color: rgba(255, 255, 255, 0.55);
}

html.tm-html.tm-prog-talentos .tm-precios-membresia-v {
  color: #e9d5ff;
}

html.tm-html.tm-prog-talentos .tm-precios-section-label {
  color: rgba(255, 255, 255, 0.5);
}

html.tm-html.tm-prog-talentos .tm-precios-rate-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(125, 66, 233, 0.28);
  box-shadow: none;
}

html.tm-html.tm-prog-talentos .tm-precios-rate-name {
  color: #c4b5fd;
}

html.tm-html.tm-prog-talentos .tm-precios-rate-col {
  background: rgba(0, 0, 0, 0.25);
}

html.tm-html.tm-prog-talentos .tm-precios-rate-col--miembro {
  background: rgba(125, 66, 233, 0.14);
  border: 1px solid rgba(103, 221, 208, 0.28);
}

html.tm-html.tm-prog-talentos .tm-precios-rate-k {
  color: rgba(255, 255, 255, 0.5);
}

html.tm-html.tm-prog-talentos .tm-precios-rate-v {
  color: #fff;
}

/* Encanto — panel oscuro cálido */
html.tm-html.tm-prog-encanto .tm-precios-modal-title {
  color: #fff;
}

html.tm-html.tm-prog-encanto .tm-precios-lead {
  color: rgba(255, 255, 255, 0.72);
}

html.tm-html.tm-prog-encanto .tm-precios-highlight {
  color: var(--encanto-gold);
}

html.tm-html.tm-prog-encanto .tm-precios-membresia {
  background: rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(200, 129, 34, 0.35);
}

html.tm-html.tm-prog-encanto .tm-precios-membresia-k {
  color: rgba(255, 255, 255, 0.55);
}

html.tm-html.tm-prog-encanto .tm-precios-membresia-v {
  color: var(--encanto-gold);
}

html.tm-html.tm-prog-encanto .tm-precios-section-label {
  color: rgba(255, 255, 255, 0.5);
}

html.tm-html.tm-prog-encanto .tm-precios-rate-card {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(200, 129, 34, 0.28);
  box-shadow: none;
}

html.tm-html.tm-prog-encanto .tm-precios-rate-name {
  color: var(--encanto-gold-soft);
}

html.tm-html.tm-prog-encanto .tm-precios-rate-col {
  background: rgba(0, 0, 0, 0.25);
}

html.tm-html.tm-prog-encanto .tm-precios-rate-col--miembro {
  background: rgba(200, 129, 34, 0.12);
  border: 1px solid rgba(225, 29, 72, 0.22);
}

html.tm-html.tm-prog-encanto .tm-precios-rate-k {
  color: rgba(255, 255, 255, 0.5);
}

html.tm-html.tm-prog-encanto .tm-precios-rate-v {
  color: #fff;
}

@media (max-width: 640px) {
  html.tm-html .tm-precios-modal.tm-precios-sheet {
    align-items: flex-end;
    padding: 0;
  }

  html.tm-html.tm-prog-misamores .tm-precios-modal.tm-precios-sheet {
    background: rgba(42, 69, 73, 0.35);
  }

  html.tm-html.tm-prog-talentos .tm-precios-modal.tm-precios-sheet,
  html.tm-html.tm-prog-encanto .tm-precios-modal.tm-precios-sheet {
    background: rgba(10, 8, 12, 0.88);
  }

  html.tm-html .tm-precios-modal.tm-precios-sheet .modal-content.tm-precios-panel {
    max-width: none;
    width: 100%;
    border-radius: 24px 24px 0 0;
    max-height: 88vh;
    padding-bottom: max(22px, env(safe-area-inset-bottom));
  }

  html.tm-html .tm-precios-rate-cols {
    grid-template-columns: 1fr;
  }
}

/* Tridente: galería — proporción y encuadre (evita cortar rostros con height fijo) */
html.tm-html .tm-landing-gallery {
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
}

html.tm-html .tm-landing-gallery .photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

html.tm-html .tm-landing-gallery .ph {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  transition: transform 0.25s ease;
}

html.tm-html .tm-landing-gallery .ph img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 5 / 4;
  object-fit: cover;
  object-position: center 22%;
}

html.tm-html .tm-landing-gallery .ph .cap {
  padding: 12px;
  font-size: 11px;
  font-weight: 800;
  text-align: center;
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-landing-gallery .ph {
  display: flex;
  flex-direction: column;
  background: #fff;
  box-shadow:
    0 1px 0 color-mix(in srgb, var(--tm-brand-mis-amores) 38%, transparent),
    0 12px 32px rgba(42, 69, 73, 0.07);
  border: 1px solid color-mix(in srgb, var(--tm-brand-mis-amores) 32%, rgba(42, 69, 73, 0.1));
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-landing-gallery .ph:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--tm-brand-mis-amores) 48%, rgba(42, 69, 73, 0.12));
  box-shadow:
    0 1px 0 color-mix(in srgb, var(--tm-brand-mis-amores) 52%, transparent),
    0 18px 42px rgba(42, 69, 73, 0.1);
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-landing-gallery .ph img,
html.tm-html.tm-prog-misamores:not([data-theme="light"]) .tm-landing-gallery .ph img {
  flex: 0 0 auto;
}

html.tm-html.tm-prog-misamores[data-theme="light"] .tm-landing-gallery .ph .cap {
  flex: 0 0 auto;
  margin: 0;
  padding: 14px 14px 17px;
  font-size: clamp(12px, 1.05vw, 13px);
  font-weight: 600;
  line-height: 1.42;
  letter-spacing: 0.01em;
  text-align: center;
  text-wrap: balance;
  color: color-mix(in srgb, var(--ink) 90%, var(--tm-brand-mis-amores) 10%);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--tm-brand-mis-amores) 16%, #fff) 0%,
    color-mix(in srgb, var(--tm-brand-mis-amores) 7%, #faf7f6) 100%
  );
  border-top: 1px solid color-mix(in srgb, var(--tm-brand-mis-amores) 42%, transparent);
}

html.tm-html.tm-prog-talentos .tm-landing-gallery .ph {
  display: flex;
  flex-direction: column;
  background: rgba(8, 4, 24, 0.55);
  border: 1px solid color-mix(in srgb, var(--talentos-violet) 34%, transparent);
  box-shadow:
    0 1px 0 color-mix(in srgb, var(--talentos-violet) 28%, transparent),
    var(--shadow-soft);
}

html.tm-html.tm-prog-talentos .tm-landing-gallery .ph:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--talentos-violet) 48%, transparent);
}

html.tm-html.tm-prog-talentos .tm-landing-gallery .ph img {
  flex: 0 0 auto;
}

html.tm-html.tm-prog-talentos .tm-landing-gallery .ph .cap {
  flex: 0 0 auto;
  margin: 0;
  padding: 14px 14px 16px;
  font-size: clamp(12px, 1.05vw, 13px);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.01em;
  text-align: center;
  text-wrap: balance;
  color: var(--talentos-ink);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--talentos-violet) 18%, rgba(8, 4, 24, 0.92)) 0%,
    color-mix(in srgb, var(--talentos-teal) 10%, rgba(8, 4, 24, 0.96)) 100%
  );
  border-top: 1px solid color-mix(in srgb, var(--talentos-violet) 32%, transparent);
}

html.tm-html.tm-prog-encanto .tm-landing-gallery .ph {
  display: flex;
  flex-direction: column;
  background: rgba(20, 14, 10, 0.45);
  border: 1px solid color-mix(in srgb, var(--encanto-brown) 35%, transparent);
}

html.tm-html.tm-prog-encanto .tm-landing-gallery .ph:hover {
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--encanto-gold) 48%, transparent);
}

html.tm-html.tm-prog-encanto .tm-landing-gallery .ph img {
  flex: 0 0 auto;
}

html.tm-html.tm-prog-encanto .tm-landing-gallery .ph .cap {
  flex: 0 0 auto;
  margin: 0;
  padding: 14px 14px 16px;
  font-size: clamp(12px, 1.05vw, 13px);
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: 0.01em;
  text-align: center;
  text-wrap: balance;
  color: var(--encanto-cream);
  background: linear-gradient(
    180deg,
    color-mix(in srgb, var(--encanto-brown) 18%, rgba(20, 14, 10, 0.92)) 0%,
    color-mix(in srgb, var(--encanto-red) 10%, rgba(20, 14, 10, 0.96)) 100%
  );
  border-top: 1px solid color-mix(in srgb, var(--encanto-brown) 32%, transparent);
}

@media (max-width: 980px) {
  html.tm-html .tm-landing-gallery .photos {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  html.tm-html .tm-landing-gallery .ph img {
    aspect-ratio: 4 / 3;
    object-position: center 18%;
  }
}

/* Encanto: UX visual — calidez y jerarquía sin perder identidad */
html.tm-html.tm-prog-encanto .title {
  background: linear-gradient(
    118deg,
    #fff8ef 0%,
    var(--encanto-gold) 38%,
    #f0d4b8 72%,
    var(--encanto-cream) 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html.tm-html.tm-prog-encanto .subtitle {
  color: color-mix(in srgb, var(--encanto-rose-soft) 55%, var(--muted));
}

html.tm-html.tm-prog-encanto .subtitle strong {
  color: var(--encanto-gold);
  font-weight: 800;
}

html.tm-html.tm-prog-encanto .meta:hover {
  border-color: color-mix(in srgb, var(--encanto-gold) 55%, var(--border));
  background: rgba(212, 168, 92, 0.11);
}

html.tm-html.tm-prog-encanto .note {
  border-color: color-mix(in srgb, var(--encanto-brown) 40%, transparent);
  background: rgba(212, 168, 92, 0.1);
  color: var(--ink);
}

html.tm-html.tm-prog-encanto .btnPrimary {
  background: linear-gradient(135deg, #d4a054 0%, #b45309 40%, var(--encanto-red) 100%);
  box-shadow: 0 8px 24px rgba(196, 30, 58, 0.22), 0 4px 12px rgba(212, 168, 92, 0.18);
}

html.tm-html.tm-prog-encanto .btnPrimary:hover:not(:disabled) {
  box-shadow: 0 12px 28px rgba(196, 30, 58, 0.28), 0 6px 16px rgba(212, 168, 92, 0.22);
}

html.tm-html.tm-prog-encanto .btnSecondary {
  background: rgba(255, 248, 240, 0.07);
  border-color: color-mix(in srgb, var(--encanto-brown) 48%, transparent);
  color: var(--ink);
}

html.tm-html.tm-prog-encanto .btnSecondary:hover {
  background: rgba(212, 168, 92, 0.14);
  border-color: var(--encanto-gold-soft);
  color: #fff;
}

html.tm-html.tm-prog-encanto .progressBar {
  background: linear-gradient(90deg, var(--encanto-brown), var(--encanto-red));
}

html.tm-html.tm-prog-encanto .progressTrack {
  background: rgba(255, 248, 240, 0.1);
}

html.tm-html.tm-prog-encanto .checkRow:has(input:checked) {
  border-color: var(--encanto-gold-soft);
  background: rgba(212, 168, 92, 0.12);
}

html.tm-html.tm-prog-encanto .checkRow input[type="checkbox"] {
  accent-color: var(--encanto-gold);
}

html.tm-html.tm-prog-encanto #termsLink {
  color: var(--encanto-gold-soft);
}

html.tm-html.tm-prog-encanto #termsLink:hover {
  color: var(--encanto-rose-soft);
}

html.tm-html.tm-prog-encanto .tm-step-badge {
  background: linear-gradient(145deg, #9a3412, var(--encanto-brown));
  color: #fff;
  box-shadow: 0 2px 8px rgba(8, 5, 4, 0.25);
}

html.tm-html.tm-prog-encanto a {
  color: var(--encanto-gold-soft);
}

html.tm-html.tm-prog-encanto a:hover {
  color: var(--encanto-rose-soft);
}

/* Talentos: UX visual — púrpura DIPAV + acento turquesa (misma jerarquía que Encanto) */
html.tm-html.tm-prog-talentos .title {
  background: linear-gradient(
    118deg,
    #fefce8 0%,
    var(--talentos-violet-soft) 38%,
    var(--talentos-violet) 62%,
    var(--talentos-teal) 100%
  );
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

html.tm-html.tm-prog-talentos .subtitle {
  color: var(--talentos-violet-soft);
  font-weight: 600;
}

html.tm-html.tm-prog-talentos .subtitle strong {
  color: var(--talentos-teal);
  font-weight: 800;
}

html.tm-html.tm-prog-talentos .meta:hover {
  border-color: color-mix(in srgb, var(--talentos-violet) 60%, var(--border));
  background: rgba(139, 92, 246, 0.1);
}

html.tm-html.tm-prog-talentos .note {
  border: 1px solid rgba(139, 92, 246, 0.28);
  background: rgba(139, 92, 246, 0.1);
  color: var(--talentos-violet-soft);
}

html.tm-html.tm-prog-talentos .btnPrimary {
  background: linear-gradient(135deg, var(--talentos-violet) 0%, #6d28d9 50%, var(--talentos-teal) 100%);
  box-shadow:
    0 8px 24px rgba(139, 92, 246, 0.32),
    0 4px 12px rgba(94, 234, 212, 0.16);
}

html.tm-html.tm-prog-talentos .btnPrimary:hover:not(:disabled) {
  box-shadow:
    0 12px 30px rgba(139, 92, 246, 0.4),
    0 6px 16px rgba(94, 234, 212, 0.22);
}

html.tm-html.tm-prog-talentos .btnSecondary {
  background: rgba(167, 139, 250, 0.1);
  border: 1px solid color-mix(in srgb, var(--talentos-violet) 38%, transparent);
  color: #fff;
}

html.tm-html.tm-prog-talentos .btnSecondary:hover {
  background: rgba(167, 139, 250, 0.18);
  border-color: var(--talentos-violet);
}

html.tm-html.tm-prog-talentos .progressBar {
  background: linear-gradient(90deg, var(--talentos-violet), var(--talentos-teal));
}

html.tm-html.tm-prog-talentos .progressTrack {
  background: rgba(167, 139, 250, 0.1);
}

html.tm-html.tm-prog-talentos .checkRow:has(input:checked) {
  border-color: var(--talentos-violet);
  background: rgba(139, 92, 246, 0.1);
}

html.tm-html.tm-prog-talentos .checkRow input[type="checkbox"] {
  accent-color: var(--talentos-violet);
}

html.tm-html.tm-prog-talentos #termsLink {
  color: var(--talentos-teal-soft);
}

html.tm-html.tm-prog-talentos #termsLink:hover {
  color: var(--talentos-violet-soft);
}

html.tm-html.tm-prog-talentos a {
  color: var(--talentos-teal-soft);
}

html.tm-html.tm-prog-talentos a:hover {
  color: var(--talentos-violet-soft);
}

html.tm-html.tm-prog-talentos .card input:focus,
html.tm-html.tm-prog-talentos .card select:focus,
html.tm-html.tm-prog-talentos .card textarea:focus {
  border-color: var(--talentos-violet);
  background: rgba(8, 4, 24, 0.55);
  box-shadow: 0 0 0 4px rgba(139, 92, 246, 0.18);
}

html.tm-html.tm-prog-encanto input:focus,
html.tm-html.tm-prog-encanto select:focus,
html.tm-html.tm-prog-encanto textarea:focus {
  border-color: var(--encanto-gold-soft);
  background: rgba(12, 8, 6, 0.42);
  box-shadow: 0 0 0 4px rgba(212, 168, 92, 0.2);
}

html.tm-html.tm-prog-talentos .card a:not(#termsLink) {
  color: var(--talentos-teal-soft);
}

html.tm-html.tm-prog-talentos .card a:hover {
  color: #a5f3fc;
}

html.tm-html.tm-prog-talentos .tal-nd-block {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

html.tm-html.tm-prog-talentos .card label {
  color: var(--muted);
}

html.tm-html.tm-prog-talentos .helper-text {
  color: color-mix(in srgb, var(--muted) 88%, transparent);
}

html.tm-html.tm-prog-talentos .tal-nd-lead {
  font-size: 11px;
  color: var(--muted);
  margin: 4px 0 10px;
  line-height: 1.35;
  font-weight: 600;
}

html.tm-html.tm-prog-talentos .nd-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-top: 8px;
}

html.tm-html.tm-prog-talentos .nd-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: border-color 0.2s ease, background 0.2s ease;
}

html.tm-html.tm-prog-talentos .nd-card:hover {
  background: rgba(255, 255, 255, 0.06);
}

html.tm-html.tm-prog-talentos .nd-card:has(input:checked) {
  border-color: var(--talentos-violet);
  background: rgba(139, 92, 246, 0.12);
}

html.tm-html.tm-prog-talentos .nd-card input {
  width: 16px;
  height: 16px;
  margin: 0;
  cursor: pointer;
  accent-color: var(--talentos-violet);
}

html.tm-html.tm-prog-talentos .nd-card label {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  cursor: pointer;
  flex-grow: 1;
}

html.tm-html.tm-prog-talentos #nd-otro-box {
  display: none;
  margin-top: 10px;
}

html.tm-html.tm-prog-talentos #nd-otro-box.show {
  display: block;
  animation: tmTalNdFade 0.3s ease;
}

@keyframes tmTalNdFade {
  from {
    opacity: 0;
    transform: translateY(-5px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

html.tm-html.tm-prog-talentos .tal-success-box {
  display: none;
  margin-top: 20px;
  padding: 24px;
  text-align: center;
  background: rgba(103, 221, 208, 0.12);
  border: 1px solid rgba(125, 66, 233, 0.28);
  border-radius: 18px;
}

html.tm-html.tm-prog-talentos .tal-success-box h3 {
  margin: 0 0 10px;
  font-size: 20px;
  font-weight: 900;
  color: #fff;
}

html.tm-html.tm-prog-talentos .tal-success-box p {
  font-size: 14px;
  margin: 0 0 20px;
  color: rgba(255, 255, 255, 0.8);
}

/* ─── Index: Ruta de aprendizaje — colores oficiales por programa (claro y oscuro) ─── */
#comparacion .progPathCard[data-prog="misamores"] {
  --path-primary: var(--tm-brand-mis-amores);
  --path-secondary: var(--tm-path-misamores-secondary);
}

#comparacion .progPathCard[data-prog="talentos"] {
  --path-primary: var(--tm-brand-talentos);
  --path-secondary: var(--tm-path-talentos-secondary);
}

#comparacion .progPathCard[data-prog="encanto"] {
  --path-primary: var(--tm-brand-encanto);
  --path-secondary: var(--tm-path-encanto-secondary);
}

#comparacion .progPathCard[data-prog="dipav"] {
  --path-primary: var(--tm-path-dipav-primary);
  --path-secondary: var(--tm-path-dipav-secondary);
}

#comparacion .progPathStep {
  background: linear-gradient(
    135deg,
    var(--path-primary, var(--accent)) 0%,
    var(--path-secondary, var(--muted)) 100%
  );
  color: #fff;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--path-primary, var(--accent)) 35%, transparent);
}

#comparacion .comparePill {
  background: color-mix(in srgb, var(--path-primary, var(--accent)) 12%, transparent);
  color: var(--path-primary, var(--accent));
  border-color: color-mix(in srgb, var(--path-primary, var(--accent)) 32%, transparent);
}

#comparacion .progPathDl dt {
  color: var(--path-secondary, var(--muted));
}

#comparacion .compareLink {
  color: var(--path-primary, var(--accent));
}

#comparacion .compareLink:hover {
  color: var(--path-secondary, var(--text));
}
