/**
 * single-sfwd-courses · Layout Curso NO Miembro
 *
 * Tokens DS UXDivi + estilos del template del curso para visitantes y
 * usuarios sin plan suscriptor. Scope: `body.uxdivi-frontend--curso-no-miembro
 * .ux-curso.ux-curso--no-miembro`.
 *
 * Fuente de verdad: rediseno/Layout Curso No Miembro.html
 * Generado por tools/regen-curso-no-miembro.py
 */

  /* ============ Course page specific ============ */

  /* Breadcrumbs */
  .crumbs { font-family: var(--mono); font-size: 12px; color: var(--ink-4); letter-spacing: 0.04em; margin-bottom: 22px; }
  .crumbs a { color: var(--ink-3); }
  .crumbs a:hover { color: var(--cyan); }
  .crumbs .sep { margin: 0 8px; opacity: 0.5; }

  /* Hero stacked */
  .hero.course { padding: 56px 0 72px; text-align: center; }
  .hero.course .hero-pill { margin-bottom: 24px; }
  /* Tipografía global de títulos h1/h2/h3 · weight 700 + Bricolage Grotesque
     forzado contra Divi/Woo (decisión Jefferson 2026-05-15). H1 y H2 con
     degradado ink→cyan. H3 solo con weight bold (sin degradado para no
     restar contraste en tarjetas y bloques de detalle). */
  body.uxdivi-frontend--curso-no-miembro h1,
  body.uxdivi-frontend--curso-no-miembro h2,
  body.uxdivi-frontend--curso-no-miembro h3,
  body.uxdivi-frontend--curso-no-miembro h4 {
    font-family: var(--display) !important;
    font-weight: 700 !important;
  }
  body.uxdivi-frontend--curso-no-miembro h2 {
    background: linear-gradient(120deg, var(--ink) 0%, var(--cyan) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
  }

  /* Hero H1 · specificity alta + !important para ganar contra reglas
     `h2, h3, ... { font-weight: 400 }` de Divi/Woo + degradado ink→cyan
     via background-clip:text (decisión Jefferson 2026-05-15 · mismo
     patrón validado en Layout Curso Miembro). */
  body.uxdivi-frontend--curso-no-miembro main.ux-curso section.hero.course h1,
  body.uxdivi-frontend--curso-no-miembro .hero.course h1 {
    font-family: var(--display) !important;
    font-size: clamp(40px, 5.2vw, 64px) !important;
    font-weight: 700 !important;
    line-height: 1.04 !important;
    letter-spacing: -0.03em !important;
    max-width: 960px;
    margin-left: auto !important;
    margin-right: auto !important;
    background: linear-gradient(120deg, var(--ink) 0%, var(--cyan) 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
  }
  .hero.course .hero-sub { max-width: 820px; font-size: 18px; margin-top: 20px; }
  .stats-bar {
    margin: 36px auto 0;
    display: inline-flex; flex-wrap: wrap; gap: 0;
    padding: 10px 4px; border-radius: 999px;
    border: 1px solid var(--line-2);
    background: rgba(255,255,255,0.02);
    font-size: 13px; color: var(--ink-2);
  }
  .stats-bar .s {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 18px;
    border-right: 1px solid var(--line-2);
  }
  .stats-bar .s:last-child { border-right: none; }
  .stats-bar .s b { color: var(--ink); font-weight: 600; }
  .stats-bar .s .ico { color: var(--cyan); display: inline-grid; place-items: center; }

  /* Video demo · sin borde (decisión Jefferson 2026-05-15) */
  .video-frame {
    margin-top: 42px;
    position: relative;
    border-radius: 20px; overflow: hidden;
    border: 0;
    background: var(--surface);
    box-shadow: 0 40px 100px -30px rgba(1,77,253,0.55);
    aspect-ratio: 16 / 9;
    cursor: pointer;
  }
  .video-frame .thumb {
    position: absolute; inset: 0;
    background:
      radial-gradient(600px 300px at 50% 40%, rgba(1,77,253,0.4), transparent 60%),
      linear-gradient(180deg, #0A0F1E, #040814);
  }
  .video-frame .thumb::after {
    content: ""; position: absolute; inset: 0;
    background:
      repeating-linear-gradient(90deg, rgba(98,229,255,0.06) 0 1px, transparent 1px 60px),
      repeating-linear-gradient(0deg,  rgba(98,229,255,0.06) 0 1px, transparent 1px 60px);
  }
  .video-frame .thumb img { width: 100%; height: 100%; object-fit: cover; }
  .video-frame .play {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 96px; height: 96px; border-radius: 50%;
    background: linear-gradient(180deg, #8CEEFF, #62E5FF);
    display: grid; place-items: center; color: #001a2a;
    box-shadow: 0 20px 50px -10px rgba(98,229,255,0.5), 0 0 0 6px rgba(98,229,255,0.15);
    transition: transform .2s ease;
  }
  .video-frame:hover .play { transform: translate(-50%, -50%) scale(1.06); }
  .video-frame .duration {
    position: absolute; bottom: 16px; right: 16px;
    padding: 4px 10px; border-radius: 6px;
    background: rgba(0,0,0,0.7); color: #fff;
    font-family: var(--mono); font-size: 12px;
  }
  .video-frame .caption {
    position: absolute; bottom: 16px; left: 16px;
    padding: 6px 12px; border-radius: 8px;
    background: rgba(10,15,30,0.75); backdrop-filter: blur(8px);
    border: 1px solid var(--line-2);
    color: var(--ink-2); font-size: 13px;
  }
  .video-frame .badge-free {
    position: absolute; top: 16px; left: 16px;
    padding: 6px 12px; border-radius: 999px;
    background: linear-gradient(180deg, #8CEEFF, #62E5FF);
    color: #001a2a; font-family: var(--mono); font-size: 11px; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    box-shadow: 0 10px 24px -8px rgba(98,229,255,0.5);
  }

  .hero-microtrust { margin-top: 20px; font-size: 13px; color: var(--ink-3); }
  .hero-microtrust b { color: var(--ink); }

  /* Sticky CTA bar */
  .sticky-cta {
    position: fixed; top: 0; left: 0; right: 0; z-index: 60;
    padding: 12px 0;
    background: rgba(7,12,28,0.85); backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(98,229,255,0.18);
    transform: translateY(-110%);
    transition: transform .3s ease;
  }
  .sticky-cta.show { transform: translateY(0); }
  .sticky-cta .inner { display: flex; align-items: center; gap: 20px; justify-content: space-between; }
  .sticky-cta .lhs { display: flex; align-items: center; gap: 14px; }
  .sticky-cta .mini-thumb { width: 52px; height: 32px; border-radius: 6px; overflow: hidden; flex-shrink: 0; }
  .sticky-cta .mini-thumb img { width: 100%; height: 100%; object-fit: cover; }
  .sticky-cta .t { font-size: 14px; color: var(--ink); font-weight: 500; }
  .sticky-cta .t small { display: block; font-family: var(--mono); font-size: 11px; color: var(--ink-4); margin-top: 2px; }
  .sticky-cta .rhs { display: flex; align-items: center; gap: 16px; }
  .sticky-cta .price-mini { font-family: var(--mono); font-size: 13px; color: var(--ink-2); }
  .sticky-cta .price-mini b { color: var(--cyan); font-weight: 600; }

  /* Outcomes cards */
  .outcomes-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .outcome {
    padding: 28px;
    border-radius: var(--radius-lg);
    border: 1px solid var(--line-2);
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
    position: relative; overflow: hidden;
  }
  .outcome::before {
    content: ""; position: absolute; top: -60px; right: -60px; width: 160px; height: 160px;
    background: radial-gradient(closest-side, rgba(1,77,253,0.18), transparent 70%);
  }
  .outcome .ico {
    width: 48px; height: 48px; border-radius: 12px;
    background: linear-gradient(135deg, rgba(1,77,253,0.25), rgba(98,229,255,0.1));
    border: 1px solid rgba(98,229,255,0.28);
    display: grid; place-items: center; color: var(--cyan);
    margin-bottom: 20px; font-size: 22px;
  }
  .outcome h3 { font-size: 19px; margin-bottom: 10px; line-height: 1.25; }
  .outcome p { font-size: 14px; color: var(--ink-3); line-height: 1.55; }

  /* Learn grid */
  .learn-grid {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px 40px;
    max-width: 960px; margin: 0 auto;
  }
  .learn-item {
    display: grid; grid-template-columns: 24px 1fr; gap: 14px;
    padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.04);
    font-size: 15px; color: var(--ink-2); line-height: 1.55;
  }
  .learn-item .ck {
    width: 22px; height: 22px; border-radius: 50%;
    background: rgba(98,229,255,0.12); color: var(--cyan);
    display: grid; place-items: center; font-size: 11px; font-weight: 700;
    margin-top: 2px;
  }

  /* Preview block */
  .preview-block {
    padding: 56px;
    border-radius: var(--radius-xl);
    background:
      radial-gradient(500px 300px at 0% 0%, rgba(1,77,253,0.22), transparent 60%),
      radial-gradient(400px 300px at 100% 100%, rgba(98,229,255,0.14), transparent 60%),
      linear-gradient(180deg, rgba(15,25,55,0.55), rgba(10,15,30,0.7));
    border: 1px solid rgba(1,77,253,0.3);
  }
  .preview-block .sec-head { margin-bottom: 36px; }
  .preview-block .video-frame { margin-top: 0; }
  .preview-recap { display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center; margin-top: 36px; padding: 24px 28px; border: 1px solid var(--line-2); border-radius: 16px; background: rgba(255,255,255,0.02); }
  .preview-recap h3 { font-size: 20px; margin-bottom: 8px; }
  .preview-recap p { color: var(--ink-3); font-size: 14px; line-height: 1.55; }

  /* Temario (modules/lessons) */
  .modules { display: grid; gap: 10px; max-width: 880px; margin: 0 auto; }
  .module {
    border: 1px solid var(--line-2);
    border-radius: 16px;
    background: var(--surface);
    overflow: hidden;
  }
  .module summary {
    cursor: pointer; list-style: none;
    padding: 20px 26px;
    display: grid; grid-template-columns: 36px 1fr auto auto; gap: 16px; align-items: center;
  }
  .module summary::-webkit-details-marker { display: none; }
  .mod-num {
    width: 36px; height: 36px; border-radius: 10px;
    background: rgba(1,77,253,0.18);
    border: 1px solid rgba(1,77,253,0.4);
    color: var(--cyan);
    display: grid; place-items: center;
    font-family: var(--mono); font-size: 13px; font-weight: 600;
  }
  .mod-info .mod-title { font-size: 16.5px; color: var(--ink); font-weight: 500; }
  .mod-info .mod-meta { font-family: var(--mono); font-size: 11px; color: var(--ink-4); margin-top: 4px; letter-spacing: 0.04em; }
  .mod-dur { font-family: var(--mono); font-size: 12px; color: var(--ink-3); }
  .mod-chev { color: var(--ink-3); transition: transform .2s; }
  .module[open] .mod-chev { transform: rotate(180deg); color: var(--cyan); }

  /* Lesson sin sub-topics · render plano sin <details> ni chevron.
     Hereda border/radius/bg de .module; reemplaza el grid del <summary>. */
  .module--leaf { padding: 20px 26px; display: grid; grid-template-columns: 36px 1fr; gap: 16px; align-items: center; }
  .module--leaf .mod-info .mod-meta { color: var(--cyan); opacity: .85; }

  .lessons { list-style: none; margin: 0; padding: 0 26px 20px 74px; display: grid; gap: 2px; }
  .lesson {
    display: grid; grid-template-columns: 24px 1fr auto auto; gap: 14px; align-items: center;
    padding: 11px 0;
    border-top: 1px solid rgba(255,255,255,0.04);
    font-size: 14px; color: var(--ink-2);
  }
  .lesson:first-child { border-top: none; }
  .lesson .lico {
    width: 22px; height: 22px; border-radius: 50%;
    display: grid; place-items: center; font-size: 10px;
    background: rgba(255,255,255,0.04); color: var(--ink-4);
    border: 1px solid var(--line-2);
  }
  .lesson.free .lico { background: rgba(98,229,255,0.14); color: var(--cyan); border-color: rgba(98,229,255,0.4); }
  .lesson.free .ltitle { color: var(--ink); }
  .lesson .ltag {
    font-family: var(--mono); font-size: 10px; padding: 3px 8px; border-radius: 4px;
    background: rgba(98,229,255,0.14); color: var(--cyan);
    border: 1px solid rgba(98,229,255,0.35);
    letter-spacing: 0.08em; text-transform: uppercase;
  }
  .lesson .ldur { font-family: var(--mono); font-size: 11px; color: var(--ink-4); }
  .temario-foot { text-align: center; margin-top: 32px; }

  /* Para ti / No es para ti */
  .forit-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
    max-width: 1000px; margin: 0 auto;
  }
  .forit-col {
    border: 1px solid var(--line-2);
    border-radius: var(--radius-lg);
    padding: 36px;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  }
  .forit-col.yes { border-color: rgba(98,229,255,0.28); background: linear-gradient(180deg, rgba(98,229,255,0.05), rgba(98,229,255,0.01)); }
  .forit-col h3 { font-size: 22px; margin-bottom: 24px; }
  .forit-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
  .forit-col li { display: grid; grid-template-columns: 22px 1fr; gap: 12px; align-items: flex-start; color: var(--ink-2); font-size: 15px; line-height: 1.5; }
  .forit-col .mark {
    width: 20px; height: 20px; border-radius: 50%;
    display: grid; place-items: center; font-size: 11px; font-weight: 700;
    margin-top: 2px;
  }
  .yes .mark { background: rgba(98,229,255,0.15); color: var(--cyan); border: 1px solid rgba(98,229,255,0.4); }
  .no .mark { background: rgba(255,255,255,0.04); color: var(--ink-4); border: 1px solid var(--line-2); }
  .forit-col.no li { color: var(--ink-3); }

  /* Certificate */
  .cert-wrap {
    display: grid; grid-template-columns: 1.4fr 1fr; gap: 56px; align-items: center;
    max-width: 1280px; margin: 0 auto;
  }
  /* Imagen real del certificado (reemplaza el cert-mock HTML del original).
     Crecido vía grid (1.4fr) sin scale extra para no invadir el copy
     (decisión Jefferson 2026-05-15). justify-self: start lo alinea a la
     izquierda de su columna. */
  .cert-image {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 40px 100px -30px rgba(1,77,253,0.45);
    border: 1px solid rgba(98,229,255,0.2);
    transform: rotate(-1.5deg);
    transform-origin: center left;
    transition: transform .3s ease;
    justify-self: start;
    max-width: 100%;
  }
  .cert-image:hover { transform: rotate(0); }
  .cert-image img { display: block; width: 100%; height: auto; }
  .cert-mock {
    position: relative;
    aspect-ratio: 4 / 3;
    border-radius: 16px;
    background: linear-gradient(180deg, #F7F9FD 0%, #E6EDFB 100%);
    border: 1px solid rgba(98,229,255,0.2);
    box-shadow: 0 40px 100px -30px rgba(1,77,253,0.45);
    padding: 36px;
    color: #0A0F1E;
    display: flex; flex-direction: column;
    transform: rotate(-1.5deg);
    overflow: hidden;
  }
  .cert-mock::before {
    content: ""; position: absolute; inset: 14px; border: 2px solid rgba(1,77,253,0.18); border-radius: 8px; pointer-events: none;
  }
  .cert-mock .cert-head { display: flex; justify-content: space-between; align-items: center; }
  .cert-mock .cert-logo { font-family: var(--display); font-weight: 700; color: #014DFD; letter-spacing: -0.02em; font-size: 18px; }
  .cert-mock .cert-micro { font-family: var(--mono); font-size: 9px; color: #566080; letter-spacing: 0.12em; text-transform: uppercase; }
  .cert-mock .cert-body { flex: 1; display: flex; flex-direction: column; justify-content: center; text-align: center; padding: 18px 0; }
  .cert-mock .cert-body .cert-of { font-family: var(--mono); font-size: 10px; color: #566080; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 12px; }
  .cert-mock .cert-body .cert-name { font-family: var(--display); font-size: 32px; font-weight: 600; color: #0A0F1E; letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 14px; }
  .cert-mock .cert-body .cert-for { font-size: 11px; color: #566080; margin-bottom: 6px; }
  .cert-mock .cert-body .cert-course { font-family: var(--display); font-size: 16px; font-weight: 500; color: #014DFD; }
  .cert-mock .cert-foot { display: flex; justify-content: space-between; align-items: flex-end; font-size: 9px; color: #566080; font-family: var(--mono); letter-spacing: 0.08em; text-transform: uppercase; }
  .cert-mock .cert-sign { font-family: "Bricolage Grotesque", cursive; font-size: 22px; color: #014DFD; font-weight: 500; font-style: italic; transform: rotate(-3deg); line-height: 1; margin-bottom: 2px; }
  .cert-copy h2 { margin-bottom: 16px; }
  .cert-copy p { color: var(--ink-2); font-size: 16px; margin-bottom: 24px; }
  .cert-copy .cert-bullets { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
  .cert-copy .cert-bullets li { display: grid; grid-template-columns: 24px 1fr; gap: 12px; font-size: 14.5px; color: var(--ink-2); align-items: flex-start; }
  .cert-copy .cert-bullets .em { color: var(--cyan); margin-top: 2px; }

  /* Jeff mini */
  .jeff-mini { display: grid; grid-template-columns: 240px 1fr; gap: 40px; align-items: center; max-width: 1000px; margin: 0 auto; }
  .jeff-mini .jph { aspect-ratio: 1; border-radius: 20px; overflow: hidden; border: 1px solid rgba(98,229,255,0.2); box-shadow: 0 20px 60px -20px rgba(1,77,253,0.4); }
  .jeff-mini .jph img { width: 100%; height: 100%; object-fit: cover; }
  .jeff-mini .sub-line { font-family: var(--mono); font-size: 12px; color: var(--cyan); letter-spacing: 0.04em; margin: 8px 0 18px; }
  .jeff-mini h2 { font-size: 30px; margin-bottom: 4px; }
  .jeff-mini p { color: var(--ink-2); font-size: 15px; }
  .jeff-mini .jeff-stats {
    display: flex; gap: 24px; flex-wrap: wrap;
    margin-top: 20px; font-size: 13px; color: var(--ink-3);
  }
  .jeff-mini .jeff-stats b { color: var(--ink); }
  .jeff-mini .more-link { display: inline-block; margin-top: 18px; color: var(--cyan); font-size: 14px; }

  /* Plans (2 cards, access focus) */
  .access-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 24px; max-width: 90%; margin: 0 auto; }

  /* ═══════════════════════════════════════════════════════════
     COURSE-CARD (importado del Catálogo de Cursos) — reemplaza .related-card
     ═══════════════════════════════════════════════════════════ */
  .course-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
  .course-card {
    background: var(--surface);
    border: 1px solid var(--line-2);
    border-radius: 18px;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    cursor: pointer;
  }
  .course-card:hover { transform: translateY(-4px); border-color: rgba(98,229,255,0.35); box-shadow: 0 30px 70px -20px rgba(1,77,253,0.45); }
  .course-card .thumb {
    position: relative; aspect-ratio: 16 / 9; overflow: hidden;
    background: linear-gradient(135deg, #1A2447 0%, #0A0F1E 100%);
  }
  .course-card .thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
  .course-card:hover .thumb img { transform: scale(1.05); }
  .course-card .thumb .badge-row {
    position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; max-width: calc(100% - 24px); flex-wrap: wrap;
  }
  .course-card .body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
  .course-card h3 {
    font-size: 17px; line-height: 1.28; letter-spacing: -0.015em; margin-bottom: 2px;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  }
  .course-card .cc-desc {
    font-size: 13px; color: var(--ink-3); line-height: 1.55;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
    min-height: 40px;
  }
  .course-card .meta-row {
    display: flex; gap: 12px; flex-wrap: wrap;
    padding: 10px 0; border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2);
    margin: 4px 0;
  }
  .course-card .mi { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-3); letter-spacing: 0.04em; }
  .course-card .mi svg { width: 12px; height: 12px; color: var(--cyan); }
  .course-card .foot { display: flex; justify-content: space-between; align-items: center; }
  .course-card .instr { display: flex; align-items: center; gap: 8px; font-size: 12px; color: var(--ink-2); }
  .course-card .instr img { width: 22px; height: 22px; border-radius: 50%; object-fit: cover; border: 1px solid rgba(98,229,255,0.3); }
  .course-card .see { font-family: var(--mono); font-size: 11px; color: var(--cyan); letter-spacing: 0.06em; display: inline-flex; align-items: center; gap: 4px; opacity: 0.8; transition: opacity .2s, transform .2s; }
  .course-card:hover .see { opacity: 1; transform: translateX(2px); }
  /* Badges compartidos */
  .b {
    display: inline-flex; align-items: center; gap: 4px;
    font-family: var(--mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase;
    padding: 4px 8px; border-radius: 999px;
    background: rgba(10,15,30,0.85); backdrop-filter: blur(8px);
    border: 1px solid var(--line-2);
  }
  .b.nuevo { background: linear-gradient(135deg, rgba(1,77,253,0.9), rgba(74,126,255,0.9)); border-color: rgba(255,255,255,0.2); color: #fff; }
  .b.actualizado { background: rgba(98,229,255,0.18); border-color: rgba(98,229,255,0.4); color: var(--cyan); }
  .b.trending { background: linear-gradient(135deg, rgba(255,206,107,0.18), rgba(255,193,59,0.12)); border-color: rgba(255,206,107,0.4); color: #FFCE6B; }
  .b.cat { background: rgba(98,229,255,0.08); border-color: rgba(98,229,255,0.25); color: var(--cyan); }

  /* ═══════════════════════════════════════════════════════════
     SISTEMA FX — atmósferas reutilizables (mismo de Home/Planes)
     ═══════════════════════════════════════════════════════════ */
  .fx-grid {
    position: absolute; inset: 0; pointer-events: none;
    background-image:
      linear-gradient(rgba(98,229,255,0.04) 1px, transparent 1px),
      linear-gradient(90deg, rgba(98,229,255,0.04) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse at center, #000 30%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 70%);
    z-index: 0;
  }
  .fx-blur-shape {
    position: absolute; pointer-events: none;
    border-radius: 50%;
    filter: blur(100px);
    mix-blend-mode: screen;
    z-index: 0;
    animation: uxdivi-float 12s ease-in-out infinite;
  }
  .fx-blur-shape--brand {
    top: 10%; left: 5%;
    width: 500px; height: 500px;
    background: radial-gradient(circle, var(--brand, #014DFD) 0%, transparent 70%);
    opacity: 0.6;
  }
  .fx-blur-shape--cyan {
    bottom: 10%; right: 5%;
    width: 600px; height: 600px;
    background: radial-gradient(circle, var(--cyan, #62E5FF) 0%, transparent 70%);
    opacity: 0.35;
    animation: uxdivi-float 14s ease-in-out infinite reverse;
  }
  @keyframes uxdivi-float {
    0%, 100% { transform: translate(0, 0) scale(1); }
    50%      { transform: translate(30px, -30px) scale(1.1); }
  }
  .fx-blur-shape--sm { filter: blur(80px); }
  .fx-blur-shape--sm.fx-blur-shape--brand {
    top: 22%; left: 5%; bottom: auto; right: auto;
    width: 380px; height: 380px;
    opacity: 0.32;
  }
  .fx-blur-shape--sm.fx-blur-shape--cyan {
    top: auto; left: auto; bottom: 22%; right: 5%;
    width: 420px; height: 420px;
    opacity: 0.20;
  }
  .fx-blur-shape--alt.fx-blur-shape--brand { left: auto; right: 5%; }
  .fx-blur-shape--alt.fx-blur-shape--cyan  { right: auto; left: 5%; }
  .glow-orb-center {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
    width: 600px; height: 380px;
    background: radial-gradient(ellipse, rgba(1,77,253,0.4), rgba(98,229,255,0.12) 50%, transparent 70%);
    border-radius: 50%;
    filter: blur(50px);
    pointer-events: none;
    z-index: 0;
  }
  .glow-orb-center--sm {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
    width: 520px; height: 360px;
    background: radial-gradient(ellipse, rgba(1,77,253,0.22), rgba(98,229,255,0.08) 50%, transparent 75%);
    border-radius: 50%;
    filter: blur(60px);
    pointer-events: none;
    z-index: 0;
  }
  /* No-cuts: clip-path para que las atmósferas sangren entre secciones */
  #lograras, #aprenderas, #preview, #contenido, #parati, #certificado,
  #instructor, #testimonios, #acceder, #relacionados, #faq, #cta-final-curso {
    position: relative;
    isolation: isolate;
    overflow: visible !important;
    clip-path: inset(-140px 0 -140px 0);
  }
  #lograras > .wrap, #aprenderas > .wrap, #preview > .wrap, #contenido > .wrap,
  #parati > .wrap, #certificado > .wrap, #instructor > .wrap, #testimonios > .wrap,
  #acceder > .wrap, #relacionados > .wrap, #faq > .wrap, #cta-final-curso > .wrap {
    position: relative;
    z-index: 1;
  }
  @media (prefers-reduced-motion: reduce) {
    .fx-blur-shape { animation: none; }
  }

  /* ═══════════════════════════════════════════════════════════
     JEFF-HERO (bloque editorial Instructor — importado de Home)
     ═══════════════════════════════════════════════════════════ */
  .jeff-hero {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
  }
  .jeff-photo {
    border-radius: 22px;
    overflow: hidden;
    aspect-ratio: 4/5;
    box-shadow: 0 40px 80px -30px rgba(1,77,253,0.45);
  }
  .jeff-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .jeff-text .eyebrow-rule {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--mono); font-size: 11px;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--cyan);
    margin-bottom: 22px;
  }
  .jeff-text .er-line { width: 24px; height: 1px; background: var(--cyan); }
  .jeff-h {
    font-family: var(--display);
    font-size: clamp(36px, 4vw, 56px);
    line-height: 1.05;
    letter-spacing: -0.025em;
    margin: 0 0 20px;
    color: var(--ink);
    text-wrap: balance;
  }
  .jeff-h .text-glow-grad {
    background: linear-gradient(120deg, #FFFFFF 0%, #62E5FF 60%, #4A7EFF 100%);
    -webkit-background-clip: text; background-clip: text; color: transparent;
  }
  .jeff-lead {
    font-family: var(--mono); font-size: 12px;
    letter-spacing: 0.06em; color: var(--cyan);
    margin-bottom: 18px;
  }
  .jeff-prose {
    font-size: 15.5px; line-height: 1.6;
    color: var(--ink-2);
    margin-bottom: 28px;
  }
  .jeff-prose strong { color: var(--ink); }
  .jeff-meta {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 32px;
    padding: 22px 0;
    border-top: 1px solid var(--line-2);
    border-bottom: 1px solid var(--line-2);
    margin-bottom: 28px;
  }
  .jeff-meta .jm-label {
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--ink-3); margin-bottom: 8px;
  }
  .jeff-meta .jm-val {
    font-family: var(--display); font-size: 14.5px;
    color: var(--ink); line-height: 1.5;
  }
  .jeff-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

  /* ═══════════════════════════════════════════════════════════
     PLAN.FEATURED overrides (importados de Planes)
     ═══════════════════════════════════════════════════════════ */
  .text-glow-grad {
    background: linear-gradient(120deg, var(--brand-light, #4A7EFF) 0%, var(--cyan, #62E5FF) 50%, #8CEEFF 100%);
    -webkit-background-clip: text; background-clip: text;
    color: transparent;
    background-size: 200% 100%;
  }
  .plan { transition: transform 250ms cubic-bezier(0.2,0.7,0.2,1), box-shadow 250ms ease; }
  .plan:hover { transform: translateY(-3px); box-shadow: 0 30px 60px -25px rgba(1,77,253,0.4); }
  .plan.featured .plan-badge {
    top: 34px; right: 40px; left: auto;
  }
  .plan.featured h3 {
    font-size: clamp(20px, 1.85vw, 24px);
    margin-top: 26px;
    letter-spacing: -0.01em;
    line-height: 1.25;
  }
  .plan.featured .uxdivi-glow-btn { padding: 22px 28px; }
  .plan.featured h3 .title-star {
    color: var(--cyan); font-size: 0.95em; margin-left: 2px;
    display: inline-block; transform: translateY(-1px);
  }

  /* ═══════════════════════════════════════════════════════════
     GUARANTEE — versión tech/seguridad (importada de Planes)
     ═══════════════════════════════════════════════════════════ */
  .guarantee {
    grid-template-columns: 88px 1fr !important;
    gap: 32px !important;
    position: relative;
    overflow: hidden;
    isolation: isolate;
    border: 1px solid rgba(98,229,255,0.28) !important;
    background:
      radial-gradient(220px 160px at 8% 50%, rgba(98,229,255,0.20), transparent 70%),
      radial-gradient(320px 220px at 100% 100%, rgba(1,77,253,0.22), transparent 70%),
      linear-gradient(180deg, rgba(15,25,55,0.45), rgba(10,15,30,0.6)) !important;
    box-shadow:
      0 20px 60px -25px rgba(1,77,253,0.55),
      inset 0 1px 0 rgba(255,255,255,0.05);
  }
  .guarantee::before {
    content: ""; position: absolute; inset: 0;
    background-image:
      linear-gradient(rgba(98,229,255,0.05) 1px, transparent 1px),
      linear-gradient(90deg, rgba(98,229,255,0.05) 1px, transparent 1px);
    background-size: 32px 32px;
    mask-image: radial-gradient(ellipse at 12% 50%, #000 18%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at 12% 50%, #000 18%, transparent 70%);
    z-index: 0; pointer-events: none;
  }
  .guarantee::after {
    content: ""; position: absolute;
    top: 0; left: 0; right: 0; height: 1px;
    background: linear-gradient(90deg, transparent, rgba(98,229,255,0.6), transparent);
    z-index: 0; pointer-events: none;
    animation: guarantee-scan 6s ease-in-out infinite;
  }
  @keyframes guarantee-scan {
    0%, 100% { opacity: 0.3; transform: translateY(0); }
    50%      { opacity: 1; transform: translateY(2px); }
  }
  .guarantee > * { position: relative; z-index: 1; }
  .guarantee .shield {
    width: 88px; height: 88px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(98,229,255,0.32), rgba(1,77,253,0.18));
    border: 1px solid rgba(98,229,255,0.55);
    position: relative;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.18),
      0 14px 40px -14px rgba(98,229,255,0.55);
    display: grid; place-items: center;
    color: var(--cyan);
  }
  .guarantee .shield::before {
    content: ""; position: absolute; inset: -10px;
    border-radius: 28px;
    background: radial-gradient(circle, rgba(98,229,255,0.50), transparent 70%);
    filter: blur(14px);
    z-index: -1;
    animation: shield-pulse 2.6s ease-in-out infinite;
  }
  @keyframes shield-pulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50%      { opacity: 0.95; transform: scale(1.10); }
  }
  .guarantee-eyebrow {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--mono); font-size: 11px;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--cyan); margin-bottom: 10px;
  }
  .guarantee-eyebrow .g-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--cyan);
    box-shadow: 0 0 10px var(--cyan), 0 0 22px rgba(98,229,255,0.6);
    animation: dot-blink 1.6s ease-in-out infinite;
  }
  @keyframes dot-blink {
    0%, 100% { opacity: 1; }
    50%      { opacity: 0.35; }
  }
  .guarantee-chips {
    display: flex; flex-wrap: wrap; gap: 8px;
    margin-top: 16px;
  }
  .g-chip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 12px; border-radius: 999px;
    background: rgba(98,229,255,0.08);
    border: 1px solid rgba(98,229,255,0.25);
    font-family: var(--mono); font-size: 11px;
    color: var(--ink-2); letter-spacing: 0.04em;
    transition: background 200ms ease, border-color 200ms ease;
  }
  .g-chip:hover {
    background: rgba(98,229,255,0.14);
    border-color: rgba(98,229,255,0.5);
  }
  .g-chip svg {
    width: 12px; height: 12px;
    color: var(--cyan); stroke: currentColor;
    flex-shrink: 0;
  }
  .g-link {
    font-family: var(--mono) !important;
    font-size: 11px !important;
    color: var(--ink-3) !important;
    margin-top: 14px !important;
    margin-bottom: 0 !important;
    letter-spacing: 0.04em;
  }
  .g-link a {
    color: var(--cyan) !important;
    text-decoration: underline;
    text-underline-offset: 3px;
    font-size: 11px !important;
  }
  @media (prefers-reduced-motion: reduce) {
    .guarantee::after,
    .guarantee .shield::before,
    .guarantee-eyebrow .g-dot { animation: none; }
  }

  /* ═══════════════════════════════════════════════════════════
     VIDEO TESTIMONIALS — facade Vimeo (importado de Planes/Home)
     ═══════════════════════════════════════════════════════════ */
  .vt-grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 28px; max-width: 1200px; margin: 0 auto;
  }
  .vt-card { position: relative; isolation: isolate; }
  .vt-play {
    position: relative; display: block;
    width: 100%; aspect-ratio: 9 / 16;
    border-radius: 24px; overflow: hidden;
    border: 1px solid var(--line-2);
    background: linear-gradient(180deg, rgba(15,25,55,0.6), rgba(10,15,30,0.85));
    cursor: pointer; padding: 0; isolation: isolate;
    transition: transform 350ms cubic-bezier(0.33, 1, 0.68, 1),
                box-shadow 350ms ease, border-color 250ms ease;
  }
  .vt-card:hover .vt-play {
    transform: translateY(-4px);
    box-shadow: 0 30px 60px -20px rgba(1,77,253,0.55);
    border-color: rgba(98,229,255,0.5);
  }
  .vt-poster {
    position: absolute; inset: 0;
    background:
      radial-gradient(80% 60% at 50% 30%, rgba(1,77,253,0.45), transparent 70%),
      radial-gradient(60% 50% at 80% 80%, rgba(98,229,255,0.25), transparent 70%),
      linear-gradient(180deg, #0A1230 0%, #040814 100%);
    background-size: cover; background-position: center;
    z-index: 0; transition: transform 600ms ease;
  }
  .vt-card:hover .vt-poster { transform: scale(1.04); }
  .vt-overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 50%, rgba(4,8,20,0.55) 100%);
    z-index: 1; pointer-events: none;
  }
  .vt-glow {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 140px; height: 140px; border-radius: 50%;
    background: radial-gradient(circle, rgba(98,229,255,0.45), transparent 70%);
    filter: blur(24px); z-index: 1;
    opacity: 0.7; pointer-events: none;
    transition: opacity 350ms ease, transform 350ms ease;
  }
  .vt-card:hover .vt-glow {
    opacity: 1; transform: translate(-50%, -50%) scale(1.15);
  }
  .vt-play-icon {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
    width: 72px; height: 72px; border-radius: 50%;
    background: linear-gradient(180deg, #FFFFFF 0%, #E8F2FF 100%);
    display: grid; place-items: center; z-index: 2;
    box-shadow:
      0 14px 34px -10px rgba(1,77,253,0.7),
      inset 0 -2px 0 rgba(0,0,0,0.05);
    transition: transform 250ms cubic-bezier(0.33, 1, 0.68, 1), box-shadow 250ms ease;
  }
  .vt-card:hover .vt-play-icon {
    transform: translate(-50%, -50%) scale(1.1);
    box-shadow:
      0 20px 50px -10px rgba(98,229,255,0.8),
      inset 0 -2px 0 rgba(0,0,0,0.05);
  }
  .vt-play-icon svg {
    width: 28px; height: 28px;
    color: var(--brand); margin-left: 4px;
  }
  .vt-duration {
    position: absolute; bottom: 14px; right: 14px; z-index: 2;
    font-family: var(--mono); font-size: 11px; color: #fff;
    background: rgba(0,0,0,0.7); padding: 4px 8px; border-radius: 6px;
    letter-spacing: 0.04em; backdrop-filter: blur(6px);
  }
  .vt-meta { margin-top: 18px; text-align: center; }
  .vt-name {
    font-family: var(--display); font-size: 16px; font-weight: 600;
    color: var(--ink); letter-spacing: -0.01em;
  }
  .vt-role {
    font-family: var(--mono); font-size: 11px; color: var(--ink-3);
    margin-top: 6px; letter-spacing: 0.06em; text-transform: uppercase;
  }
  .vt-card.is-playing .vt-play { display: none; }
  .vt-iframe-wrap {
    position: relative; width: 100%; aspect-ratio: 9 / 16;
    border-radius: 24px; overflow: hidden;
    border: 1px solid var(--line-2); background: #000;
  }
  .vt-iframe-wrap iframe {
    position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
  }
  @keyframes vt-pulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(98,229,255,0.5); }
    50%      { box-shadow: 0 0 0 12px rgba(98,229,255,0); }
  }
  .vt-card:hover .vt-play-icon { animation: vt-pulse 1.6s ease-out infinite; }
  @media (max-width: 1100px) { .vt-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; } }
  @media (max-width: 600px)  { .vt-grid { grid-template-columns: 1fr; max-width: 360px; } }
  @media (prefers-reduced-motion: reduce) {
    .vt-card:hover .vt-play-icon { animation: none; }
    .vt-poster, .vt-play, .vt-glow { transition: none; }
  }

  /* ═══════════════════════════════════════════════════════════
     CTA FINAL — Aurora Gradient (importado de Planes)
     ═══════════════════════════════════════════════════════════ */
  .final {
    isolation: isolate;
    background: linear-gradient(180deg, rgba(15,25,55,0.85), rgba(10,15,30,0.92));
    border: 0;
  }
  .final::before {
    content: ""; position: absolute; inset: -30%;
    background:
      radial-gradient(circle at 20% 30%, var(--brand, #014DFD) 0%, transparent 35%),
      radial-gradient(circle at 75% 20%, var(--cyan, #62E5FF) 0%, transparent 35%),
      radial-gradient(circle at 50% 80%, var(--brand-light, #4A7EFF) 0%, transparent 40%);
    filter: blur(80px); opacity: 0.6;
    z-index: -1; pointer-events: none;
    transform-origin: center center; will-change: transform;
    animation: uxdivi-aurora-drift 22s ease-in-out infinite;
  }
  @keyframes uxdivi-aurora-drift {
    0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
    25%      { transform: translate3d(5%, -5%, 0) scale(1.10); }
    50%      { transform: translate3d(-4%, 4%, 0) scale(1.18); }
    75%      { transform: translate3d(-5%, -3%, 0) scale(1.12); }
  }
  .final::after {
    content: ""; position: absolute; inset: 0;
    background-image:
      linear-gradient(rgba(98,229,255,0.03) 1px, transparent 1px),
      linear-gradient(90deg, rgba(98,229,255,0.03) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse at center, #000 20%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 20%, transparent 70%);
    z-index: -1; pointer-events: none;
  }
  .final h2 { text-wrap: balance; }
  @media (prefers-reduced-motion: reduce) {
    .final::before { animation: none; }
  }

  /* ═══════════════════════════════════════════════════════════
     FAQ accordion — animación de apertura/cierre 350ms (de Planes)
     ═══════════════════════════════════════════════════════════ */
  .faq-item .body {
    overflow: hidden;
    transition:
      height 350ms cubic-bezier(0.33, 1, 0.68, 1),
      padding 350ms cubic-bezier(0.33, 1, 0.68, 1),
      opacity 220ms ease;
  }
  .faq-item:not([open]) .body {
    height: 0;
    padding-top: 0;
    padding-bottom: 0;
    opacity: 0;
  }
  .faq-item[open] .body { opacity: 1; }

  /* ═══════════════════════════════════════════════════════════
     Iconos SVG Lucide cyan reutilizables (reemplazan emojis)
     ═══════════════════════════════════════════════════════════ */
  .lucide { width: 14px; height: 14px; stroke: currentColor; flex-shrink: 0; }
  .lucide--cyan { color: var(--cyan); }
  .stats-bar .s .ico { width: 16px; height: 16px; }
  .stats-bar .s .ico svg { width: 16px; height: 16px; stroke: currentColor; }
  .outcome .ico svg { width: 22px; height: 22px; stroke: currentColor; }
  .forit-col .mark svg { width: 11px; height: 11px; stroke: currentColor; }
  .lesson .lico svg { width: 11px; height: 11px; stroke: currentColor; }
  .cert-copy .cert-bullets .em svg { width: 16px; height: 16px; stroke: currentColor; }
  .micro .micro-ico {
    display: inline-flex; align-items: center;
    vertical-align: -3px;
    margin-right: 4px;
    color: var(--cyan);
  }
  .micro .micro-ico svg { width: 14px; height: 14px; stroke: currentColor; }

  /* Container principal del rediseño 2026 · regla dura del sitio (1280px).
     Sin padding lateral en desktop · 4vw lateral en mobile/tablet (92% vw).
     Ver memoria feedback-container-1280px.md. */
  .wrap { max-width: 1280px; margin: 0 auto; }

  /* Padding vertical uniforme en TODAS las secciones del Layout No Miembro
     (decisión Jefferson 2026-05-15): 60px desktop · 20px mobile.
     Specificity alta + !important para ganarle a paddings heredados del
     theme Divi (100px+) y a reglas section{padding} sueltas del HTML
     fuente. */
  body.uxdivi-frontend--curso-no-miembro section {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  /* Rallas atmosféricas del fondo del temario · ocultadas (decisión
     Jefferson 2026-05-15 · prefiere fondo sólido limpio para el bloque
     de "Contenido completo del curso"). */
  body.uxdivi-frontend--curso-no-miembro #contenido .fx-grid {
    display: none !important;
  }

  /* Temario · fila inferior con descripción + botón "Expandir todo" en
     space-between (el título queda arriba centrado en su .sec-head propio
     · decisión Jefferson 2026-05-15). */
  .temario-meta-row {
    display: flex; align-items: center; justify-content: space-between;
    gap: 20px; margin: 0 auto 24px; max-width: 880px;
  }
  .temario-meta-row__sub {
    margin: 0; flex: 1 1 auto;
    color: var(--ink-3); font-size: 15px; line-height: 1.55;
  }
  .temario-toggle-all {
    display: inline-flex; align-items: center; gap: 8px;
    flex-shrink: 0;
    cursor: pointer;
    border: 1px solid rgba(98,229,255,0.25);
    background: rgba(98,229,255,0.05);
    color: var(--cyan);
    padding: 8px 14px;
    border-radius: 999px;
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    transition: background .2s, border-color .2s, transform .2s;
  }
  .temario-toggle-all:hover { background: rgba(98,229,255,0.1); border-color: rgba(98,229,255,0.45); }
  .temario-toggle-all:active { transform: scale(0.97); }
  .temario-toggle-all__icon { transition: transform .25s ease; }
  .temario-toggle-all[aria-expanded="true"] .temario-toggle-all__icon { transform: rotate(180deg); }
  @media (max-width: 720px) {
    body.uxdivi-frontend--curso-no-miembro .temario-meta-row {
      flex-direction: column !important;
      align-items: flex-start !important;
      gap: 14px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .temario-toggle-all {
      align-self: flex-start;
    }
  }
  @media (max-width: 980px) {
    .wrap { padding-left: 4vw; padding-right: 4vw; }
  }

  /* Mobile <=720px · simplificar hero (decisión Jefferson 2026-05-15):
     ocultar crumbs, hero-pill, stats-bar para que el primer fold muestre
     solo título + descripción corta + video + 2 botones. Botones inline
     uno al lado del otro (no apilados). */
  @media (max-width: 720px) {
    body.uxdivi-frontend--curso-no-miembro .hero.course .crumbs,
    body.uxdivi-frontend--curso-no-miembro .hero.course .hero-pill,
    body.uxdivi-frontend--curso-no-miembro .hero.course .stats-bar {
      display: none !important;
    }
    body.uxdivi-frontend--curso-no-miembro .hero.course {
      padding: 32px 0 40px !important;
      text-align: center;
    }
    body.uxdivi-frontend--curso-no-miembro .hero-ctas {
      display: flex !important;
      flex-direction: row !important;
      justify-content: center !important;
      flex-wrap: nowrap !important;
      gap: 10px !important;
      margin-top: 28px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .hero-ctas .btn {
      flex: 1 1 0 !important;
      min-width: 0 !important;
      padding: 12px 14px !important;
      font-size: 13px !important;
      white-space: nowrap !important;
    }

    /* Outcomes en mobile · grid 4-cols → 1 columna apilada · cards
       full-width (decisión Jefferson 2026-05-15 · 4 columnas estrechas
       en mobile cortaban texto). */
    body.uxdivi-frontend--curso-no-miembro .outcomes-grid {
      grid-template-columns: 1fr !important;
      gap: 14px !important;
    }
    /* Learn-grid (highlights) · misma lógica · ya iba a 1 col por defecto
       en mobile pero forzamos por consistencia. */
    body.uxdivi-frontend--curso-no-miembro .learn-grid {
      grid-template-columns: 1fr !important;
    }
    /* Preview recap (clase gratis · "Esta es la clase ...") · 1 columna
       en mobile · el grid 1fr+auto del desktop dejaba el texto exprimido
       a la izquierda y el botón a la derecha. */
    body.uxdivi-frontend--curso-no-miembro .preview-recap {
      grid-template-columns: 1fr !important;
      gap: 18px !important;
      padding: 20px 18px !important;
      text-align: left !important;
    }
    body.uxdivi-frontend--curso-no-miembro .preview-recap .btn {
      width: 100% !important;
      justify-content: center !important;
    }
    body.uxdivi-frontend--curso-no-miembro .preview-recap h3 {
      font-size: 18px !important;
      line-height: 1.3 !important;
    }

    /* Padding vertical de sections en mobile · 20px arriba y abajo. */
    body.uxdivi-frontend--curso-no-miembro section {
      padding-top: 20px !important;
      padding-bottom: 20px !important;
    }

    /* Para ti / No es para ti · 2-cols → 1 columna en mobile · padding
       reducido para no comer espacio horizontal. */
    body.uxdivi-frontend--curso-no-miembro .forit-grid {
      grid-template-columns: 1fr !important;
      gap: 14px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .forit-col {
      padding: 24px 20px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .forit-col h3 {
      font-size: 18px !important;
      margin-bottom: 16px !important;
    }

    /* Certificado · 2-cols → 1 columna apilada · imagen del cert sin
       rotación ni scale (que en desktop hacen el +25% del tamaño). */
    body.uxdivi-frontend--curso-no-miembro .cert-wrap {
      grid-template-columns: 1fr !important;
      gap: 32px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .cert-image,
    body.uxdivi-frontend--curso-no-miembro .cert-image:hover {
      transform: none !important;
    }
    body.uxdivi-frontend--curso-no-miembro .cert-copy h2 {
      font-size: clamp(24px, 6vw, 32px) !important;
    }

    /* Sobre el instructor (Jefferson) · 2-cols → 1 columna · foto arriba,
       texto abajo · jeff-ctas en row (2 botones lado a lado compactos). */
    body.uxdivi-frontend--curso-no-miembro .jeff-hero {
      grid-template-columns: 1fr !important;
      gap: 28px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .jeff-photo {
      max-width: 320px;
      margin: 0 auto;
    }
    body.uxdivi-frontend--curso-no-miembro .jeff-h {
      font-size: clamp(26px, 7vw, 36px) !important;
    }
    body.uxdivi-frontend--curso-no-miembro .jeff-ctas {
      display: flex !important;
      flex-direction: row !important;
      flex-wrap: nowrap !important;
      gap: 10px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .jeff-ctas .btn {
      flex: 1 1 0 !important;
      min-width: 0 !important;
      padding: 12px 14px !important;
      font-size: 13px !important;
      white-space: nowrap !important;
      justify-content: center !important;
    }

    /* Trustpilot bar · 3-cols (logo / meta / btn) → stack vertical en mobile
       (decisión Jefferson 2026-05-15). El `.trustpilot-bar` base del DS usa
       `display: grid` · forzamos `display: flex` para poder usar
       `flex-direction: column` correctamente. */
    body.uxdivi-frontend--curso-no-miembro .trustpilot-bar {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      justify-content: center !important;
      text-align: center !important;
      gap: 14px !important;
      padding: 20px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .trustpilot-bar .tp-meta {
      display: flex !important;
      flex-direction: column !important;
      align-items: center !important;
      gap: 8px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .trustpilot-bar .btn {
      width: 100% !important;
      justify-content: center !important;
    }

    /* Cómo acceder · access-grid 2-cols → 1 columna apilada en mobile. */
    body.uxdivi-frontend--curso-no-miembro .access-grid {
      grid-template-columns: 1fr !important;
      gap: 18px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .plan {
      padding: 24px 22px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .plan h3 {
      font-size: 18px !important;
      line-height: 1.35 !important;
    }
    /* Garantía 7 días · grid 88px+1fr → stack en mobile. */
    body.uxdivi-frontend--curso-no-miembro .guarantee {
      grid-template-columns: 1fr !important;
      gap: 16px !important;
      text-align: center !important;
      padding: 24px 20px !important;
    }
    body.uxdivi-frontend--curso-no-miembro .guarantee .shield {
      margin: 0 auto;
    }

    /* Cursos relacionados · 4-cols → 1 col apilada en mobile · cards
       full-width igual al patrón del Layout Curso Miembro. */
    body.uxdivi-frontend--curso-no-miembro .course-grid {
      grid-template-columns: 1fr !important;
      gap: 16px !important;
      max-width: 420px;
      margin: 0 auto;
    }
  }

  /* Tablet · cursos relacionados 4-cols → 2-cols intermedio. */
  @media (max-width: 980px) and (min-width: 721px) {
    body.uxdivi-frontend--curso-no-miembro .course-grid {
      grid-template-columns: repeat(2, 1fr) !important;
    }
  }

  /* Anti scroll-horizontal · las atmósferas .fx-blur-shape sangran con
     offsets negativos. body{overflow-x:hidden} contiene el desbordamiento. */
  html, body { overflow-x: hidden; }
  /* Fondo uniforme del DS UXDivi · scope al body class del template
     para no filtrar a otras pages del sitio. */
  body.uxdivi-frontend--curso-no-miembro { background: var(--bg) !important; }
