.elementor-35800 .elementor-element.elementor-element-b24b9c7 > .elementor-element-populated{padding:0px 0px 0px 0px;}/* Start custom CSS */:root{
    --font-d:'Prata',Georgia,serif; --font-b:'Roboto',system-ui,sans-serif;
    --ink:#182838; --ink-2:#3D5263; --ink-3:#5E7280; --border:#E2EAEF;
    --green:#00705f; --green-deep:#013A35; --green-2:#1FA89A;
    --accent:#2C8FB0; --accent-bright:#6FC6E0;
    --ease:cubic-bezier(.4,0,.2,1); --r:18px; --r-lg:24px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--font-b)!important;color:#fff!important;line-height:1.65!important;-webkit-font-smoothing:antialiased!important;background:linear-gradient(160deg,#0a1f1b 0%,#0e2b27 38%,#0f2438 72%,#0b1f2e 100%)!important;background-attachment:fixed!important}
  h1,h2,h3,h4{font-family:var(--font-d)!important;font-weight:400!important;line-height:1.18!important}
  img{max-width:100%;display:block}
  .wrap{max-width:1180px;margin:0 auto;padding:0 30px}
  .aurora{position:fixed;inset:-20%;z-index:-1;background:radial-gradient(circle at 22% 26%,rgba(31,168,154,.22),transparent 42%),radial-gradient(circle at 82% 34%,rgba(0,112,95,.26),transparent 46%),radial-gradient(circle at 56% 86%,rgba(44,143,176,.2),transparent 48%)}
  @media(prefers-reduced-motion:no-preference){.aurora{animation:aur 26s ease-in-out infinite alternate}}
  @keyframes aur{0%{transform:translate(0,0) scale(1)}100%{transform:translate(-5%,4%) scale(1.16)}}
  .sec-label{display:inline-block;font-size:.89rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green-2);}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--font-b);font-weight:700;font-size:1.1rem;padding:15px 30px;border-radius:999px!important;border:none;cursor:pointer;text-decoration:none;transition:transform .2s var(--ease),box-shadow .2s,filter .2s}
  .btn-primary{background:linear-gradient(135deg,var(--green),var(--green-2));color:#fff;box-shadow:0 10px 26px rgba(0,112,95,.3)}
  .btn-primary:hover{transform:translateY(-2px);color:#fff!important;box-shadow:0 14px 34px rgba(0,112,95,.4)}
  .btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.4)}
  .btn-ghost:hover{border-color:#fff;color:#fff!important;background:rgba(255,255,255,.08)}

  /* HERO */
  .hero{position:relative;min-height:88vh;display:flex;align-items:center;text-align:center;overflow:hidden;padding:90px 0}
  .hero .wrap{position:relative;z-index:2;max-width:880px}
  .hero h1{font-size: clamp(2.2rem, 5vw, 4.15rem);color:#fff;margin-bottom:18px}
  .hero p{color:rgba(255,255,255,.8);font-size:1.25rem;max-width:60ch;margin:0 auto 30px}
  .hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
  .hero-scroll{margin-top:48px;color:rgba(255,255,255,.55);font-size:.9rem;letter-spacing:.16em;text-transform:uppercase}
  /* moléculas / fichas hero */
  .fx{position:absolute;z-index:1;will-change:transform}
  .fx-mol{opacity:.5}.fx-mol .atom{fill:rgba(31,168,154,.5)}.fx-mol .bond{stroke:rgba(255,255,255,.28);stroke-width:2;fill:none}
  .fx-tile{width:58px;height:58px;border-radius:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);display:flex;flex-direction:column;align-items:center;justify-content:center;color:rgba(255,255,255,.75)}
  .fx-tile b{font-family:var(--font-d);font-size:1.5rem;top: 10px;left: 4px;
    position: relative;line-height:1}.fx-tile.cl b{top: 2px;left: 1px;} .fx-tile span{font-size:.55rem;top: 25px;
    position: relative;
    left: -10px;opacity:.7}
  @media(prefers-reduced-motion:no-preference){.fa{animation:fA 14s ease-in-out infinite}.fb{animation:fB 18s ease-in-out infinite}.fspin{animation:fS 34s linear infinite;transform-origin:center}}
  @keyframes fA{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-26px) rotate(8deg)}}
  @keyframes fB{0%,100%{transform:translate(0,0)}50%{transform:translate(-12px,22px)}}
  @keyframes fS{to{transform:rotate(360deg)}}

  /* NAV LATERAL */
  .tour-nav{position:fixed;left:22px;top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;gap:6px}
  .tour-nav a{display:flex;align-items:center;gap:11px;text-decoration:none;color:rgba(255,255,255,.55);padding:6px 4px}
  .tour-nav .dot{width:12px;height:12px;border-radius:50%;border:2px solid rgba(255,255,255,.4);flex-shrink:0;transition:.2s}
  .tour-nav .lbl{font-size:.92rem;font-weight:600;letter-spacing:.02em;max-width:0;overflow:hidden;white-space:nowrap;opacity:0;transition:.25s}
  .tour-nav a:hover .lbl,.tour-nav a.active .lbl{max-width:160px;opacity:1}
  .tour-nav a.active{color:#fff}
  .tour-nav a.active .dot{background:var(--green-2);border-color:var(--green-2);box-shadow:0 0 0 4px rgba(31,168,154,.2)}
  @media(max-width:1100px){.tour-nav{display:none}}

  /* ESTANCIAS */
  .estancia{min-height:96vh;display:flex;align-items:center;padding:80px 0;position:relative}
  .est-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;width:100%}
  .estancia.reverse .est-visual{order:2}
  .est-step{font-family:var(--font-d);font-size:3.9rem;color:rgba(255,255,255,.12);line-height:1}
  .est-text h2{font-size: clamp(1.9rem, 3.2vw, 3rem);color:#fff;margin: 16px 0 14px 0 !important}
  .est-text p{color:rgba(255,255,255,.78);font-size:1.18rem;line-height:1.8;margin-bottom:20px;font-weight: 400;max-width:48ch}
  .est-bullets{list-style:none;display:flex;flex-direction:column;gap:11px;margin-left: 0;margin-bottom:24px}
  .est-bullets li{display:flex;align-items:flex-start;gap:11px;color:rgba(255,255,255,.9);font-size:1.1rem}
  .est-bullets svg{flex-shrink:0;margin-top:2px;color:var(--green-2)}
  .est-more{font-weight:700;font-size:.9rem;color:var(--green-2);text-decoration:none;display:inline-flex;gap:6px}
  .est-more:hover{gap:10px}

  /* MOCKUPS */
  .frame{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 34px 80px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.1)}
  .frame-bar{display:flex;align-items:center;gap:7px;padding:11px 14px;background:#eef2f5;border-bottom:1px solid #e2eaef}
  .frame-dot{width:10px;height:10px;border-radius:50%}
  .frame-url{margin-left:10px;background:#fff;border:1px solid #e2eaef;border-radius:8px;padding:4px 12px;font-size:.8rem;color:#5E7280;font-weight: 400;flex:1;max-width:280px}
  .frame-body{padding:18px;background:#F2F6F8;color:#182838}
  .livebadge{display:inline-flex;align-items:center;gap:6px;background:rgba(178,34,52,.92);color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 10px;border-radius:999px}
  .live-dot{width:7px;height:7px;border-radius:50%;background:#FF4D5E}
  @media(prefers-reduced-motion:no-preference){.live-dot{animation:pulse 1.5s infinite}}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
  .avset{display:inline-flex}
  .av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.66rem;font-weight:700;color:#fff;border:2px solid #fff;margin-left:-9px}
  .av:first-child{margin-left:0}
  /* Masterclass live tile */
  .mc-tile{position:relative;border-radius:12px;aspect-ratio:16/9;background:linear-gradient(135deg,#013A35,#00705f 60%,#1FA89A);display:flex;align-items:center;justify-content:center}
  .mc-play{width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:#013A35}
  .mc-meta{display:flex;align-items:center;justify-content:space-between;margin-top:13px;font-size:.93rem;font-weight: 400;color:#3D5263}
  .mc-duo{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .mc-cell{position:relative;aspect-ratio:1/1;border-radius:10px;overflow:hidden;background:radial-gradient(circle at 50% 124%,rgba(31,168,154,.5),transparent 60%),linear-gradient(160deg,#0f3a36,#0a2630)}
  .mc-cell img{position:absolute;bottom:0;left:50%;transform:translateX(-50%);height:99%;width:auto;max-width:112%;object-fit:contain}
  .mc-cell .nm{position:absolute;bottom:8px;left:8px;z-index:2;background:rgba(0,0,0,.42);color:#fff;font-size:.82rem;font-weight:600;padding:3px 9px;border-radius:6px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
  .tut-photo{width:54px;height:54px;border-radius:50%;overflow:hidden;background:linear-gradient(160deg,#0e3a35,#1FA89A);flex-shrink:0;display:block}
  .tut-photo img{width:100%;height:100%;object-fit:cover;object-position:top center}
  /* Videoteca grid */
  .vt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
  .vt-card{border-radius:9px;overflow:hidden;background:#fff;border:1px solid #e6edf1}
  .vt-thumb{aspect-ratio:16/10;background:linear-gradient(135deg,#1a2b3c,#2c5e7c);position:relative}
  .vt-thumb::after{content:"▶";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.85);font-size:.8rem}
  .vt-card span{display:block;padding:7px 9px;font-size:.92rem;color:#5E7280}
  /* Tutorías cards */
  .tut{display:flex;flex-direction:column;gap:12px}
  .tut-card{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid #e6edf1;border-radius:14px;padding:14px 16px;box-shadow:0 4px 16px rgba(24,40,56,.06)}
  .tut-card .av{width:52px;height:52px;margin:0;border:none;font-size:1rem;flex-shrink:0}
  .tut-card .tn{font-weight:700;color:#182838;font-size:1.15rem}
  .tut-card .tr{font-size:.94rem;font-weight: 400;color:#5E7280}
  /* Carnet */
  .carnet-wrap{position:relative}
  .carnet-wrap img{border-radius:16px;box-shadow:0 30px 70px rgba(0,0,0,.4)}
  .carnet-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
  .chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:999px;padding:7px 14px;font-size:.95rem;font-weight:600;color:#fff}
  .chip b{color:var(--green-2)}
  /* Networking mesas */
  .net-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .net-table{border-radius:10px;aspect-ratio:4/3;background:linear-gradient(135deg,#15314A,#285E7C);position:relative;display:flex;align-items:flex-end;padding:10px}
  .net-table b{color:#fff;font-size:1rem;font-weight:700;font-family:var(--font-b)}
  .net-table .seats{position:absolute;top:10px;right:10px;display:flex}
  .net-table .seats i{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.5);margin-left:-5px;border:1.5px solid #285E7C}


  /* Promotores */
  .pro-panel{display:flex;flex-direction:column;gap:13px}
  .pro-head{background:linear-gradient(135deg,#013A35,#00705f 68%,#1FA89A);border-radius:14px;padding:18px;color:#fff;position:relative;overflow:hidden}
  .pro-head::after{content:"";position:absolute;width:150px;height:150px;border-radius:50%;right:-58px;top:-58px;background:rgba(255,255,255,.12)}
  .pro-head b{display:block;font-family:var(--font-d);font-size:1.35rem;font-weight:400;line-height:1.2;position:relative;z-index:1}
  .pro-head span{display:block;font-size:.9rem;color:rgba(255,255,255,.78);font-weight:400;margin-top:4px;position:relative;z-index:1}
  .pro-link{background:#fff;border:1px solid #e6edf1;border-radius:12px;padding:12px 14px;color:#3D5263;font-size:.92rem;font-weight:400;display:flex;align-items:center;gap:10px}
  .pro-link code{font-family:var(--font-b);background:#E6F2EF;color:#00705f;border-radius:7px;padding:4px 8px;font-weight:700;white-space:nowrap}
  .pro-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px}
  .pro-stat{background:#fff;border:1px solid #e6edf1;border-radius:12px;padding:12px 10px;text-align:center}
  .pro-stat b{display:block;font-family:var(--font-d);font-size:1.55rem;line-height:1;color:#00705f;font-weight:400}
  .pro-stat span{display:block;margin-top:5px;font-size:.78rem;color:#5E7280;font-weight:600}
  .pro-materials{display:flex;gap:8px;flex-wrap:wrap}
  .pro-materials span{background:rgba(0,112,95,.08);border:1px solid rgba(0,112,95,.16);border-radius:999px;padding:7px 12px;font-size:.84rem;font-weight:700;color:#00705f}
  @media(max-width:520px){.pro-stats{grid-template-columns:1fr}.pro-link{align-items:flex-start;flex-direction:column}}

  /* CTA final */
  .cta{padding:90px 0 110px;text-align:center}
  .cta-band{background:linear-gradient(135deg,var(--green-deep),var(--green) 70%,var(--green-2));border-radius:28px;padding:60px 40px;box-shadow:0 30px 70px rgba(0,0,0,.3)}
  .cta-band h2{font-size: clamp(1.9rem, 3.5vw, 2.98rem);margin-top:10px;color: #fff;margin-bottom:14px}
  .cta-band p{color:rgba(255,255,255,.85);max-width:560px;font-weight:400;margin:0 auto 26px}
  .cta-band .btn-primary{background:#fff;color:var(--green)}
  .cta-band .btn-primary:hover{color:#00705f!important;}

  /* CTA · elección clara por curso */
  /* ══════════ FIX CTA FINAL · CURSOS TOUR GUIADO ══════════ */
  #join-campus .cta-band .cta-course-actions {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 20px !important;
    max-width: 1125px !important;
    margin: 36px auto 0 !important;
    padding: 0 !important;
    align-items: stretch !important;
  }

  #join-campus .cta-band .cta-course-btn {
    appearance: none !important;
    -webkit-appearance: none !important;
    width: 100% !important;
    min-height: 245px !important;
    padding: 28px 28px 26px !important;
    border: 1px solid rgba(255, 255, 255, .82) !important;
    border-top: 6px solid var(--course-color) !important;
    border-radius: 24px !important;
    background: linear-gradient(180deg, #ffffff 0%, #f7fafb 100%) !important;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .14) !important;
    cursor: pointer !important;
    text-align: center !important;
    text-decoration: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 0 !important;
    color: var(--ink) !important;
    font-family: var(--font-b) !important;
    line-height: 1.35 !important;
    transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease) !important;
  }

  #join-campus .cta-band .cta-course-btn:hover,
  #join-campus .cta-band .cta-course-btn:focus-visible {
    transform: translateY(-4px) !important;
    box-shadow: 0 26px 58px rgba(0, 0, 0, .22) !important;
    border-color: rgba(255, 255, 255, 1) !important;
    outline: none !important;
  }

  #join-campus .cta-band .cta-course-btn b {
    display: block !important;
    width: 100% !important;
    max-width: 310px !important;
    margin: 0 auto 14px !important;
    padding: 0 !important;
    color: var(--ink) !important;
    font-family: var(--font-d) !important;
    font-size: clamp(1.42rem, 2vw, 1.65rem) !important;
    font-weight: 400 !important;
    line-height: 1.3 !important;
    letter-spacing: -.035em !important;
    text-transform: none !important;
  }

  #join-campus .cta-band .cta-course-btn small {
    display: block !important;
    width: 100% !important;
    max-width: 295px !important;
    margin: 0 auto 22px !important;
    padding: 0 !important;
    color: var(--ink-3) !important;
    font-family: var(--font-b) !important;
    font-size: 1.1rem !important;
    font-weight: 400 !important;
    line-height: 1.4 !important;
    text-transform: none !important;
  }

  /* Botón interno premium · Ver planes / Ver curso */
  #join-campus .cta-band .cta-course-btn em {
    position: relative !important;
    isolation: isolate !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-width: 165px !important;
    min-height: 46px !important;
    margin: auto 0 0 !important;
    padding: 12px 22px !important;
    border-radius: 999px !important;
    border: 1px solid color-mix(in srgb, var(--course-color, var(--green)) 36%, transparent) !important;
    background: linear-gradient(135deg, var(--course-color, var(--green)), color-mix(in srgb, var(--course-color, var(--green)) 78%, #ffffff 22%)) !important;
    color: #fff !important;
    font-family: var(--font-b) !important;
    font-size: .98rem !important;
    font-style: normal !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: .01em !important;
    text-decoration: none !important;
    box-shadow: 0 13px 26px color-mix(in srgb, var(--course-color, var(--green)) 26%, transparent) !important;
    overflow: hidden !important;
    transform: translateZ(0) !important;
    transition: transform .22s var(--ease), box-shadow .22s var(--ease), filter .22s var(--ease) !important;
  }

  #join-campus .cta-band .cta-course-btn em::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: -1 !important;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.36) 42%, transparent 72%) !important;
    transform: translateX(-120%) !important;
    transition: transform .65s var(--ease) !important;
  }

  #join-campus .cta-band .cta-course-btn em::after {
    content: "→" !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    font-size: 1.05rem !important;
    line-height: 1 !important;
    color: #fff !important;
    transition: transform .22s var(--ease) !important;
  }

  #join-campus .cta-band .cta-course-btn:hover em,
  #join-campus .cta-band .cta-course-btn:focus-visible em {
    transform: translateY(-2px) !important;
    filter: saturate(1.08) !important;
    box-shadow: 0 18px 34px color-mix(in srgb, var(--course-color, var(--green)) 34%, transparent) !important;
  }

  #join-campus .cta-band .cta-course-btn:hover em::before,
  #join-campus .cta-band .cta-course-btn:focus-visible em::before {
    transform: translateX(120%) !important;
  }

  #join-campus .cta-band .cta-course-btn:hover em::after,
  #join-campus .cta-band .cta-course-btn:focus-visible em::after {
    transform: translateX(4px) !important;
  }

  /* Etiqueta superior del curso · sin apariencia de botón */
  #join-campus .cta-band .cta-course-btn span {
    position: relative !important;
    display: inline-block !important;
    margin: 0 0 22px !important;
    padding: 0 0 10px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    color: var(--course-color, var(--green)) !important;
    font-family: var(--font-b) !important;
    font-size: .92rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
    box-shadow: none !important;
  }

  #join-campus .cta-band .cta-course-btn span::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    bottom: 0 !important;
    width: 42px !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: var(--course-color, var(--green)) !important;
    transform: translateX(-50%) !important;
    opacity: .75 !important;
  }
  
  #join-campus .cta-band .cta-course-btn:hover,
  #join-campus .cta-band .cta-course-btn:focus-visible {
    border-top-color: var(--course-color, var(--green)) !important;
  }

  @media (max-width: 980px) {
    #join-campus .cta-band .cta-course-actions {
      grid-template-columns: 1fr !important;
      max-width: 560px !important;
      gap: 16px !important;
      margin-top: 30px !important;
    }

    #join-campus .cta-band .cta-course-btn {
      min-height: auto !important;
      padding: 26px 24px 24px !important;
    }

    #join-campus .cta-band .cta-course-btn b {
      max-width: 420px !important;
      font-size: 1.65rem !important;
    }

    #join-campus .cta-band .cta-course-btn small {
      max-width: 420px !important;
    }
  }

  @media (max-width: 520px) {
    #join-campus .cta-band {
      padding-left: 20px !important;
      padding-right: 20px !important;
    }

    #join-campus .cta-band .cta-course-actions {
      margin-top: 24px !important;
      gap: 14px !important;
    }

    #join-campus .cta-band .cta-course-btn {
      padding: 22px 18px 20px !important;
      border-radius: 20px !important;
    }

    #join-campus .cta-band .cta-course-btn span {
      margin-bottom: 17px !important;
      padding-bottom: 9px !important;
      font-size: .85rem !important;
      letter-spacing: .16em !important;
    }

    #join-campus .cta-band .cta-course-btn span::after {
      width: 36px !important;
    }

    #join-campus .cta-band .cta-course-btn b {
      font-size: 1.5rem !important;
      line-height: 1.2 !important;
      margin-bottom: 10px !important;
      margin-top: 10px!important;
    }

    #join-campus .cta-band .cta-course-btn small {
      font-size: 1.05rem !important;
      line-height: 1.42 !important;
      margin-bottom: 18px !important;
    }

    #join-campus .cta-band .cta-course-btn em {
      font-size: 1.2rem !important;
      margin-top: 8px!important;
    }
  }

  /* Popup · planes por curso */
  .ki-enroll-modal,
  .ki-enroll-modal * {
    box-sizing: border-box;
  }

  .ki-enroll-modal {
    --ki-ink: #243746;
    --ki-muted: #607487;
    --ki-line: rgba(36, 55, 70, .14);
    --ki-soft: #f6f8f9;
    --ki-gold: #c28b2e;
    --ki-gold-dark: #9b6618;
    --ki-teal: #0b7f7b;
    --ki-teal-dark: #075d5a;
    --ki-blue: #2f6699;

    position: fixed;
    inset: 0;
    z-index: 2147483000;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 18px;
    font-family: var(--font-b);
    color: var(--ki-ink);
  }

  .ki-enroll-modal.is-open {
    display: flex;
  }

  .ki-modal-backdrop {
    position: absolute;
    inset: 0;
    background:
      radial-gradient(circle at 18% 20%, rgba(194, 139, 46, .24), transparent 34%),
      radial-gradient(circle at 82% 25%, rgba(11, 127, 123, .22), transparent 35%),
      linear-gradient(135deg, rgba(8, 18, 28, .90), rgba(15, 31, 44, .88));
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
  }

  .ki-modal-panel {
    position: relative;
    width: min(820px, calc(100vw - 30px));
    max-height: calc(100svh - 36px);
    overflow: visible;
    background: #fff;
    border-radius: 28px;
    box-shadow: 0 30px 90px rgba(7, 22, 35, .38);
    padding: 32px 40px 30px;
    outline: none;
    transform: translateY(12px) scale(.98);
    opacity: 0;
  }

  .ki-enroll-modal.is-open .ki-modal-panel {
    animation: kiModalIn .25s ease forwards;
  }

  @keyframes kiModalIn {
    to {
      transform: translateY(0) scale(1);
      opacity: 1;
    }
  }

  .ki-modal-close {
    position: absolute;
    top: 18px;
    right: 18px;
    width: 42px;
    height: 42px;
    padding: 0;
    border: 1px solid rgba(11, 127, 123, .18);
    border-radius: 999px;
    background: rgba(11, 127, 123, .10);
    color: var(--ki-teal-dark) !important;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    line-height: 1;
    transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  }

  .ki-modal-close svg {
    display: block;
    width: 20px;
    height: 20px;
    pointer-events: none;
  }

  .ki-modal-close svg path {
    stroke: currentColor !important;
  }

  .ki-modal-close:hover,
  .ki-modal-close:focus-visible {
    background: var(--ki-teal);
    border-color: var(--ki-teal);
    color: #fff !important;
    transform: rotate(90deg);
    outline: none;
  }

  .ki-modal-close:hover svg path,
  .ki-modal-close:focus-visible svg path {
    stroke: #fff !important;
  }

  .ki-modal-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0 52px 8px 0;
    color: var(--ki-gold-dark);
    font-size: 10.5px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
  }

  .ki-modal-kicker::before {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--ki-gold);
    box-shadow: 0 0 0 6px rgba(194, 139, 46, .13);
  }

  .ki-modal-title {
    margin: 0 0 16px;
    padding-right: 48px;
    font-family: var(--font-d);
    font-size: clamp(28px, 3.2vw, 36px);
    font-weight: 400;
    line-height: 1.05;
    letter-spacing: -.035em;
    color: var(--ki-ink);
  }

  .ki-modal-course {
    margin: 0;
    color: var(--ki-teal-dark);
    font-size: 15.5px;
    font-weight: 900;
    line-height: 1.25;
  }

  .ki-modal-desc {
    margin: 0 0 22px;
    max-width: 660px;
    color: var(--ki-muted);
    font-size: 14.2px;
    font-weight: 400;
    line-height: 1.5;
  }

  .ki-plan-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    align-items: stretch;
    margin-top: 20px;
  }

  .ki-plan-grid.is-single {
    grid-template-columns: minmax(0, 430px);
    justify-content: center;
  }

  .ki-plan-card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 315px;
    padding: 24px 26px 24px;
    border-radius: 22px;
    background: #fff;
    border: 1px solid var(--ki-line);
    box-shadow: 0 14px 36px rgba(36, 55, 70, .08);
    overflow: hidden;
  }

  .ki-plan-card::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 6px;
    background: var(--plan-color);
  }

  .ki-plan-card.is-plus {
    border-color: rgba(11, 127, 123, .30);
    box-shadow: 0 16px 42px rgba(11, 127, 123, .13);
  }

  .ki-recommended {
    position: absolute;
    top: 16px;
    right: 16px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(11, 127, 123, .10);
    color: var(--ki-teal-dark);
    font-size: 9.5px;
    font-weight: 900;
    letter-spacing: .07em;
    text-transform: uppercase;
  }

  .ki-plan-label {
    margin: 6px 0 9px;
    color: var(--plan-color);
    font-size: 10.5px;
    font-weight: 900;
    letter-spacing: .13em;
    text-transform: uppercase;
  }

  .ki-plan-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin: 0 0 14px;
  }

  .ki-plan-name {
    margin: 0;
    padding-right: 0;
    font-family: var(--font-d);
    font-size: 29px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -.03em;
    color: var(--ki-ink);
  }

  .ki-plan-price {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-start;
    min-width: 82px;
    margin-top: -3px;
    line-height: 1;
  }

  .ki-price-offer {
    display: block;
    color: var(--plan-color);
    font-size: 24px;
    font-weight: 900;
    letter-spacing: -.04em;
    white-space: nowrap;
  }

  .ki-price-real {
    display: block;
    margin-top: 4px;
    color: var(--ki-muted);
    font-size: 13px;
    font-weight: 800;
    text-decoration: line-through;
    opacity: .72;
    white-space: nowrap;
  }

  .ki-plan-course {
    margin: 0 0 10px!important;
    padding: 9px 12px;
    border-radius: 14px;
    background: var(--ki-soft);
    color: var(--ki-muted);
    font-size: 14px;
    font-weight: 800;
    line-height: 1.35;
  }

  .ki-plan-sub {
    margin: 0 0 15px !important;
    color: var(--ki-ink);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.4;
  }

  .ki-plan-list {
    display: grid;
    gap: 9px;
    margin: 0 0 22px;
    padding: 0;
    list-style: none;
  }

  .ki-plan-list li {
    display: flex;
    align-items: flex-start;
    gap: 9px;
    color: var(--ki-ink);
    font-size: 14px;
    font-weight: 700;
    line-height: 1.34;
  }

  .ki-plan-list li::before {
    content: "✓";
    flex: 0 0 20px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: rgba(11, 127, 123, .10);
    color: var(--ki-teal);
    font-weight: 900;
    font-size: 11px;
    margin-top: -1px;
  }

  .ki-plan-cta {
    position: relative;
    isolation: isolate;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    width: 100%;
    margin-top: auto;
    padding: 13px 18px;
    border-radius: 999px;
    background: var(--plan-color);
    color: #fff !important;
    text-decoration: none !important;
    font-size: 13.5px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
    overflow: hidden;
    box-shadow: 0 14px 26px rgba(36, 55, 70, .14);
    transition: transform .2s ease, box-shadow .2s ease;
  }

  .ki-plan-cta::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.34) 42%, transparent 74%);
    transform: translateX(-120%);
    transition: transform .6s ease;
  }

  .ki-plan-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 32px rgba(36, 55, 70, .22);
  }

  .ki-plan-cta:hover::after {
    transform: translateX(120%);
  }

  .ki-plan-card.is-plus .ki-plan-cta {
    background: linear-gradient(100deg, var(--ki-teal), #21a29d 58%, var(--ki-gold));
  }

  @media (max-width: 860px) {
    .ki-enroll-modal {
      align-items: center;
      justify-content: center;
      padding: 10px;
    }

    .ki-modal-panel {
      width: min(620px, 100%);
      max-height: calc(100svh - 20px);
      overflow: auto;
      padding: 26px 20px 22px;
      border-radius: 24px;
      margin: auto;
    }

    .ki-plan-grid {
      grid-template-columns: 1fr;
      gap: 14px;
    }

    .ki-plan-grid.is-single {
      grid-template-columns: 1fr;
    }

    .ki-plan-card {
      min-height: auto;
      padding: 22px;
    }

    .ki-plan-name {
      font-size: 30px;
    }

    .ki-recommended {
      position: static;
      width: fit-content;
      margin-bottom: 10px;
    }
  }

  @media (max-width: 560px) {
    .ki-enroll-modal {
      align-items: center;
      justify-content: center;
      padding: 8px;
    }

    .ki-modal-panel {
      max-height: calc(100svh - 16px);
      padding: 19px 15px 15px;
      border-radius: 22px;
      scrollbar-width: thin;
      margin: auto;
    }

    .ki-modal-close {
      top: 12px;
      right: 12px;
      width: 38px;
      height: 38px;
    }

    .ki-modal-close svg {
      width: 18px;
      height: 18px;
    }

    .ki-modal-kicker {
      max-width: calc(100% - 52px);
      margin-bottom: 7px;
      font-size: 9px;
      letter-spacing: .11em;
      line-height: 1.25;
    }

    .ki-modal-kicker::before {
      width: 7px;
      height: 7px;
      box-shadow: 0 0 0 5px rgba(194, 139, 46, .13);
    }

    .ki-modal-title {
      margin-bottom: 11px;
      padding-right: 45px;
      font-size: 27px;
      line-height: 1;
    }

    .ki-modal-course {
      margin-bottom: 5px;
      font-size: 15px;
      line-height: 1.22;
    }

    .ki-modal-desc {
      margin-bottom: 12px;
      max-width: 95%;
      font-size: 12.5px;
      line-height: 1.42;
    }

    .ki-plan-grid {
      gap: 10px;
    }

    .ki-plan-card {
      padding: 15px 15px 14px;
      border-radius: 18px;
      box-shadow: 0 10px 24px rgba(36, 55, 70, .07);
    }

    .ki-plan-card::before {
      height: 5px;
    }

    .ki-plan-label {
      margin: 3px 0 5px;
      font-size: 9.5px;
      letter-spacing: .12em;
    }

    .ki-plan-head {
      align-items: flex-start;
      gap: 10px;
      margin-bottom: 9px;
    }

    .ki-plan-name {
      margin: 0;
      font-size: 25px !important;
      line-height: .98;
    }

    .ki-plan-price {
      min-width: 72px;
      margin-top: -2px;
    }

    .ki-price-offer {
      font-size: 21px;
    }

    .ki-price-real {
      margin-top: 3px;
      font-size: 11.5px;
    }

    .ki-plan-course {
      display: none;
    }

    .ki-plan-sub {
      margin: 0 0 10px !important;
      font-size: 14px;
      line-height: 1.32;
    }

    .ki-plan-list {
      gap: 6px;
      margin-bottom: 12px;
    }

    .ki-plan-list li {
      gap: 8px;
      font-size: 14px;
      line-height: 1.26;
    }

    .ki-plan-list li::before {
      flex-basis: 18px;
      width: 18px;
      height: 18px;
      font-size: 10px;
    }

    .ki-plan-cta {
      min-height: 43px;
      padding: 10px 14px;
      font-size: 12.6px;
      letter-spacing: .06em;
    }

    .ki-recommended {
      margin: 0 0 7px;
      padding: 5px 9px;
      font-size: 8.8px;
    }
  }

  @media (max-width: 390px) {
    .ki-modal-panel {
      max-height: calc(100svh - 14px);
      padding: 17px 13px 13px;
      margin: auto;
    }

    .ki-modal-title {
      font-size: 25px;
    }

    .ki-modal-course {
      font-size: 14px;
    }

    .ki-modal-desc {
      font-size: 12.8px;
      margin-bottom: 10px;
    }

    .ki-plan-card {
      padding: 13px;
    }

    .ki-plan-name {
      font-size: 23px !important;
    }

    .ki-plan-price {
      min-width: 68px;
    }

    .ki-price-offer {
      font-size: 19px;
    }

    .ki-price-real {
      font-size: 10.8px;
    }

    .ki-plan-sub {
      font-size: 12px;
    }

    .ki-plan-list li {
      font-size: 11.8px;
    }

    .ki-plan-cta {
      min-height: 40px;
      font-size: 12px;
    }
  }
  /* Reveal */
  [data-fx]{opacity:1}
  @media(prefers-reduced-motion:no-preference){
    .js [data-fx]{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
    .js [data-fx].in{opacity:1;transform:none}
  }
  @media(max-width:880px){
    .est-grid{grid-template-columns:1fr;gap:32px}
    .estancia.reverse .est-visual{order:0}
    .estancia{min-height:0;padding:64px 0}
    .vt-grid{grid-template-columns:repeat(3,1fr)}
  }
    @media(max-width:880px){
        .join-box h3{
           font-size: 1.5rem;
        }
        .join-sub{
            font-size: .8rem;
            margin-bottom: 10px;
        }
        /*.jc h4{
            font-size: 1.2rem;
        }*/
        .jc .jc-btns .btn{
            padding: 10px 16px;
        }
        .fx.fx-tile.cl{
            top: 5%!important;
        }
        .fx.fx-tile.lo{
            left: 10%!important;
        }
    }/* End custom CSS */