*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#FFFFFF;
  --dark:#0D1117;
  --orange:#FF5A1F;
  --dark-2:#2A2F38;
  --cream:#FAF7F2;
  --cream-pale:#FAF9F7;
  --border:rgba(13,17,23,0.07);
  --card-shadow:0 2px 24px rgba(13,17,23,0.08);
}
html{scroll-behavior:smooth}
html,body{
  background:var(--bg);font-family:'Inter',sans-serif;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"ss01","cv11","kern";
}
::selection{background:var(--orange);color:#fff}
a:focus-visible,button:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
  border-radius:6px;
}
@media(hover:none){
  .btn-p:hover,.btn-s:hover,.nav-cta:hover,.dc-btn-p:hover,
  .esp-card:hover,.prog-card:hover{transform:none}
}

/* ── NAV ── */
nav.main-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 56px;height:68px;
  background:var(--cream);
  -webkit-backdrop-filter:none;
  backdrop-filter:none;
  border-bottom:1px solid rgba(13,17,23,.06);
  box-shadow:0 1px 0 rgba(13,17,23,.02), 0 8px 24px -16px rgba(13,17,23,.08);
}
.nav-logo img{height:44px;width:auto;display:block}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{
  position:relative;
  text-decoration:none;color:var(--dark);
  font-size:14px;font-weight:500;opacity:.55;
  letter-spacing:.01em;
  transition:opacity .2s;
}
.nav-links a::after{
  content:"";
  position:absolute;left:0;right:0;bottom:-22px;height:2px;
  background:var(--orange);
  transform:scaleX(0);transform-origin:center;
  transition:transform .35s;
}
.nav-links a:hover::after{transform:scaleX(.7)}
.nav-links a:hover{opacity:1}
.nav-links li:first-child a{opacity:.55;color:var(--dark)}
.nav-links li:first-child a::before{display:none}
.nav-links a.is-active{opacity:1;color:var(--dark)}
.nav-links a.is-active::after{transform:scaleX(.7)}
.nav-links a.is-active::before{
  content:"";position:absolute;left:50%;bottom:-22px;
  width:5px;height:5px;border-radius:50%;
  background:var(--orange);
  transform:translateX(-50%);
}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-login{
  font-size:14px;font-weight:600;color:var(--dark);
  opacity:.5;cursor:pointer;text-decoration:none;
  transition:opacity .2s;
}
.nav-login:hover{opacity:1}
.nav-cta{
  background:var(--orange);color:#fff;border:none;
  padding:10px 24px;border-radius:50px;
  font-size:14px;font-weight:600;cursor:pointer;
  font-family:'Inter',sans-serif;
  letter-spacing:.01em;
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 6px 16px -4px rgba(255,90,31,.45), 0 2px 6px -2px rgba(255,90,31,.35);
  transition:transform .15s,box-shadow .15s;
  white-space:nowrap;
}
.nav-cta:hover{
  transform:translateY(-1px) scale(1.02);
  box-shadow:0 1px 0 rgba(255,255,255,.3) inset, 0 12px 28px -6px rgba(255,90,31,.55), 0 4px 10px -2px rgba(255,90,31,.4);
}

/* ── NAV DROPDOWN ── */
.nav-has-dropdown{position:relative}
.nav-dropdown-trigger{display:flex;align-items:center;gap:5px;white-space:nowrap}
.nav-chevron{
  flex-shrink:0;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  opacity:.55;
}
.nav-has-dropdown.is-open .nav-chevron{transform:rotate(180deg);opacity:1}

.nav-dropdown{
  position:absolute;top:calc(100% + 18px);left:50%;
  transform:translateX(-50%) translateY(-6px);
  background:#fff;
  border:1px solid rgba(13,17,23,.08);
  border-radius:14px;
  box-shadow:0 16px 40px -8px rgba(13,17,23,.14), 0 4px 12px -4px rgba(13,17,23,.08);
  padding:8px;
  min-width:280px;
  opacity:0;pointer-events:none;
  transition:opacity .2s, transform .2s cubic-bezier(.4,0,.2,1);
  z-index:200;
}
.nav-dropdown::before{
  content:"";position:absolute;top:-6px;left:50%;
  transform:translateX(-50%);
  width:12px;height:6px;
  background:#fff;
  clip-path:polygon(50% 0%,0% 100%,100% 100%);
}
.nav-has-dropdown.is-open .nav-dropdown{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}

.nav-dropdown-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 12px;
  border-radius:10px;
  text-decoration:none;
  transition:background .15s;
  opacity:1 !important;
}
.nav-dropdown-item:hover{background:rgba(255,90,31,.05)}
.nav-dropdown-item::after{display:none !important}

.nav-dd-icon{
  flex-shrink:0;
  width:36px;height:36px;
  background:rgba(255,90,31,.08);
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);
}
.nav-dd-icon svg{width:18px;height:18px}

.nav-dd-text{display:flex;flex-direction:column;gap:2px}
.nav-dd-name{
  font-size:13px;font-weight:600;
  color:var(--dark);letter-spacing:-.01em;
}
.nav-dd-desc{
  font-size:11px;color:rgba(13,17,23,.45);
  font-weight:400;
}

/* Mobile dropdown */
@media(max-width:768px){
  .nav-has-dropdown{position:static}
  .nav-dropdown{
    position:static;
    transform:none;
    box-shadow:none;
    border:none;
    border-radius:0;
    background:rgba(13,17,23,.03);
    padding:4px 0 4px 16px;
    margin:0;
    min-width:auto;
    max-height:0;overflow:hidden;
    transition:max-height .3s cubic-bezier(.4,0,.2,1), opacity .2s;
    opacity:0;
  }
  .nav-dropdown::before{display:none}
  .nav-has-dropdown.is-open .nav-dropdown{
    max-height:300px;opacity:1;
    transform:none;
  }
  .nav-dropdown-item{padding:10px 24px}
  .nav-dd-icon{width:28px;height:28px}
  .nav-dd-icon svg{width:14px;height:14px}
  .nav-chevron{display:inline-block !important}
}

/* ── HERO ── */
.hero{
  height:calc(100vh - 132px);
  height:calc(100dvh - 132px);
  margin-top:68px;
  display:grid;
  grid-template-columns:40% 60%;
  overflow:hidden;
  min-height:500px;
}

/* ── LEFT ── */
.hero-left{
  display:flex;flex-direction:column;justify-content:center;
  padding:32px 40px 32px 56px;
  z-index:2;
}

.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;font-weight:700;letter-spacing:.2em;
  color:var(--orange);text-transform:uppercase;
  margin-bottom:16px;
  opacity:0;animation:fadeUp .5s ease .1s forwards;
}
.eyebrow-line{width:24px;height:1.5px;background:var(--orange);border-radius:2px}

.headline{
  font-family:'Playfair Display',serif;
  font-size:clamp(40px,4vw,64px);
  font-weight:800;line-height:1.02;
  letter-spacing:-.028em;
  color:var(--dark);
  margin-bottom:22px;
  opacity:1;
}
.headline .hl-line{display:block;overflow:hidden;padding:.05em 0}
.headline .hl-inner{
  display:inline-block;
  transform:translateY(110%);
  opacity:0;
  animation:hlReveal .9s cubic-bezier(.22,.61,.36,1) forwards;
}
.headline .hl-line:nth-child(1) .hl-inner{animation-delay:.18s}
.headline .hl-line:nth-child(2) .hl-inner{animation-delay:.30s}
.headline .hl-line:nth-child(3) .hl-inner{animation-delay:.42s}
@keyframes hlReveal{to{transform:translateY(0);opacity:1}}
.w-red{
  font-style:italic;
  font-family:'Playfair Display',serif;
  background:linear-gradient(180deg, var(--orange) 0%, #CC4819 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}

/* Subline: objection-crushing format */
@keyframes fadeUpSubline{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:.62;transform:translateY(0)}
}
.subline{
  font-size:14px;line-height:1.7;
  color:#3a3a44;opacity:0;
  max-width:400px;
  margin-bottom:12px;
  animation:fadeUpSubline .6s ease .34s forwards;
}

/* Quick specs — answers: online? duration? live? */
.specs{
  display:flex;align-items:center;gap:0;
  margin-bottom:32px;
  opacity:0;animation:fadeUp .5s ease .44s forwards;
}
.spec{
  display:flex;align-items:center;gap:5px;
  font-size:12px;font-weight:500;
  color:rgba(13,17,23,.6);
  padding:0 14px;
  border-right:1px solid rgba(13,17,23,.14);
  letter-spacing:.01em;
}
.spec:first-child{padding-left:0}
.spec:last-child{border-right:none;padding-right:0}
.spec:hover{color:var(--dark)}
.spec-icon{font-size:13px}

/* Social proof strip */
.proof-strip{
  display:flex;align-items:flex-start;gap:14px;
  margin-bottom:28px;
  padding:14px 16px;
  background:rgba(13,17,23,.025);
  border-left:2px solid var(--orange);
  border-radius:0 8px 8px 0;
  max-width:440px;
  opacity:0;animation:fadeUp .5s ease .5s forwards;
}
.proof-avatars{display:flex}
.pav{
  width:28px;height:28px;border-radius:50%;
  margin-right:-7px;
  font-size:9px;font-weight:700;color:#fff;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  box-shadow:0 0 0 2px #fff, 0 2px 6px rgba(13,17,23,.15);
  transition:transform .3s;
}
.proof-avatars:hover .pav{transform:translateX(-2px)}
.proof-avatars .pav:hover{transform:translateY(-2px) scale(1.08)}
.pav1{background:#6366f1}.pav2{background:#f59e0b}
.pav3{background:#22c55e}.pav4{background:#ec4899}
.proof-text{
  margin-left:16px;
  font-size:13px;font-weight:600;color:var(--dark);
}
.proof-text span{color:var(--orange)}

/* Buttons */
.btns{
  display:flex;gap:0;align-items:center;
  margin-bottom:10px;
  opacity:0;animation:fadeUp .6s ease .58s forwards;
}
.btn-p{
  display:flex;align-items:center;gap:8px;
  background:linear-gradient(180deg, #FF7043 0%, var(--orange) 55%, #CC4819 100%);
  color:#fff;
  padding:15px 30px;border-radius:50px;
  font-size:14px;font-weight:700;text-decoration:none;
  letter-spacing:.01em;
  box-shadow:0 1px 0 rgba(255,255,255,.28) inset, 0 0 0 1px rgba(255,90,31,.4), 0 10px 28px -6px rgba(255,90,31,.5), 0 4px 10px -2px rgba(255,90,31,.35);
  transition:transform .15s,box-shadow .15s;
  white-space:nowrap;
}
.btn-p:hover{
  transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.35) inset, 0 0 0 1px rgba(255,90,31,.5), 0 18px 40px -8px rgba(255,90,31,.6), 0 6px 14px -2px rgba(255,90,31,.4);
}
.btn-s{
  display:flex;align-items:center;gap:8px;
  background:rgba(13,17,23,.02);color:var(--dark);
  padding:14px 24px;border-radius:50px;
  font-size:14px;font-weight:600;text-decoration:none;
  border:1.5px solid rgba(13,17,23,.12);
  transition:border-color .2s,background .15s;
  white-space:nowrap;
}
.btn-s:hover{border-color:rgba(13,17,23,.35);background:rgba(13,17,23,.04);transform:translateY(-1px)}

/* Trust line under CTA */
.trust{
  display:flex;align-items:center;gap:14px;
  font-size:11px;color:var(--dark);
  font-weight:500;
  margin-top:6px;margin-bottom:0;
  opacity:0;animation:fadeUp .5s ease .7s forwards;
}
.trust b{color:var(--orange);font-weight:700}
.trust-hot{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--orange);
  font-size:13px;font-weight:700;
  letter-spacing:.005em;
}
.trust-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(255,90,31,.18);
  animation:trustPulse 2.2s ease-in-out infinite;
}
@keyframes trustPulse{
  0%,100%{box-shadow:0 0 0 4px rgba(255,90,31,.18)}
  50%{box-shadow:0 0 0 7px rgba(255,90,31,.04)}
}
.trust-sub{
  font-size:11px;color:var(--dark);opacity:.4;
  font-weight:500;
}

/* ── RIGHT ── */
.hero-right{position:relative;overflow:hidden}
.hero-right::after{
  content:"";
  position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 0%, transparent 22%),
    radial-gradient(120% 80% at 50% 100%, rgba(13,17,23,.12), transparent 60%);
  z-index:1;
}
.hero-slider{position:absolute;inset:0;overflow:hidden}
.hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:60% center;
  opacity:0;
  transform:scale(1.04);
  transition:opacity 1.2s cubic-bezier(.4,0,.2,1);
  will-change:opacity,transform;
}
.hero-slide.is-on{
  opacity:1;
  animation:heroKB 9s ease-out forwards;
}
@keyframes heroKB{
  from{transform:scale(1.04)}
  to{transform:scale(1.10)}
}
.hero-slider::after{
  content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(
    to right,
    rgba(255,255,255,.92) 0%,
    rgba(255,255,255,.55) 12%,
    rgba(255,255,255,.12) 26%,
    rgba(255,255,255,0) 42%,
    transparent 100%
  );
}

/* Caption + pagination */
.hero-meta{
  position:absolute;left:24px;bottom:22px;z-index:3;
  display:flex;align-items:center;gap:18px;
  pointer-events:auto;
}
.hero-caption{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  opacity:0;transform:translateY(4px);
  transition:opacity .5s ease, transform .5s ease;
}
.hero-caption.is-on{opacity:1;transform:none}
.hero-pag{display:flex;align-items:center;gap:10px}
.hero-pag button{
  width:22px;height:2px;border:none;padding:0;cursor:pointer;
  background:rgba(13,17,23,.18);
  transition:background .3s ease, width .3s ease;
}
.hero-pag button.is-on{background:var(--orange);width:32px}
.hero-pag button:hover{background:rgba(13,17,23,.4)}
.hero-slider:hover .hero-slide.is-on{animation-play-state:paused}

/* Eyebrow metadata live */
.eyebrow-meta{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(13,17,23,.55);
  font-weight:500;
}
.eyebrow-meta .eb-item{display:inline-flex;align-items:center;gap:6px}
.eyebrow-meta .eb-num{color:var(--orange);font-weight:700;font-feature-settings:"tnum"}
.eyebrow-meta .eb-sep{opacity:.3}
.eyebrow-meta .eb-live{color:var(--orange);font-weight:600}
.eyebrow-meta .eb-pulse{
  width:6px;height:6px;border-radius:50%;
  background:#22c55e;
  box-shadow:0 0 0 3px rgba(34,197,94,.22);
  animation:ebPulse 2s ease-in-out infinite;
}
@keyframes ebPulse{
  0%,100%{box-shadow:0 0 0 3px rgba(34,197,94,.22)}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,.05)}
}

/* Hero numeric pagination */
.hero-pag-num{gap:14px}
.hpag-btn{
  background:transparent;border:none;padding:0;
  display:flex;align-items:center;gap:8px;
  width:auto;height:auto;cursor:pointer;
}
.hpag-num{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;letter-spacing:.12em;
  color:rgba(13,17,23,.35);
  transition:color .35s ease;
  font-feature-settings:"tnum";
}
.hpag-btn.is-on .hpag-num{color:var(--orange)}
.hpag-bar{
  display:block;width:0;height:1.5px;
  background:rgba(13,17,23,.12);
  transition:width .4s ease;
  overflow:hidden;position:relative;
}
.hpag-btn.is-on .hpag-bar{width:48px}
.hpag-fill{
  position:absolute;inset:0;width:0%;
  background:var(--orange);
  transform-origin:left center;
}
.hpag-btn.is-on .hpag-fill{animation:hpagFill 5.8s linear forwards}
.hpag-btn.is-paused.is-on .hpag-fill{animation-play-state:paused}
@keyframes hpagFill{from{width:0%}to{width:100%}}

/* Cards adaptive fade on people slides */
.hero-right.slide-people .cards{opacity:.6;transition:opacity .8s ease}
.hero-right .cards{transition:opacity .8s ease}

/* proof-strip internals */
.pav-real{
  width:38px;height:38px;
  background:#e8d8cc;
  font-size:0;color:transparent;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 0 2px #fff, 0 4px 10px rgba(255,90,31,.25);
  flex-shrink:0;margin:0;
  background-size:cover;background-position:center top;
  overflow:hidden;
}
.proof-quote{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:14px;line-height:1.45;color:var(--dark);opacity:.85;margin:0;
}
.proof-meta{font-size:11px;color:var(--dark);opacity:.55;letter-spacing:.01em;margin:0}
.proof-meta b{font-weight:700;color:var(--dark);opacity:1}
.proof-count{color:var(--orange);font-weight:600}

@media(prefers-reduced-motion:reduce){
  .headline .hl-inner{animation:none;transform:none;opacity:1}
  .trust-dot{animation:none}
  .eyebrow-meta .eb-pulse{animation:none}
  .hpag-btn.is-on .hpag-fill{animation:none;width:100%}
}

/* ── MOBILE NAV ── */
.nav-hamburger{
  display:none;
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;
  width:40px;height:40px;
  background:none;border:none;cursor:pointer;
  padding:4px;border-radius:8px;
  transition:background .2s;
  margin-left:auto;
}
.nav-hamburger:hover{background:rgba(13,17,23,.06)}
.nav-hamburger span{
  display:block;width:22px;height:2px;
  background:var(--dark);border-radius:2px;
  transition:transform .3s cubic-bezier(.4,0,.2,1), opacity .2s;
  transform-origin:center;
}
.nav-hamburger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-hamburger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:768px){
  nav.main-nav{padding:0 20px}
  .nav-hamburger{display:flex}
  .nav-login{display:none}
  .nav-cta{display:none}

  .nav-links{
    display:flex;
    flex-direction:column;
    position:fixed;
    top:68px;left:0;right:0;
    background:rgba(255,255,255,.97);
    -webkit-backdrop-filter:saturate(180%) blur(20px);
    backdrop-filter:saturate(180%) blur(20px);
    border-bottom:1px solid rgba(13,17,23,.08);
    padding:8px 0 20px;
    gap:0;
    list-style:none;
    transform:translateY(-8px);
    opacity:0;
    pointer-events:none;
    transition:transform .25s cubic-bezier(.4,0,.2,1), opacity .2s;
    z-index:99;
    box-shadow:0 12px 32px -8px rgba(13,17,23,.12);
  }
  .nav-links.is-open{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }
  .nav-links li{width:100%}
  .nav-links a{
    display:block;
    padding:14px 24px;
    font-size:15px;
    opacity:1;
    border-bottom:1px solid rgba(13,17,23,.05);
  }
  .nav-links a::after{display:none}
  .nav-links a.is-active{color:var(--orange);opacity:1}
  .nav-links a.is-active::before{display:none}

  /* CTA dentro del menú móvil */
  .nav-links::after{
    content:"Ver programas →";
    display:block;
    margin:16px 20px 0;
    padding:13px 20px;
    background:var(--orange);
    color:#fff;
    font-size:14px;font-weight:600;
    border-radius:50px;
    text-align:center;
    cursor:pointer;
    box-shadow:0 6px 16px -4px rgba(255,90,31,.45);
  }
}

/* ── HERO MOBILE ── */
@media(max-width:768px){
  .hero{
    grid-template-columns:1fr;
    height:auto;
    min-height:calc(100svh - 68px);
  }
  .hero-left{
    padding:36px 20px 32px;
    order:1;
  }
  .hero-right{
    order:2;
    height:52vw;
    min-height:260px;
    max-height:360px;
  }
  .headline{font-size:clamp(34px,9vw,52px)}
  .subline{max-width:100%}
  .proof-strip{display:none}
  .specs{flex-wrap:wrap;gap:8px}
  .spec{padding:0 10px;font-size:11px}
}
@media(max-width:480px){
  .hero-left{padding:28px 16px 24px}
  .headline{font-size:clamp(30px,10vw,44px)}
  /* Ocultar testimonio en mobile */
  .proof-strip{display:none}
  /* Ocultar todas las cards menos c2 */
  .c1,.c3,.c4,.c5{display:none}
  /* Reposicionar c2 para mobile */
  .c2{
    top:auto;left:50%;bottom:14px;
    transform:translateX(-50%);
    min-width:210px;max-width:calc(100% - 32px);
    animation:cardIn .5s ease .8s forwards;
  }
}

/* ── CARDS ── */
.cards{position:absolute;inset:0;z-index:3;pointer-events:none}
.card{
  position:absolute;
  background:#fff;
  border:1px solid rgba(13,17,23,.08);
  border-radius:14px;padding:13px 16px;
  box-shadow:var(--card-shadow);
  pointer-events:auto;opacity:0;
}

.c1{top:7%; left:22%; min-width:180px; animation:cardIn .5s ease .8s  forwards; background:rgba(255,255,255,.96); backdrop-filter:blur(14px) saturate(160%); -webkit-backdrop-filter:blur(14px) saturate(160%);}
.c2{top:32%;left:18%; min-width:172px; animation:cardIn .5s ease .95s forwards; background:rgba(255,255,255,.96); backdrop-filter:blur(14px) saturate(160%); -webkit-backdrop-filter:blur(14px) saturate(160%);}
.c3{top:7%; right:3%; min-width:210px; animation:cardIn .5s ease 1.1s forwards}
.c4{top:48%;right:3%; min-width:188px; animation:cardIn .5s ease 1.25s forwards}
.c5{top:67%;right:3%; min-width:195px; animation:cardIn .5s ease 1.4s forwards}

.c1.fl{animation:cardIn .5s ease .8s  forwards, float1 4.4s ease-in-out 1.4s infinite}
.c2.fl{animation:cardIn .5s ease .95s forwards, float2 5.2s ease-in-out 1.55s infinite}
.c3.fl{animation:cardIn .5s ease 1.1s forwards, float3 4.8s ease-in-out 1.7s infinite}
.c4.fl{animation:cardIn .5s ease 1.25s forwards,float1 5.5s ease-in-out 1.85s infinite}
.c5.fl{animation:cardIn .5s ease 1.4s forwards, float2 5.0s ease-in-out 2.0s infinite}

/* Card internals */
.clabel{
  display:flex;align-items:center;gap:5px;
  font-size:9px;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--dark);opacity:.28;
  margin-bottom:7px;
}
.cldot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.cgreen{background:#22c55e}.corange{background:var(--orange)}.cblue{background:#3b82f6}
.ctitle{font-size:13px;font-weight:700;color:var(--dark);line-height:1.35;margin-bottom:2px}
.csub{font-size:10px;color:var(--dark);opacity:.35;line-height:1.4}

/* ── Result metric cards ── */
.card-metric{
  font-size:26px;font-weight:800;letter-spacing:-.03em;
  color:var(--dark);line-height:1;margin:5px 0 7px;
}
.card-tools{
  display:flex;align-items:center;gap:7px;
  margin-bottom:5px;
}
.card-tool-label{
  font-size:10px;font-weight:600;color:var(--dark);
  opacity:.45;letter-spacing:.01em;
}
.clink{font-size:10px;font-weight:700;color:var(--orange);margin-top:7px;display:inline-block;text-decoration:none}

/* Tool logo row */
.tool-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}
.tool-logo{height:15px;width:auto}
.tool-stat{margin-left:auto;font-size:10px;font-weight:700;color:#16a34a;background:#f0fdf4;padding:2px 7px;border-radius:20px}

/* Progress */
.progress-num{font-family:'Playfair Display',serif;font-size:26px;font-weight:800;color:var(--dark);line-height:1;margin-bottom:7px}
.prog-wrap{background:rgba(13,17,23,.07);border-radius:4px;height:3px;overflow:hidden}
.prog-fill{height:100%;width:72%;background:var(--orange);border-radius:4px}
.prog-meta{display:flex;justify-content:space-between;margin-top:5px}

/* Live badge */
.live-badge{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(255,90,31,.08);border-radius:20px;
  padding:3px 9px;font-size:9px;font-weight:700;
  color:var(--orange);letter-spacing:.05em;
  text-transform:uppercase;margin-bottom:7px;
}
.live-dot{width:5px;height:5px;border-radius:50%;background:var(--orange);animation:pulse 1.5s ease-in-out infinite;flex-shrink:0}

/* Urgency badge on card 3 */
.urgency{
  display:inline-flex;align-items:center;gap:4px;
  background:#fff7ed;border-radius:6px;
  padding:3px 8px;font-size:9.5px;font-weight:700;
  color:#c2410c;margin-top:7px;
}

/* Avatars */
.avatars{display:flex;align-items:center;margin:7px 0 5px}
.av{width:22px;height:22px;border-radius:50%;border:2px solid #fff;margin-right:-5px;display:flex;align-items:center;justify-content:center;font-size:7.5px;font-weight:700;color:#fff;flex-shrink:0}
.av1{background:#6366f1}.av2{background:#22c55e}.av3{background:#f59e0b}.av4{background:#ec4899}.av5{background:#14b8a6}
.avcount{font-size:13px;font-weight:700;color:var(--dark);margin-left:12px}

/* Mini chart */
.mini-chart{display:flex;align-items:flex-end;gap:3px;height:28px;margin:8px 0 4px}
.bar{flex:1;border-radius:3px 3px 0 0;background:rgba(13,17,23,.08)}
.bar.hi{background:var(--orange)}

/* Testimonial card */
.testi-photo{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,#6366f1,#ec4899);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#fff;
  margin-bottom:8px;flex-shrink:0;
}
.testi-quote{font-size:11px;line-height:1.5;color:var(--dark);opacity:.7;font-style:italic;margin-bottom:6px}
.testi-name{font-size:10px;font-weight:700;color:var(--dark)}
.testi-role{font-size:10px;color:var(--dark);opacity:.38}

/* ── LOGOS BAR ── */
.logos-bar{
  height:64px;background:#fff;
  display:flex;align-items:center;
  padding:0 56px;
  border-top:1px solid var(--border);
}
.logos-label-inline{
  font-size:10px;font-weight:600;
  color:var(--dark);opacity:.22;
  text-transform:uppercase;letter-spacing:.08em;
  white-space:nowrap;margin-right:32px;
  flex-shrink:0;
}
.logos-row{display:flex;align-items:center;gap:36px;flex:1;justify-content:center}
.logo-item img{height:20px;width:auto;opacity:.5;transition:opacity .25s}
.logo-item img:hover{opacity:.85}

@media(max-width:768px){
  .logos-bar{
    height:auto;padding:16px 20px;
    gap:14px;align-items:center;
  }
  .logos-label-inline{margin-right:0}
  .logos-row{display:inline-flex;flex-wrap:nowrap;gap:20px;padding:0 20px}
  .logo-item img{height:16px;opacity:.4}
}

/* ── ANIMATIONS ── */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes cardIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes float1{
  0%,100%{transform:translateY(0) rotate(0deg)}
  35%{transform:translateY(-7px) rotate(.25deg)}
  68%{transform:translateY(-3px) rotate(-.18deg)}
}
@keyframes float2{
  0%,100%{transform:translateY(0) rotate(0deg)}
  42%{transform:translateY(-9px) rotate(-.28deg)}
  72%{transform:translateY(-4px) rotate(.18deg)}
}
@keyframes float3{
  0%,100%{transform:translateY(0) rotate(0deg)}
  28%{transform:translateY(-5px) rotate(.2deg)}
  62%{transform:translateY(-10px) rotate(-.22deg)}
  82%{transform:translateY(-3px) rotate(.1deg)}
}
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.4;transform:scale(.75)}
}

/* ── FOOTER ── */
.pa-footer{background:var(--dark);color:#fff;padding:80px 0 28px;position:relative;overflow:hidden}
.pa-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--orange),transparent);opacity:.6}
.ft-wrap{max-width:1240px;margin:0 auto;padding:0 48px}
.ft-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;padding-bottom:56px;border-bottom:1px solid rgba(255,255,255,.08)}
.ft-brand{display:flex;flex-direction:column;gap:18px}
.ft-logo{display:flex;align-items:center;gap:12px}
.ft-logo-mark{width:38px;height:38px;border-radius:10px;background:var(--orange);color:#fff;display:grid;place-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-weight:700;font-size:14px;letter-spacing:.04em}
.ft-logo-name{font-family:'Instrument Serif',Georgia,serif;font-size:22px;letter-spacing:-.01em;font-weight:400}
.ft-logo-name em{font-style:italic;color:var(--orange)}
.ft-tag{font-size:14px;line-height:1.6;color:rgba(255,255,255,.6);margin:0;max-width:340px}
.ft-social{display:flex;gap:10px;margin-top:4px}
.ft-social a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;color:rgba(255,255,255,.75);transition:background .2s,color .2s,border-color .2s,transform .2s}
.ft-social svg{width:16px;height:16px}
.ft-social a:hover{background:var(--orange);border-color:var(--orange);color:#fff;transform:translateY(-2px)}
.ft-col{display:flex;flex-direction:column;gap:12px}
.ft-col h4{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--orange);font-weight:600;margin:0 0 6px}
.ft-col a{font-size:14px;color:rgba(255,255,255,.72);text-decoration:none;transition:color .2s,transform .2s;line-height:1.4}
.ft-col a:hover{color:#fff;transform:translateX(2px)}
.ft-cta-col p{font-size:14px;line-height:1.5;color:rgba(255,255,255,.6);margin:0 0 4px}
.ft-cta-btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;padding:10px 16px;border-radius:999px;font-size:13px;font-weight:600;text-decoration:none;align-self:flex-start;transition:transform .2s,box-shadow .2s,background .2s}
.ft-cta-btn:hover{background:#CC4819;transform:translateY(-2px);box-shadow:0 12px 24px -8px rgba(255,90,31,.5)}
.ft-cta-btn span{transition:transform .2s}
.ft-cta-btn:hover span{transform:translateX(3px)}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:24px;flex-wrap:wrap}
.ft-copy{font-size:12px;color:rgba(255,255,255,.5);font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:.04em}
.ft-links{display:flex;gap:24px}
.ft-links a{font-size:12px;color:rgba(255,255,255,.5);text-decoration:none;transition:color .2s}
.ft-links a:hover{color:var(--orange)}
@media (max-width:900px){
  .ft-top{grid-template-columns:1fr 1fr;gap:40px}
  .ft-brand{grid-column:1/-1}
}
@media (max-width:768px){
  .ft-wrap{padding:0 20px}
  .tst-wrap{padding:0 20px}
  .cm-wrap{padding:0 20px}
}
@media (max-width:560px){
  .pa-footer{padding:60px 0 24px}
  .ft-wrap{padding:0 16px}
  .ft-top{grid-template-columns:1fr;gap:32px;padding-bottom:40px}
  .ft-bottom{flex-direction:column;align-items:flex-start;gap:16px}
}



/* ── EXTRA SECTIONS (consolidated) ── */
/* Scoped to .pa-programs so it doesn't leak into hero */
.pa-programs{
  --pa-bg:var(--cream-pale);
  --pa-fg:var(--dark);
  --pa-primary:var(--orange);
  --pa-primary-soft:#f4e8e4;
  --pa-border:rgba(13,17,23,.08);
  --pa-border-soft:rgba(13,17,23,.04);
  --pa-mono:'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;
  --pa-serif:'Playfair Display',serif;
  --pa-sans:'Inter',sans-serif;
  --pa-ease:cubic-bezier(.32,.72,0,1);

  background:var(--pa-bg);
  color:var(--pa-fg);
  font-family:var(--pa-sans);
  position:relative;
  overflow:hidden;
}
.pa-programs ::selection{background:rgba(255,90,31,.2)}

.pa-wrap{max-width:1240px;margin:0 auto;padding:0 32px}

/* ── HEADER ── */
.pa-header{
  padding:64px 0 72px;
  border-bottom:1px solid var(--pa-border);
}
.pa-header-grid{
  display:flex;flex-direction:column;gap:40px;
  justify-content:space-between;align-items:flex-start;
}
@media(min-width:900px){
  .pa-header-grid{flex-direction:row;align-items:flex-end;gap:48px}
}
.pa-eyebrow{
  font-family:var(--pa-mono);
  font-size:10px;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--pa-primary);
  margin-bottom:20px;display:block;
}
.pa-h2{
  font-family:var(--pa-serif);
  font-size:clamp(32px,4.2vw,62px);
  font-weight:300;line-height:1.06;
  letter-spacing:-.018em;
  font-style:italic;
  max-width:16ch;
  color:var(--pa-fg);
  text-wrap:balance;
}
.pa-h2 .pa-h2-bold{font-style:normal;font-weight:600;color:var(--pa-primary)}
.pa-header-meta{max-width:320px;padding-bottom:6px}
.pa-lede{
  font-size:14px;line-height:1.65;
  color:rgba(13,17,23,.62);
  margin-bottom:28px;text-wrap:pretty;
}
.pa-link{
  display:inline-flex;align-items:center;gap:12px;
  font-size:11px;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--pa-fg);text-decoration:none;
  transition:color .3s var(--pa-ease);
}
.pa-link-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--pa-primary);
  transition:transform .3s var(--pa-ease);
}
.pa-link:hover .pa-link-dot{transform:scale(1.6)}

/* ── FLAGSHIP (01) ── */
.pa-flagship{
  border-bottom:1px solid var(--pa-border);
  padding:80px 0;
  display:grid;
  grid-template-columns:48px 1fr;
  gap:48px;
  position:relative;
}
@media(min-width:1000px){
  .pa-flagship{
    grid-template-columns:48px minmax(0,1fr) minmax(0,1fr);
    gap:96px;
  }
}
.pa-num{
  font-family:var(--pa-serif);
  font-style:italic;
  font-size:38px;font-weight:400;
  color:rgba(255,90,31,.3);
  line-height:1;
}
.pa-flagship-body{
  display:flex;flex-direction:column;
  justify-content:space-between;gap:48px;
  min-width:0;
}
.pa-tag-row{
  display:flex;align-items:center;gap:14px;
  margin-bottom:24px;flex-wrap:wrap;
}
.pa-tag{
  background:var(--pa-primary);
  color:#fff;
  font-family:var(--pa-mono);
  font-size:9.5px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  padding:3px 8px;border-radius:2px;
}
.pa-tag-meta{
  font-family:var(--pa-mono);
  font-size:9.5px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(13,17,23,.4);
}
.pa-flagship-title{
  font-family:var(--pa-serif);
  font-size:clamp(34px,3.8vw,52px);
  font-weight:500;line-height:1.05;
  letter-spacing:-.012em;
  margin-bottom:24px;
  transition:background .4s var(--pa-ease),-webkit-background-clip .4s,color .4s var(--pa-ease);
}
.pa-flagship:hover .pa-flagship-title{
  background:linear-gradient(135deg,var(--orange) 0%,#f2916b 60%,#e8724a 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.pa-flagship-desc{
  font-size:15px;line-height:1.7;
  color:rgba(13,17,23,.7);
  max-width:38ch;margin-bottom:0;
}
.pa-stats{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:28px 24px;
  padding-top:32px;
  border-top:1px solid var(--pa-border-soft);
}
@media(min-width:600px){
  .pa-stats{grid-template-columns:repeat(4,1fr)}
}
.pa-stat-label{
  display:block;
  font-family:var(--pa-mono);
  font-size:9.5px;font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;
  color:rgba(13,17,23,.4);
  margin-bottom:6px;
}
.pa-stat-val{font-size:14px;font-weight:500;color:var(--pa-fg)}

.pa-flagship-visual{position:relative;align-self:stretch;min-height:280px}
.pa-flagship-img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  aspect-ratio:4/3;
}
.pa-apply{
  position:absolute;right:-16px;bottom:-16px;
  width:104px;height:104px;border-radius:50%;
  background:var(--pa-fg);color:#fff;border:none;
  font-family:var(--pa-mono);
  font-size:10px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;
  transition:background .3s var(--pa-ease), transform .3s var(--pa-ease);
  box-shadow:0 12px 32px -8px rgba(13,17,23,.35);
}
.pa-apply:hover{background:var(--pa-primary);transform:scale(1.06) rotate(-3deg)}

/* ── SPECIALIZATIONS (02-04) ── */
.pa-spec-grid{
  display:grid;
  grid-template-columns:1fr;
}
@media(min-width:900px){
  .pa-spec-grid{grid-template-columns:repeat(3,1fr)}
}
.pa-spec{
  padding:72px 0;
  display:flex;flex-direction:column;
  border-bottom:1px solid var(--pa-border);
  position:relative;
}
@media(min-width:900px){
  .pa-spec{
    padding:80px 48px;
    border-bottom:none;
    border-right:1px solid var(--pa-border);
  }
  .pa-spec:first-child{padding-left:0}
  .pa-spec:last-child{padding-right:0;border-right:none}
}
.pa-spec:last-child{border-bottom:none}

.pa-spec-head{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:32px;
}
.pa-spec-num{
  font-family:var(--pa-serif);
  font-style:italic;font-size:28px;font-weight:400;
  color:rgba(255,90,31,.3);line-height:1;
}
.pa-spec-kind{
  font-family:var(--pa-mono);
  font-size:9.5px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--pa-primary);
}
.pa-spec-title{
  font-family:var(--pa-serif);
  font-size:26px;font-weight:500;line-height:1.15;
  letter-spacing:-.005em;
  margin-bottom:16px;
  transition:background .4s var(--pa-ease), -webkit-background-clip .4s, color .4s var(--pa-ease);
}
.pa-spec:hover .pa-spec-title{
  background:linear-gradient(135deg,var(--orange) 0%,#f2916b 60%,#e8724a 100%);
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;
}
.pa-spec-desc{
  font-size:14px;line-height:1.65;
  color:rgba(13,17,23,.6);
  margin-bottom:36px;
  min-height:64px;text-wrap:pretty;
}
.pa-spec-data{
  list-style:none;padding:0;margin:0 0 40px;
}
.pa-spec-data li{
  display:flex;justify-content:space-between;align-items:baseline;
  font-size:12px;
  padding:10px 0;
  border-bottom:1px solid var(--pa-border-soft);
}
.pa-spec-data li:last-child{border-bottom:none}
.pa-spec-data .k{
  font-family:var(--pa-mono);font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;
  color:rgba(13,17,23,.4);
}
.pa-spec-data .v{font-weight:500;color:var(--pa-fg)}
.pa-spec-data .v.accent{color:var(--pa-primary)}

/* ── TOOLS ── */
.pa-tools{margin-bottom:20px;min-height:100px}
.pa-tools-label{
  font-family:var(--pa-mono);
  font-size:9.5px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  color:rgba(13,17,23,.38);
  display:block;margin-bottom:12px;
}
.pa-tools-list{display:flex;flex-wrap:wrap;gap:8px 14px}
.pa-tool-item{
  display:flex;align-items:center;gap:5px;
  font-size:12px;font-weight:500;
  color:rgba(13,17,23,.65);
}
.pa-tool-item svg{flex-shrink:0}

.pa-spec-cta{
  width:100%;
  background:transparent;
  border:1px solid rgba(13,17,23,.12);
  color:var(--pa-fg);
  padding:18px 20px;
  font-family:var(--pa-mono);
  font-size:10px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;
  transition:background .3s var(--pa-ease), color .3s var(--pa-ease), border-color .3s var(--pa-ease);
  text-decoration:none;display:block;text-align:center;
  margin-top:auto;
}
.pa-spec:hover .pa-spec-cta{
  background:var(--pa-primary);
  color:#fff;
  border-color:var(--pa-primary);
}

/* ── FOOTER ROW ── */
.pa-foot{
  border-top:1px solid var(--pa-border);
  padding:80px 0 112px;
  display:flex;flex-direction:column;gap:32px;
  align-items:center;justify-content:space-between;
  text-align:center;
}
@media(min-width:800px){
  .pa-foot{flex-direction:row;text-align:left}
}
.pa-foot-q{
  font-family:var(--pa-serif);
  font-style:italic;font-size:26px;font-weight:400;
  line-height:1.2;margin-bottom:8px;
}
.pa-foot-sub{
  font-size:14px;color:rgba(13,17,23,.55);
}
.pa-foot-btn{
  padding:18px 32px;
  background:var(--pa-primary);color:#fff;border:none;
  font-family:var(--pa-mono);font-size:10px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 8px 24px -6px rgba(255,90,31,.45);
  transition:filter .25s var(--pa-ease), transform .25s var(--pa-ease);
  text-decoration:none;display:inline-block;white-space:nowrap;
}
.pa-foot-btn:hover{filter:brightness(1.08);transform:translateY(-2px)}


/* ── v3 IMPROVEMENTS ── */

/* Metadata bar between header and flagship */
.pa-metabar{
  display:flex;flex-wrap:wrap;gap:24px 56px;
  padding:22px 0;
  border-bottom:1px solid var(--pa-border);
  font-family:var(--pa-mono);
  font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(13,17,23,.55);
}
.pa-metabar b{font-weight:600;color:var(--pa-fg);margin-right:8px}
.pa-metabar .pa-metabar-dot{
  display:inline-block;width:5px;height:5px;border-radius:50%;
  background:var(--pa-primary);margin-right:10px;vertical-align:middle;
  animation:pa-pulse 2.4s ease-in-out infinite;
}
@keyframes pa-pulse{0%,100%{opacity:.4}50%{opacity:1}}

/* index rail removed — hidden by design */

/* Instructor row */
.pa-instructor{
  display:flex;align-items:center;gap:12px;
  padding:14px 0;margin-top:24px;
  border-top:1px solid var(--pa-border-soft);
  font-family:var(--pa-mono);
  font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(13,17,23,.55);
}
.pa-instructor-avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--pa-primary),#f2916b);
  flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:600;font-size:10px;letter-spacing:0;
}
.pa-instructor b{color:var(--pa-fg);font-weight:600;margin-right:6px}

/* Learning outcomes for specs */
.pa-outcomes{
  list-style:none;padding:0;margin:0 0 28px;
  display:flex;flex-direction:column;gap:8px;
}
.pa-outcomes li{
  font-size:12px;line-height:1.55;color:rgba(13,17,23,.72);
  display:flex;gap:10px;align-items:baseline;
}
.pa-outcomes li::before{
  content:"·";color:var(--pa-primary);font-family:var(--pa-mono);
  font-weight:700;font-size:14px;line-height:1;
}

/* Spec hover: top line draws in */
.pa-spec::before{
  content:"";position:absolute;top:0;left:0;height:1px;width:0;
  background:var(--pa-primary);
  transition:width .55s var(--pa-ease);
}
.pa-spec:hover::before{width:100%}

/* Rotating Aplicar button */
.pa-apply-rotor{
  position:absolute;right:-18px;bottom:-18px;
  width:128px;height:128px;
  cursor:pointer;
  filter:drop-shadow(0 20px 40px rgba(255,90,31,.42));
}
.pa-apply-rotor svg{
  width:100%;height:100%;display:block;
  animation:pa-spin 14s linear infinite;
}
.pa-apply-rotor:hover svg{animation-duration:5s}
.pa-apply-rotor .pa-apply-disc{
  position:absolute;inset:18px;border-radius:50%;
  background:var(--pa-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;
  transition:transform .3s var(--pa-ease), box-shadow .3s var(--pa-ease);
  box-shadow:0 8px 24px -4px rgba(255,90,31,.5);
}
.pa-apply-rotor:hover .pa-apply-disc{
  transform:scale(1.1);
  box-shadow:0 16px 40px -6px rgba(255,90,31,.65);
}
@keyframes pa-spin{to{transform:rotate(360deg)}}

/* Footnote */
.pa-footnote{
  border-top:1px solid var(--pa-border-soft);
  padding:24px 0 8px;
  font-family:var(--pa-mono);
  font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(13,17,23,.4);
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
}
.pa-footnote span b{color:var(--pa-primary);font-weight:600;margin-right:6px}

@media(prefers-reduced-motion:reduce){
  .pa-apply-rotor svg{animation:none}
  .pa-metabar .pa-metabar-dot{animation:none;opacity:1}
}

/* ── Flagship CTA row ── */
.pa-flagship-cta-row{
  display:flex;align-items:center;gap:14px;
  margin-top:28px;
  flex-wrap:wrap;
}
.pa-flagship-btn-p{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--pa-primary);color:#fff;
  padding:13px 26px;border-radius:999px;
  font:600 14px/1 'Inter',sans-serif;
  letter-spacing:.01em;text-decoration:none;
  box-shadow:0 6px 20px -4px rgba(255,90,31,.45),0 1px 0 rgba(255,255,255,.25) inset;
  transition:transform .2s,box-shadow .2s;
  white-space:nowrap;
}
.pa-flagship-btn-p:hover{transform:translateY(-2px);box-shadow:0 14px 32px -6px rgba(255,90,31,.6),0 1px 0 rgba(255,255,255,.3) inset}
.pa-flagship-btn-s{
  font:500 14px/1 'Inter',sans-serif;
  color:var(--pa-fg);
  text-decoration:none;
  opacity:.55;
  transition:opacity .2s;
  white-space:nowrap;
}
.pa-flagship-btn-s:hover{opacity:1}

/* ── Editorial entrance ── */
.pa-up{opacity:0;transform:translateY(20px);transition:opacity .9s var(--pa-ease), transform .9s var(--pa-ease)}
.pa-up.is-in{opacity:1;transform:none}

/* ── MOBILE COMPACT ── */
@media(max-width:639px){
  /* Ocultar header intro y metabar */
  .pa-header, .pa-metabar, .pa-footnote, .pa-foot{display:none}
  /* Card 01 flagship: stack verticalmente */
  .pa-flagship{
    padding:48px 0;
    display:flex;
    flex-direction:column;
    gap:0;
  }
  .pa-num{font-size:22px;margin-bottom:16px}
  .pa-flagship-body{gap:20px}
  .pa-flagship-title{font-size:28px;margin-bottom:10px}
  .pa-flagship-desc{font-size:14px;max-width:none}
  .pa-stats{
    grid-template-columns:repeat(2,1fr);
    gap:14px 12px;
    padding-top:18px;
  }
  .pa-flagship-visual{
    min-height:unset;
    align-self:auto;
    margin-top:28px;
    border-radius:4px;
    overflow:hidden;
  }
  .pa-flagship-img{
    aspect-ratio:3/2;
    height:auto;
  }
  .pa-flagship-cta-row{gap:10px;margin-top:20px}
  .pa-flagship-btn-p{padding:13px 22px;font-size:12px}
  /* Ocultar CTA secundario en mobile */
  .pa-flagship-btn-s{display:none}

  /* Cards 02-04 */
  .pa-spec{padding:40px 0}
  .pa-spec-head{margin-bottom:20px}
  .pa-spec-title{font-size:20px;margin-bottom:10px}
  .pa-spec-desc{font-size:13px;margin-bottom:12px}
  .pa-outcomes{margin-bottom:16px}
  .pa-outcomes li{font-size:13px;padding:3px 0 3px 14px}
  .pa-spec-data{margin-bottom:16px}
  .pa-spec-data li{padding:8px 0;font-size:12px}
  .pa-spec-data .k{font-size:11px}
  .pa-tools{min-height:unset;margin-bottom:16px}
  .pa-tools-label{font-size:11px;margin-bottom:8px}
  .pa-tools-list{gap:6px 10px}
  .pa-tool-item{font-size:11px}
  .pa-spec-cta{padding:15px 16px;font-size:11px}
}


.pa-lms{
  background:var(--cream);
  padding:100px 0 100px;
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(13,17,23,.06);
}
.pa-lms::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(13,17,23,.035) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, transparent, #000 15%, #000 85%, transparent);
  pointer-events:none;z-index:0;
}
.lms-wrap{
  max-width:1240px;
  margin:0 auto;
  padding:0 48px;
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:64px;
  align-items:center;
}
.lms-left{max-width:520px}
.lms-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font:500 11px/1 'JetBrains Mono',ui-monospace,monospace;letter-spacing:.18em;
  color:var(--orange);text-transform:uppercase;margin-bottom:28px;
}
.lms-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 4px rgba(255,90,31,.12)}
.lms-title{
  font:400 52px/1.05 'Playfair Display',serif;
  color:var(--dark);letter-spacing:-.015em;margin:0 0 24px;
}
.lms-title em{font-style:italic;color:var(--orange);font-weight:400}
.lms-lead{
  font:400 16px/1.65 'Inter',sans-serif;color:#3a3a48;margin:0 0 40px;
}
.lms-pillars{
  list-style:none;padding:0;margin:0 0 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:24px 28px;
}
.lms-pillars li{position:relative;padding-left:0}
.lms-pillars svg{width:20px;height:20px;color:var(--dark);margin-bottom:8px;display:block}
.lms-pillars h4{font:600 14px/1.3 'Inter',sans-serif;color:var(--dark);margin:0 0 4px}
.lms-pillars p{font:400 13px/1.5 'Inter',sans-serif;color:#6a6a78;margin:0}
.lms-ctas{display:flex;gap:14px;align-items:center;margin-bottom:32px;flex-wrap:wrap}
.lms-cta-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;
  padding:14px 22px;border-radius:999px;
  font:500 14px/1 'Inter',sans-serif;text-decoration:none;
  transition:transform .25s ease,box-shadow .25s ease;
  box-shadow:0 8px 24px -8px rgba(255,90,31,.45);
}
.lms-cta-primary:hover{transform:translateY(-1px);box-shadow:0 14px 32px -10px rgba(255,90,31,.55)}
.lms-cta-primary svg{transition:transform .25s ease}
.lms-cta-primary:hover svg{transform:translateX(3px)}
.lms-cta-ghost{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--dark);text-decoration:none;
  font:500 14px/1 'Inter',sans-serif;padding:14px 4px;
  border-bottom:1px solid transparent;transition:border-color .2s ease;
}
.lms-cta-ghost:hover{border-bottom-color:var(--dark)}
.lms-stats{
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  font:500 12px/1 'JetBrains Mono',ui-monospace,monospace;color:#6a6a78;letter-spacing:.04em;
  padding-top:20px;border-top:1px solid rgba(13,17,23,.08);
}
.lms-stats b{color:var(--dark);font-weight:600}
.lms-sep{color:rgba(13,17,23,.2)}

/* RIGHT — imagen doble de grande, se corta */
.lms-right{
  position:relative;
  overflow:hidden;
  /* Gradiente inferior para suavizar el corte */
  -webkit-mask-image:linear-gradient(to bottom, #000 75%, transparent 100%);
  mask-image:linear-gradient(to bottom, #000 75%, transparent 100%);
}
.lms-laptop-wrap{
  width:200%;
  margin-left:-15%;
  margin-top:-20px;
  border-radius:20px 0 0 0;
  overflow:hidden;
  box-shadow:
    -20px 20px 80px -20px rgba(13,17,23,.18),
    0  0    0      1px rgba(13,17,23,.04);
}
.lms-laptop-img{
  display:block;width:100%;height:auto;
}

/* Estilos heredados que pueden existir en el HTML pero no se usan */
.lms-glow{display:none}
.lms-browser,.lms-bar,.lms-dots,.lms-url,.lms-stage,.lms-panel,
.lms-video,.lms-lessons,.lms-chat,.lms-feed,.lms-quote,
.lms-float,.lms-float-ai,.lms-float-com,.lms-float-cert{display:none}

/* Responsive */
@media(max-width:1024px){
  .lms-wrap{grid-template-columns:1fr;gap:56px;padding:0 48px}
  .lms-right{margin-right:0}
  .lms-title{font-size:40px}
  .lms-left{max-width:100%}
}
@media(max-width:640px){
  .pa-lms{padding:72px 0 72px}
  .lms-wrap{padding:0 24px;gap:40px}
  .lms-title{font-size:34px}
  .lms-lead{font-size:15px;margin-bottom:28px}
  .lms-pillars{grid-template-columns:1fr;gap:20px}
}

.pa-cta-band{
  background:var(--dark);
  padding:56px 0;
}
.cta-band-wrap{
  max-width:1240px;
  margin:0 auto;
  padding:0 48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:40px;
}
.cta-band-text{
  display:flex;
  flex-direction:column;
  gap:10px;
  max-width:620px;
}
.cta-band-q{
  font-family:'Playfair Display',serif;
  font-size:clamp(22px,2.4vw,32px);
  font-weight:700;
  color:#ffffff;
  line-height:1.15;
  letter-spacing:-.015em;
  margin:0;
}
.cta-band-sub{
  font-size:16px;
  line-height:1.6;
  color:rgba(255,255,255,.72);
  margin:0;
  font-weight:400;
}
.cta-band-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:var(--orange);
  color:#fff;
  text-decoration:none;
  font-family:'Inter',sans-serif;
  font-size:15px;
  font-weight:600;
  padding:16px 28px;
  border-radius:50px;
  white-space:nowrap;
  flex-shrink:0;
  box-shadow:0 6px 24px -6px rgba(255,90,31,.55);
  transition:transform .2s,box-shadow .2s;
  letter-spacing:.01em;
}
.cta-band-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px -8px rgba(255,90,31,.65);
}
.cta-band-btn svg{
  flex-shrink:0;
  transition:transform .2s;
}
.cta-band-btn:hover svg{transform:translateX(4px)}

@media(max-width:768px){
  .cta-band-wrap{
    flex-direction:column;
    align-items:flex-start;
    gap:28px;
    padding:0 20px;
  }
  .pa-cta-band{padding:48px 0}
  .cta-band-btn{width:100%;justify-content:center}
}


.pa-tst{background:var(--dark);padding:100px 0 100px;position:relative;overflow:hidden;color:#fff}
.pa-tst::before{content:"";position:absolute;inset:0;background:radial-gradient(620px 320px at 10% 0%,rgba(255,90,31,.10),transparent 60%),radial-gradient(620px 320px at 95% 100%,rgba(255,90,31,.06),transparent 60%);pointer-events:none}
.tst-wrap{max-width:1080px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.tst-head{max-width:720px;margin:0 auto 36px;text-align:center}
.tst-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;letter-spacing:.16em;color:var(--orange);text-transform:uppercase;font-weight:600;margin-bottom:16px;padding:6px 12px;background:rgba(255,90,31,.10);border:1px solid rgba(255,90,31,.28);border-radius:999px}
.tst-eb-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:tstPulse 2s ease-in-out infinite}
@keyframes tstPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.tst-title{font-family:'Instrument Serif',Georgia,serif;font-size:clamp(26px,3.2vw,38px);line-height:1.1;letter-spacing:-.015em;margin:0;font-weight:400}
.tst-title em{font-style:italic;color:var(--orange)}
.tst-carousel{position:relative;display:flex;align-items:center;gap:14px}
.tst-viewport{flex:1;overflow:hidden;border-radius:14px}
.tst-track{display:flex;list-style:none;margin:0;padding:0;transition:transform .55s cubic-bezier(.2,.8,.2,1)}
.tst-slide{flex:0 0 100%;padding:0 2px}
.tst-card{position:relative;background:#fff;color:var(--dark);border-radius:14px;padding:28px 30px 22px;display:flex;flex-direction:column;gap:14px;border:1px solid rgba(13,17,23,.08);box-shadow:0 18px 40px -22px rgba(13,17,23,.35);overflow:hidden;min-height:180px}
.tst-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange)}
.tst-mark{position:absolute;top:-6px;right:18px;font-family:'Instrument Serif',Georgia,serif;font-size:96px;line-height:1;color:rgba(255,90,31,.14);font-style:italic;pointer-events:none}
.tst-q{font-family:'Instrument Serif',Georgia,serif;font-size:18px;line-height:1.5;color:var(--dark);margin:0;font-weight:400;letter-spacing:-.005em;position:relative;z-index:1}
.tst-by{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid rgba(13,17,23,.08)}
.tst-av{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#FF7043,var(--orange) 60%,#CC4819);color:#fff;display:grid;place-items:center;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;font-weight:700;letter-spacing:.04em;flex-shrink:0}
.tst-meta{display:flex;flex-direction:column;gap:1px;line-height:1.2}
.tst-meta b{font-size:13px;font-weight:600;color:var(--dark)}
.tst-meta i{font-style:normal;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:rgba(13,17,23,.55);font-family:'JetBrains Mono',ui-monospace,monospace}
.tst-nav{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.04);color:#fff;display:grid;place-items:center;cursor:pointer;transition:background .2s,border-color .2s,transform .2s;flex-shrink:0}
.tst-nav svg{width:18px;height:18px}
.tst-nav:hover{background:var(--orange);border-color:var(--orange);transform:scale(1.05)}
.tst-dots{position:absolute;left:50%;bottom:-30px;transform:translateX(-50%);display:flex;gap:8px}
.tst-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.22);border:none;cursor:pointer;padding:0;transition:width .3s,background .3s}
.tst-dot.is-on{width:22px;border-radius:4px;background:var(--orange)}
@media (max-width:680px){
  .pa-tst{padding:72px 0 72px}
  .tst-wrap{padding:0 20px}
  .tst-nav{width:34px;height:34px}
  .tst-card{padding:24px 22px 18px}
  .tst-q{font-size:16px}
}


.pa-community{background:var(--cream);padding:60px 0 100px;position:relative;overflow:hidden;color:var(--dark)}
.pa-community::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 15% 0%,rgba(10,102,194,.05),transparent 60%),radial-gradient(600px 360px at 90% 100%,rgba(221,42,123,.05),transparent 60%);pointer-events:none}
.cm-wrap{max-width:1100px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.cm-head{max-width:720px;margin-bottom:44px;text-align:left}
.cm-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;letter-spacing:.14em;color:rgba(13,17,23,.5);text-transform:uppercase;font-weight:600;margin-bottom:18px;padding:6px 12px;background:rgba(13,17,23,.05);border:1px solid rgba(13,17,23,.1);border-radius:999px}
.cm-eb-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:cmPulse 2s ease-in-out infinite}
@keyframes cmPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.cm-title{font-family:'Instrument Serif',Georgia,serif;font-size:clamp(28px,3.4vw,42px);line-height:1.08;letter-spacing:-.015em;margin:0 0 12px;font-weight:400;color:var(--dark)}
.cm-title em{font-style:italic;color:var(--orange)}
.cm-sub{font-size:15px;line-height:1.6;color:rgba(13,17,23,.62);max-width:600px;margin:0}
.cm-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.cm-card{position:relative;background:#fff;border:1px solid rgba(13,17,23,.08);border-radius:14px;padding:24px;display:flex;flex-direction:column;gap:16px;transition:transform .3s cubic-bezier(.2,.8,.2,1),border-color .25s,box-shadow .25s;overflow:hidden}
.cm-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px}
.cm-li::before{background:#0a66c2}
.cm-ig::before{background:linear-gradient(90deg,#f58529,#dd2a7b,#8134af)}
.cm-card:hover{transform:translateY(-2px);border-color:rgba(13,17,23,.14);box-shadow:0 12px 30px -16px rgba(13,17,23,.18)}
.cm-card-top{display:flex;align-items:center;gap:12px}
.cm-logo{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}
.cm-logo svg{width:22px;height:22px}
.cm-logo-li{background:#0a66c2;color:#fff}
.cm-logo-ig{background:linear-gradient(135deg,#f58529 0%,#dd2a7b 50%,#8134af 100%);color:#fff}
.cm-meta{display:flex;flex-direction:column;gap:2px}
.cm-net{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(13,17,23,.5);font-family:'JetBrains Mono',ui-monospace,monospace}
.cm-handle{font-size:15px;font-weight:600;color:var(--dark);letter-spacing:-.01em}
.cm-tagline{font-family:'Instrument Serif',Georgia,serif;font-style:italic;font-size:17px;color:var(--dark);line-height:1.3}
.cm-desc{font-size:14px;line-height:1.55;color:rgba(13,17,23,.6);margin:0}
.cm-stats{display:flex;align-items:center;gap:24px;padding:14px 0;border-top:1px solid rgba(13,17,23,.08);border-bottom:1px solid rgba(13,17,23,.08)}
.cm-stat{display:flex;flex-direction:column;gap:3px}
.cm-num{font-family:'Instrument Serif',Georgia,serif;font-size:26px;line-height:1;color:var(--dark);display:inline-flex;align-items:flex-start}
.cm-plus{font-size:14px;color:#c9a84c;margin-left:2px;line-height:1}
.cm-lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(13,17,23,.5);font-family:'JetBrains Mono',ui-monospace,monospace}
.cm-stat-sep{width:1px;height:32px;background:rgba(13,17,23,.1)}
.cm-cta{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;padding:10px 16px;border-radius:999px;font-weight:600;font-size:13px;text-decoration:none;transition:transform .25s,box-shadow .25s,background .25s;margin-top:auto}
.cm-cta-li{background:#0a66c2;color:#fff}
.cm-cta-li:hover{background:#0958a8;transform:translateY(-2px);box-shadow:0 10px 20px -8px rgba(10,102,194,.45)}
.cm-cta-ig{background:linear-gradient(135deg,#f58529,#dd2a7b 55%,#8134af);color:#fff}
.cm-cta-ig:hover{transform:translateY(-2px);box-shadow:0 10px 20px -8px rgba(221,42,123,.45)}
.cm-arrow{transition:transform .25s}
.cm-cta:hover .cm-arrow{transform:translateX(3px)}
@media (max-width:900px){
  .pa-community{padding:40px 0 72px}
  .cm-wrap{padding:0 24px}
  .cm-grid{grid-template-columns:1fr;gap:16px}
  .cm-card{padding:22px}
}
.pa-agenda{background:var(--cream-pale);padding:100px 0 100px;position:relative;overflow:hidden}
.pa-agenda::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(13,17,23,.04) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, transparent, #000 20%, #000 80%, transparent);
  pointer-events:none;
}
.ag-wrap{max-width:1240px;margin:0 auto;padding:0 48px;position:relative;z-index:2}

/* HEAD */
.ag-head{max-width:760px;margin-bottom:64px}
.ag-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;letter-spacing:.14em;color:var(--orange);
  text-transform:uppercase;font-weight:600;margin-bottom:28px;
  padding:7px 14px;background:rgba(255,90,31,.06);border:1px solid rgba(255,90,31,.18);border-radius:999px;
}
.ag-eb-dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:agPulse 2s ease-in-out infinite}
@keyframes agPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}
.ag-eb-sep{opacity:.4}
.ag-eb-count{color:var(--dark);opacity:.6}
.ag-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(42px,5.4vw,72px);line-height:1.02;letter-spacing:-.022em;
  font-weight:800;color:var(--dark);margin:0 0 22px;
}
.ag-title em{font-style:italic;color:var(--orange);font-weight:600}
.ag-sub{font-size:17px;line-height:1.55;color:#3a3a44;opacity:.7;max-width:560px;margin:0}

/* TOOLBAR */
.ag-toolbar{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  padding:18px 0;margin-bottom:24px;
  border-top:1px solid rgba(13,17,23,.1);
  border-bottom:1px solid rgba(13,17,23,.1);
}
.ag-filters{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.ag-f{
  position:relative;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:#3a3a44;
  background:transparent;border:1px solid transparent;border-radius:999px;
  padding:8px 14px;cursor:pointer;letter-spacing:.005em;
  transition:all .25s cubic-bezier(.2,.7,.2,1);
  display:inline-flex;align-items:center;gap:8px;
}
.ag-f:hover{background:rgba(13,17,23,.04);color:var(--dark)}
.ag-f.is-on{background:var(--dark);color:#fff;border-color:var(--dark)}
.ag-f.is-on::after{
  content:"";position:absolute;left:50%;bottom:-7px;width:18px;height:2px;
  background:var(--orange);transform:translateX(-50%);border-radius:2px;
  animation:agUnderline .35s cubic-bezier(.2,.7,.2,1);
}
@keyframes agUnderline{from{width:0;opacity:0}to{width:18px;opacity:1}}
.ag-f.is-on .ag-count{background:rgba(255,255,255,.18);color:#fff}
.ag-count{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:600;
  background:rgba(13,17,23,.08);color:#3a3a44;padding:2px 7px;border-radius:999px;
  transition:all .3s;
}
.ag-eb-count.is-flash{animation:agFlash .55s cubic-bezier(.2,.7,.2,1)}
@keyframes agFlash{0%{opacity:.2;transform:translateY(-3px)}100%{opacity:.6;transform:translateY(0)}}
.ag-f-sm{font-size:12px;padding:6px 12px;opacity:.7}
.ag-f-sm.is-on{background:rgba(255,90,31,.1);color:var(--orange);border-color:rgba(255,90,31,.25);opacity:1}
.ag-f-sm.is-on::after{background:var(--dark)}
.ag-filters-zone{align-items:center;gap:10px}
.ag-f-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;
  color:#7a7a82;margin-right:2px;
}
.ag-filters-zone .ag-f-sm.is-on{
  background:rgba(40,90,140,.08);color:#1f4d7a;border-color:rgba(40,90,140,.22);
}
.ag-filters-zone .ag-f-sm.is-on::after{background:#1f4d7a}
.ev-zone{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;letter-spacing:.12em;
  text-transform:uppercase;padding:3px 8px;border-radius:3px;
}
.ev-zone.zone-la{background:rgba(40,90,140,.08);color:#1f4d7a}
.ev-zone.zone-eu{background:rgba(120,70,150,.08);color:#5a3a7a}
.ev-zone.zone-both{background:linear-gradient(90deg,rgba(40,90,140,.08),rgba(120,70,150,.08));color:#3a3a55}

/* LIST */
.ag-list{display:flex;flex-direction:column}

/* month dividers */
.ag-month{
  display:flex;align-items:baseline;gap:18px;
  padding:46px 8px 14px;
}
.ag-month:first-child{padding-top:8px}
.ag-month-label{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:500;
  font-size:30px;color:var(--dark);letter-spacing:-.015em;line-height:1;
}
.ag-month-line{flex:1;height:1px;background:linear-gradient(to right,rgba(13,17,23,.18),rgba(13,17,23,0))}
.ag-month-count{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;
  color:#3a3a44;opacity:.5;letter-spacing:.14em;text-transform:uppercase;
}

.ev-row{
  display:grid;
  grid-template-columns:100px 170px 1fr 200px 130px;
  align-items:center;gap:32px;
  padding:26px 8px;
  border-bottom:1px solid rgba(13,17,23,.07);
  position:relative;
  transition:transform .25s cubic-bezier(.2,.7,.2,1), box-shadow .25s, border-color .25s, background .25s;
  opacity:0;transform:translateY(12px);
  animation:agFadeIn .6s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay:calc(var(--i) * 50ms);
  cursor:pointer;
}
@keyframes agFadeIn{to{opacity:1;transform:translateY(0)}}
.ev-row::before{
  content:"";position:absolute;left:-16px;right:-16px;top:0;bottom:0;
  background:#fff;border-radius:12px;
  box-shadow:0 8px 32px -8px rgba(13,17,23,.14), 0 0 0 1px rgba(255,90,31,.18);
  opacity:0;transition:opacity .25s;z-index:-1;
}
/* fila elevada en hover */
.ev-row:hover{
  transform:translateY(-2px);
  border-bottom-color:transparent;
}
.ev-row:hover::before{opacity:1}
/* número de fecha en naranja */
.ev-row:hover .ev-day{color:var(--orange)}
/* nombre en naranja */
.ev-row:hover .ev-name{color:var(--dark)}
/* pills en naranja suave */
.ev-row:hover .ev-pill{
  background:rgba(255,90,31,.08);
  border-color:rgba(255,90,31,.2);
  color:var(--orange);
}
/* CTA se convierte en botón real */
.ev-row:hover .ev-cta{
  background:var(--orange);
  color:#fff;
  padding:10px 18px;
  border-radius:999px;
  box-shadow:0 6px 20px -4px rgba(255,90,31,.5);
  gap:10px;
}
.ev-row:hover .ev-cta svg{transform:translateX(2px);opacity:1}
.ev-row.is-hidden{display:none}

/* PRÓXIMO flag — pulsing coral indicator */
.ev-row.is-next{
  background:linear-gradient(90deg, rgba(255,90,31,.045) 0%, rgba(255,90,31,0) 60%);
  border-bottom-color:rgba(255,90,31,.18);
}
.ev-row.is-next .ev-day{color:var(--orange)}
.ev-flag{
  position:absolute;top:-11px;left:-2px;
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 11px 5px 9px;border-radius:999px;
  background:var(--orange);color:#fff;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:600;letter-spacing:.14em;
  box-shadow:0 6px 16px -3px rgba(255,90,31,.5);
  z-index:2;
}
.ev-flag-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:agPulseDot 1.6s ease-in-out infinite}
@keyframes agPulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.55;transform:scale(.7)}}

/* date — stronger hierarchy: bigger day, smaller name */
.ev-date{display:flex;flex-direction:column;align-items:flex-start;line-height:.9}
.ev-day{
  font-family:'Playfair Display',serif;font-size:68px;font-weight:800;
  color:var(--dark);letter-spacing:-.04em;font-variant-numeric:tabular-nums;
}
.ev-mon{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:600;
  color:var(--orange);letter-spacing:.2em;margin-top:6px;
}

/* tag */
.ev-tag{display:flex;flex-direction:column;gap:6px}
.ev-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:8px;vertical-align:middle}
.ev-tipo{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:600;color:var(--dark);letter-spacing:.14em}
.ev-fmt{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:9.5px;font-weight:500;color:#3a3a44;opacity:.55;letter-spacing:.16em;margin-left:15px}

/* main — toned down so date wins hierarchy */
.ev-name{
  font-family:'Playfair Display',serif;font-size:20px;line-height:1.3;letter-spacing:-.01em;
  font-weight:500;color:var(--dark);margin:0 0 5px;transition:color .3s;
}
.ev-speaker{font-size:13px;color:#3a3a44;opacity:.7;margin:0}
.ev-speaker b{font-weight:600;color:var(--dark);opacity:.9}

/* meta pills */
.ev-meta{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-start}
.ev-pill{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;font-weight:600;
  padding:5px 10px;border-radius:999px;letter-spacing:.1em;text-transform:uppercase;
  background:rgba(13,17,23,.05);color:#3a3a44;border:1px solid rgba(13,17,23,.06);
}
.pill-free{background:rgba(34,197,94,.1);color:#16a34a;border-color:rgba(34,197,94,.22)}
.pill-paid{background:rgba(13,17,23,.05);color:#3a3a44}

/* cta — always visible, morphs into button on row hover */
.ev-cta{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  color:rgba(13,17,23,.42);
  text-decoration:none;justify-self:end;
  padding:10px 0;border-radius:999px;
  transition:color .25s, gap .25s, background .25s, padding .25s, box-shadow .25s;
  white-space:nowrap;
}
.ev-cta svg{transition:transform .25s, opacity .25s;opacity:.55}

/* empty */
.ag-empty{padding:80px 0;text-align:center}
.ag-empty p{font-family:'Playfair Display',serif;font-size:22px;color:#3a3a44;opacity:.5;margin:0;font-style:italic}

/* quote transition band — softens cream→dark */
.ag-quote{
  margin-top:80px;padding:60px 32px 52px;text-align:center;
  background:linear-gradient(180deg, transparent 0%, rgba(13,17,23,.03) 100%);
  border-radius:16px 16px 0 0;
}
.ag-quote p{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:400;
  font-size:34px;line-height:1.3;letter-spacing:-.015em;
  color:var(--dark);margin:0 0 14px;
}
.ag-quote p em{color:var(--orange);font-style:italic}
.ag-quote-by{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;
  color:#3a3a44;opacity:.55;letter-spacing:.14em;text-transform:uppercase;
}

/* foot */
.ag-foot{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
  margin-top:0;padding:36px 40px;
  background:var(--dark);border-radius:0 0 16px 16px;
}
.ag-foot-txt{font-family:'Playfair Display',serif;font-size:22px;color:#fafaf7;margin:0;letter-spacing:-.01em}
.ag-foot-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;text-decoration:none;
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  padding:14px 22px;border-radius:999px;letter-spacing:.005em;
  box-shadow:0 6px 20px -4px rgba(255,90,31,.5);
  transition:transform .25s, box-shadow .25s, gap .25s;
}
.ag-foot-cta:hover{transform:translateY(-2px);gap:14px;box-shadow:0 12px 28px -6px rgba(255,90,31,.6)}

/* responsive */
@media(max-width:1100px){
  .ev-row{grid-template-columns:80px 150px 1fr auto;gap:20px}
  .ev-cta{grid-column:4;grid-row:1}
  .ev-meta{grid-column:1 / -1;justify-content:flex-start;padding-left:100px;margin-top:-8px}
  .ev-day{font-size:54px}
  .ag-quote p{font-size:26px}
}
@media(max-width:720px){
  .pa-agenda{padding:72px 0 72px}
  .ag-filters{display:none}
  .ag-wrap{padding:0 24px}
  .ag-head{margin-bottom:40px}
  .ag-month{padding:34px 4px 10px}
  .ag-month-label{font-size:22px}
  .ev-row{grid-template-columns:72px 1fr;gap:16px;padding:22px 4px}
  .ev-tag{grid-column:2;grid-row:1}
  .ev-main{grid-column:1 / -1;grid-row:2}
  .ev-meta{grid-column:1 / -1;grid-row:3;padding-left:0;margin-top:0}
  .ev-cta{grid-column:1 / -1;grid-row:4;justify-self:flex-start;padding:10px 16px;background:rgba(255,90,31,.08);border-radius:999px;color:var(--orange);margin-top:4px}
  .ev-day{font-size:46px}
  .ev-fmt{display:none}
  .ev-flag{top:-12px;left:0;font-size:11px}
  .ag-quote{padding:36px 20px 28px;margin-top:48px}
  .ag-quote p{font-size:20px}
  .ag-foot{flex-direction:column;text-align:center;padding:28px 20px}
  .ag-foot-txt{font-size:18px}

  /* Filtros en mobile: cada fila ocupa todo el ancho */
  .ag-toolbar{
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
    padding:14px 0;
  }
  .ag-filters{
    width:100%;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    flex-wrap:nowrap;
    padding-bottom:4px;
    scrollbar-width:none;
  }
  .ag-filters::-webkit-scrollbar{display:none}
  .ag-f{white-space:nowrap;flex-shrink:0}
  .ag-filters-zone{width:100%;overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;scrollbar-width:none}
  .ag-filters-zone::-webkit-scrollbar{display:none}
  .ag-f-label{display:none}
}
@media(prefers-reduced-motion:reduce){
  .ev-row{animation:none;opacity:1;transform:none}
  .ag-eb-dot{animation:none}
}

/* ============================================================
   GALLERY · Últimos eventos
============================================================ */
.pa-gallery{background:var(--dark);padding:100px 0 100px;position:relative;overflow:hidden}
.pa-gallery::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.04) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, transparent, #000 15%, #000 85%, transparent);
  pointer-events:none;
}
.gal-wrap{max-width:1240px;margin:0 auto;padding:0 48px;position:relative;z-index:2}
.gal-head{max-width:720px;margin-bottom:36px;display:flex;flex-direction:column;gap:8px}
.gal-eyebrow{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;
  color:var(--orange);letter-spacing:.18em;text-transform:uppercase;
  display:inline-block;
}
.gal-title{
  font-family:'Playfair Display',serif;font-weight:500;
  font-size:clamp(28px,3.4vw,40px);line-height:1.05;letter-spacing:-.02em;
  color:#fafaf7;margin:0;
}
.gal-title em{color:var(--orange);font-style:italic;font-weight:400}
.gal-sub{
  font-family:'Inter',sans-serif;font-size:14px;line-height:1.5;
  color:rgba(250,250,247,.55);margin:4px 0 0;max-width:540px;
}

.gal-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:12px;
}
.gal-i1{grid-column:span 4}
.gal-i1 .gal-img{aspect-ratio:3/1}
.gal-i2{grid-column:span 2}
.gal-i2 .gal-img{aspect-ratio:3/2}
.gal-i3,.gal-i4,.gal-i5{grid-column:span 2}
.gal-i3 .gal-img,.gal-i4 .gal-img,.gal-i5 .gal-img{aspect-ratio:3/2}
.gal-i6{grid-column:span 6}
.gal-i6 .gal-img{aspect-ratio:3/1}

.gal-item{
  position:relative;margin:0;overflow:hidden;border-radius:14px;
  background:#1a1a22;cursor:pointer;
  transition:transform .5s cubic-bezier(.2,.7,.2,1);
}
.gal-item:hover{transform:translateY(-4px)}
.gal-img{
  display:block;width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform .8s cubic-bezier(.2,.7,.2,1), filter .4s;
  filter:saturate(.9) brightness(.9);
}
.gal-item:hover .gal-img{transform:scale(1.05);filter:saturate(1) brightness(1)}
.gal-item::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.78) 100%);
  pointer-events:none;
}
.gal-item figcaption{
  position:absolute;left:18px;right:18px;bottom:16px;z-index:2;
  display:flex;flex-direction:column;gap:6px;
}
.gal-cap-tag{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:10px;
  color:var(--orange);letter-spacing:.16em;text-transform:uppercase;
}
.gal-cap-txt{
  font-family:'Playfair Display',serif;font-style:italic;font-weight:400;
  font-size:15px;line-height:1.25;color:#fafaf7;letter-spacing:-.01em;
}

.gal-foot{
  margin-top:32px;padding-top:22px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.gal-foot-meta{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:11px;
  color:rgba(250,250,247,.5);letter-spacing:.14em;text-transform:uppercase;
}
.gal-foot-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;text-decoration:none;
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  padding:14px 22px;border-radius:999px;
  box-shadow:0 6px 20px -4px rgba(255,90,31,.5);
  transition:transform .25s, box-shadow .25s, gap .25s;
}
.gal-foot-cta:hover{transform:translateY(-2px);gap:14px;box-shadow:0 12px 28px -6px rgba(255,90,31,.6)}

@media(max-width:960px){
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .gal-i1,.gal-i2,.gal-i3,.gal-i4,.gal-i5,.gal-i6{grid-column:span 2}
  .gal-i1 .gal-img,.gal-i6 .gal-img{aspect-ratio:16/9}
}
@media(max-width:640px){
  .pa-gallery{padding:72px 0 72px}
  .gal-wrap{padding:0 24px}
  .gal-head{margin-bottom:36px}
  .gal-grid{grid-template-columns:1fr;gap:10px}
  .gal-i1,.gal-i2,.gal-i3,.gal-i4,.gal-i5,.gal-i6{grid-column:span 1}
  .gal-i1 .gal-img,.gal-i2 .gal-img,.gal-i3 .gal-img,.gal-i4 .gal-img,.gal-i5 .gal-img,.gal-i6 .gal-img{aspect-ratio:3/2}
  .gal-foot{flex-direction:column;align-items:flex-start}
}

/* ── AGENDA HERO HEADER ── */
.ag-hero-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:48px;
  align-items:center;
  padding:24px 0 40px;
  border-bottom:1px solid rgba(13,17,23,.07);
  margin-bottom:32px;
}
.ag-hero-left{ position:relative }
.ag-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(24px,2.6vw,40px);
  font-weight:700;line-height:1.1;
  letter-spacing:-.02em;
  color:var(--dark);
  margin:0 0 12px;
  white-space:nowrap;
}
.ag-title em{
  font-style:italic;
  color:var(--orange);
  font-weight:700;
}
.ag-sub{
  font-size:15px;line-height:1.6;
  color:rgba(13,17,23,.6);
  margin:0 0 16px;
}
.ag-sub strong{color:var(--dark);font-weight:600}
.ag-sub-line{
  width:40px;height:2.5px;
  background:var(--orange);
  border-radius:2px;
}
.ag-cities{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  align-items:end;
}
.ag-city{
  display:block;
  background:none;border:none;padding:0;
  cursor:pointer;position:relative;
}
.ag-city-img{
  width:100%;height:auto;display:block;
  transition:transform .4s cubic-bezier(.2,.8,.2,1), opacity .3s;
  mix-blend-mode:multiply;
  opacity:.85;
}
.ag-city:hover .ag-city-img{ transform:translateY(-8px);opacity:1 }
.ag-city.is-active .ag-city-img{
  opacity:1;
  transform:translateY(-6px);
  filter:drop-shadow(0 12px 28px rgba(255,90,31,.3));
}
.ag-city.is-active::after{
  content:"";
  position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);
  width:28px;height:3px;border-radius:2px;
  background:var(--orange);
}
@media(max-width:1024px){
  .ag-title{white-space:normal;font-size:clamp(22px,2.4vw,36px)}
}
@media(max-width:900px){
  .ag-hero-row{grid-template-columns:1fr;gap:28px}
  .ag-cities{max-width:420px}
}
@media(max-width:640px){
  .ag-cities{gap:10px}
  .ag-title{font-size:28px}
}

/* ── WHATSAPP FLOTANTE ── */
.wa-float{
  position:fixed;
  bottom:28px;right:28px;
  z-index:999;
  display:flex;align-items:center;gap:0;
  filter:drop-shadow(0 8px 24px rgba(37,211,102,.35));
  transition:filter .3s;
}
.wa-float:hover{filter:drop-shadow(0 12px 32px rgba(37,211,102,.55))}

.wa-btn{
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,#25d366,#128c7e);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  transition:transform .3s cubic-bezier(.2,.8,.2,1);
  position:relative;flex-shrink:0;
}
.wa-btn:hover{transform:scale(1.1)}
.wa-btn svg{width:30px;height:30px;fill:#fff}

/* Pulso */
.wa-btn::before{
  content:"";
  position:absolute;inset:0;border-radius:50%;
  background:rgba(37,211,102,.4);
  animation:waPulse 2.4s ease-out infinite;
}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.7}
  70%{transform:scale(1.55);opacity:0}
  100%{transform:scale(1.55);opacity:0}
}

/* Tooltip */
.wa-tooltip{
  background:var(--dark);color:#fff;
  font:500 13px/1 'Inter',sans-serif;
  padding:10px 14px;border-radius:10px;
  white-space:nowrap;
  margin-right:12px;
  opacity:0;transform:translateX(8px);
  transition:opacity .25s,transform .25s;
  pointer-events:none;
}
.wa-float:hover .wa-tooltip{opacity:1;transform:translateX(0)}

@media(max-width:640px){
  .wa-float{bottom:20px;right:20px}
  .wa-btn{width:50px;height:50px}
  .wa-btn svg{width:26px;height:26px}
}

/* ══════════════════════════════════════
   FAQ SECTION — alineado con design system
══════════════════════════════════════ */
.pa-faq{
  background:var(--cream-pale);
  padding:100px 0 0;
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(13,17,23,.06);
}
/* dot grid sutil — igual que pa-agenda y pa-lms */
.pa-faq::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(13,17,23,.032) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
  pointer-events:none;
}

.faq-wrap{
  max-width:1240px;margin:0 auto;padding:0 48px;
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:80px;
  align-items:start;
}

/* ── LEFT ── */
.faq-left{position:sticky;top:100px}

/* eyebrow — mismo patrón que .tst-eyebrow */
.faq-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--orange);
  background:rgba(255,90,31,.10);
  border:1px solid rgba(255,90,31,.28);
  border-radius:999px;padding:6px 12px;
  margin-bottom:20px;
}
.faq-eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--orange);
  animation:tstPulse 2s ease-in-out infinite; /* reutiliza keyframe existente */
}

/* título — mismo patrón que .cm-title (Instrument Serif, light, italic em) */
.faq-title{
  font-family:'Instrument Serif',Georgia,serif;
  font-size:clamp(28px,3.4vw,44px);
  font-weight:400;line-height:1.08;
  letter-spacing:-.015em;
  color:var(--dark);
  margin:0 0 14px;
}
.faq-title em{font-style:italic;color:var(--orange)}

/* subtítulo — mismo patrón que .cm-sub */
.faq-sub{
  font-size:15px;line-height:1.6;
  color:rgba(13,17,23,.62);
  max-width:340px;margin:0 0 24px;
}
/* línea naranja decorativa — igual que .ag-sub-line */
.faq-sub-line{
  width:40px;height:3px;
  background:var(--orange);border-radius:2px;
  margin-bottom:36px;
}

/* tarjeta metodología — igual que .tst-card */
.faq-card{
  background:#fff;
  border-radius:14px;
  padding:24px 26px 22px;
  border:1px solid rgba(13,17,23,.08);
  box-shadow:0 18px 40px -22px rgba(13,17,23,.14);
  position:relative;overflow:hidden;
}
.faq-card::before{
  content:"";
  position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--orange);
}
.faq-card-icon{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,90,31,.10);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;font-size:18px;
}
.faq-card h4{
  font-family:'Inter',sans-serif;
  font-size:14px;font-weight:600;line-height:1.35;
  color:var(--dark);margin:0 0 8px;letter-spacing:-.005em;
}
.faq-card p{
  font-family:'Inter',sans-serif;
  font-size:13px;line-height:1.6;
  color:rgba(13,17,23,.6);margin:0 0 14px;
}
/* link — mismo patrón que .pa-link */
.faq-card-link{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
  color:var(--orange);text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  transition:gap .25s;
}
.faq-card-link:hover{gap:14px}

/* ── RIGHT — acordeón ── */
.faq-list{
  display:flex;flex-direction:column;gap:0;
  padding-bottom:0;
}
.faq-item{
  border:1px solid rgba(13,17,23,.08);  /* misma intensidad que .tst-card */
  border-radius:14px;                   /* mismo radius que .tst-card */
  margin-bottom:10px;
  overflow:hidden;
  background:#fff;
  transition:box-shadow .25s cubic-bezier(.2,.8,.2,1), border-color .25s;
}
.faq-item.is-open{
  box-shadow:0 8px 32px -8px rgba(13,17,23,.12);
  border-color:rgba(255,90,31,.22);
}
.faq-q{
  width:100%;background:none;border:none;
  padding:20px 22px;
  display:flex;align-items:center;gap:16px;
  cursor:pointer;text-align:left;
  font-family:'Inter',sans-serif;
  font-size:15px;font-weight:500;line-height:1.4;
  color:var(--dark);
  transition:color .2s;
}
.faq-q:hover{color:var(--orange)}
.faq-q-icon{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:rgba(255,90,31,.10);
  border:1.5px solid rgba(255,90,31,.25);
  display:flex;align-items:center;justify-content:center;
  color:var(--orange);
  font-family:'Inter',sans-serif;
  font-size:18px;font-weight:300;line-height:1;
  transition:background .25s,transform .35s cubic-bezier(.4,0,.2,1);
  user-select:none;flex-shrink:0;
}
.faq-item.is-open .faq-q-icon{
  background:var(--orange);color:#fff;
  transform:rotate(45deg);
}
.faq-q-text{flex:1}
.faq-chevron{
  color:rgba(13,17,23,.3);flex-shrink:0;
  transition:transform .35s cubic-bezier(.4,0,.2,1), color .2s;
}
.faq-item.is-open .faq-chevron{transform:rotate(180deg);color:var(--orange)}

.faq-a{max-height:0;overflow:hidden;transition:max-height .4s cubic-bezier(.4,0,.2,1)}
.faq-item.is-open .faq-a{max-height:400px}
.faq-a-inner{
  padding:0 22px 20px 68px;
  font-family:'Inter',sans-serif;
  font-size:14px;line-height:1.7;
  color:rgba(13,17,23,.62);  /* mismo que .cm-sub y .pa-lede */
}

/* ── CTA bar — mismo patrón que .ag-foot ── */
.faq-cta-bar{
  background:var(--dark);           /* mismo que .ag-foot */
  padding:28px 48px;
  display:flex;align-items:center;gap:24px;
  flex-wrap:wrap;
  position:relative;z-index:2;
}
.faq-cta-icon{
  width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:rgba(255,90,31,.15);
  display:flex;align-items:center;justify-content:center;
}
.faq-cta-icon svg{width:20px;height:20px;color:var(--orange)}
.faq-cta-txt{flex:1}
.faq-cta-txt strong{
  display:block;
  font-family:'Instrument Serif',Georgia,serif;  /* mismo que .ag-foot-txt */
  font-size:20px;line-height:1.2;letter-spacing:-.01em;
  color:#fafaf7;font-weight:400;
}
.faq-cta-txt span{
  font-family:'Inter',sans-serif;
  font-size:14px;line-height:1.5;
  color:rgba(255,255,255,.55);  /* mismo que .ft-tag */
}
/* botón — mismo que .ag-foot-cta */
.faq-cta-btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--orange);color:#fff;text-decoration:none;
  font-family:'Inter',sans-serif;font-size:14px;font-weight:600;
  padding:14px 22px;border-radius:999px;letter-spacing:.005em;
  box-shadow:0 6px 20px -4px rgba(255,90,31,.5);
  transition:transform .25s,box-shadow .25s,gap .25s;
  white-space:nowrap;
}
.faq-cta-btn:hover{transform:translateY(-2px);gap:14px;box-shadow:0 12px 28px -6px rgba(255,90,31,.6)}

/* responsive */
@media(max-width:1024px){
  .faq-wrap{grid-template-columns:1fr;gap:48px;padding:0 24px}
  .faq-left{position:static}
  .faq-list{padding-bottom:0}
}
@media(max-width:640px){
  .pa-faq{padding:72px 0 0}
  .faq-wrap{padding:0 24px;gap:32px}
  .faq-cta-bar{padding:24px}
  .faq-a-inner{padding-left:22px}
  .faq-title{font-size:28px}
}

/* ══════════════════════════════════════
   FOOTER CREMA
══════════════════════════════════════ */
.pa-footer{
  background:var(--cream) !important;
  color:var(--dark) !important;
}
.pa-footer::before{
  background:linear-gradient(90deg,transparent,rgba(255,90,31,.4),transparent) !important;
}
.ft-logo-name{color:var(--dark)}
.ft-tag{color:rgba(13,17,23,.55) !important}
.ft-social a{
  background:rgba(13,17,23,.05) !important;
  border-color:rgba(13,17,23,.12) !important;
  color:rgba(13,17,23,.6) !important;
}
.ft-social a:hover{background:var(--orange) !important;border-color:var(--orange) !important;color:#fff !important}
.ft-col h4{color:var(--orange) !important}
.ft-col a{color:rgba(13,17,23,.6) !important}
.ft-col a:hover{color:var(--dark) !important}
.ft-top{border-bottom-color:rgba(13,17,23,.1) !important}
.ft-copy{color:rgba(13,17,23,.45) !important}
.ft-links a{color:rgba(13,17,23,.45) !important}
.ft-links a:hover{color:var(--orange) !important}
.ft-cta-btn{background:var(--orange) !important;color:#fff !important}

/* ════════════════════════════════════════════════
   SISTEMA DE BOTONES — 3 variantes únicas
   .pa-btn           → solid coral (acción primaria)
   .pa-btn--ghost    → outline oscuro (acción secundaria)
   .pa-btn--dark     → solid coral sobre fondo oscuro
   ════════════════════════════════════════════════ */

:root{
  --orange-glow: rgba(255,90,31,.32);
  --orange-glow-hover: rgba(255,90,31,.52);
}

.pa-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--orange);color:#fff;
  padding:14px 28px;border-radius:999px;border:none;
  font:600 14px/1 'Inter',sans-serif;
  letter-spacing:.01em;text-decoration:none;cursor:pointer;
  white-space:nowrap;
  box-shadow:0 1px 0 rgba(255,255,255,.22) inset,
             0 8px 24px -6px var(--orange-glow);
  transition:transform .18s cubic-bezier(.2,.8,.2,1),
             box-shadow .18s cubic-bezier(.2,.8,.2,1),
             gap .18s;
}
.pa-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.28) inset,
             0 16px 36px -8px var(--orange-glow-hover);
  gap:13px;
}
.pa-btn:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:4px;
  border-radius:999px;
}

.pa-btn--ghost{
  display:inline-flex;align-items:center;gap:9px;
  background:transparent;color:var(--dark);
  padding:13px 28px;border-radius:999px;
  border:1.5px solid rgba(13,17,23,.18);
  font:600 14px/1 'Inter',sans-serif;
  letter-spacing:.01em;text-decoration:none;cursor:pointer;
  white-space:nowrap;
  transition:border-color .2s,background .2s,transform .18s,gap .18s;
}
.pa-btn--ghost:hover{
  border-color:rgba(13,17,23,.45);
  background:rgba(13,17,23,.04);
  transform:translateY(-1px);
  gap:13px;
}
.pa-btn--ghost:focus-visible{
  outline:2px solid var(--dark);
  outline-offset:4px;
  border-radius:999px;
}

.pa-btn--dark{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--orange);color:#fff;
  padding:14px 28px;border-radius:999px;border:none;
  font:600 14px/1 'Inter',sans-serif;
  letter-spacing:.01em;text-decoration:none;cursor:pointer;
  white-space:nowrap;
  box-shadow:0 6px 20px -4px var(--orange-glow);
  transition:transform .18s cubic-bezier(.2,.8,.2,1),
             box-shadow .18s cubic-bezier(.2,.8,.2,1),
             gap .18s;
}
.pa-btn--dark:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 32px -6px var(--orange-glow-hover);
  gap:13px;
}
.pa-btn--dark:focus-visible{
  outline:2px solid #fff;
  outline-offset:4px;
  border-radius:999px;
}

/* ════════════════════════════════════════════════
   PUNTO 6 — Microdetalles
   ════════════════════════════════════════════════ */

/* Fold divider — línea coral gradient entre folds claros */
.pa-fold-divider{
  height:1px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,90,31,.25) 30%,
    rgba(255,90,31,.35) 50%,
    rgba(255,90,31,.25) 70%,
    transparent 100%);
  border:none;margin:0;
}

/* Orange glow hover en tarjetas */
.pa-programs .pa-spec:hover,
.pa-faq .faq-item.is-open{
  --card-glow: 0 8px 32px -8px var(--orange-glow);
}

/* Focus-visible global armonizado */
a:focus-visible,
button:focus-visible,
[role="button"]:focus-visible{
  outline:2px solid var(--orange);
  outline-offset:3px;
  border-radius:6px;
}

/* Hover glow en CTAs existentes que no se migran */
.nav-cta:hover,
.btn-p:hover,
.lms-cta-primary:hover,
.pa-flagship-btn-p:hover,
.faq-cta-btn:hover,
.cta-band-btn:hover{
  box-shadow:0 1px 0 rgba(255,255,255,.28) inset,
             0 16px 36px -8px var(--orange-glow-hover) !important;
}

/* ── Isotipo de fondo decorativo ── */
.pa-isotipo-bg{
  position:absolute;
  pointer-events:none;
  user-select:none;
}
/* Hero — esquina inferior derecha, muy sutil */
.hero .pa-isotipo-bg{
  width:340px;height:auto;
  bottom:-40px;right:-60px;
  color:var(--orange);
  opacity:.06;
}
/* CTA band — centrado grande, sutil */
.pa-cta-band .pa-isotipo-bg{
  width:480px;height:auto;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  color:#fff;
  opacity:.04;
}

/* ── Community: isotipo decorativo + badge ── */
.pa-community{position:relative;overflow:hidden}

.cm-isotipo-bg{
  position:absolute;
  top:-40px;right:-80px;
  width:420px;height:auto;
  color:var(--orange);
  opacity:.07;
  pointer-events:none;
  user-select:none;
}

.cm-ecosystem{
  display:inline-flex;align-items:center;gap:14px;
  margin-top:36px;
}
.cm-ecosystem-icon{
  width:32px;height:auto;
  color:var(--orange);
  flex-shrink:0;
}
.cm-ecosystem-sep{
  width:1px;height:28px;
  background:rgba(13,17,23,.15);
}
.cm-ecosystem-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;font-weight:500;
  letter-spacing:.12em;
  color:rgba(13,17,23,.45);
  text-transform:uppercase;
}

/* Agenda isotipo bg */
.pa-agenda{position:relative;overflow:hidden}
.ag-isotipo-bg{
  position:absolute;top:-60px;right:-100px;
  width:460px;height:auto;
  color:var(--orange);opacity:.05;
  pointer-events:none;user-select:none;
}

/* FAQ isotipo bg + badge eyebrow */
.pa-faq{position:relative;overflow:hidden}

.faq-eyebrow-badge{
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:16px;
}
.faq-eyebrow-badge svg{
  width:20px;height:auto;
  color:var(--orange);
}
.faq-eyebrow-badge .faq-eyebrow{margin-bottom:0}


@media(max-width:768px){
  
  
}

/* ══════════════════════════════════════
   EMPRESAS — Fold oscuro B2B
══════════════════════════════════════ */
.pa-empresas{
  background:var(--dark);
  color:#fafaf7;
  padding:100px 0 100px;
  position:relative;
  overflow:hidden;
}
/* Dot grid sutil igual que pa-gallery */
.pa-empresas::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(255,255,255,.04) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg, transparent, #000 12%, #000 88%, transparent);
  pointer-events:none;z-index:0;
}
/* Glow naranja de fondo — decorativo */
.pa-empresas::after{
  content:"";position:absolute;
  top:-120px;right:-160px;
  width:560px;height:560px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,90,31,.13) 0%, transparent 70%);
  pointer-events:none;z-index:0;
}

.emp-wrap{
  max-width:1240px;margin:0 auto;padding:0 48px;
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}

/* ── LEFT ── */
.emp-left{max-width:540px}

.emp-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  margin-bottom:28px;
}
.emp-eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(255,90,31,.18);
  animation:pa-pulse 2.4s ease-in-out infinite;
}

.emp-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(38px,4.5vw,64px);
  font-weight:400;line-height:1.03;
  letter-spacing:-.022em;
  color:#fafaf7;
  margin:0 0 24px;
}
.emp-title em{
  font-style:italic;
  color:var(--orange);
}

.emp-desc{
  font-size:16px;line-height:1.65;
  color:rgba(250,250,247,.62);
  margin:0 0 40px;
  max-width:42ch;
}

/* CTAs */
.emp-ctas{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:40px}

/* Trust checks */
.emp-checks{
  display:flex;flex-wrap:wrap;gap:10px 28px;
  padding-top:28px;
  border-top:1px solid rgba(255,255,255,.08);
}
.emp-check{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:500;
  color:rgba(250,250,247,.65);
}
.emp-check-icon{
  width:18px;height:18px;border-radius:50%;
  background:rgba(255,90,31,.18);
  border:1px solid rgba(255,90,31,.3);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.emp-check-icon svg{width:10px;height:10px;color:var(--orange)}

/* ── RIGHT — logo grid ── */
.emp-right{}

.emp-logos-label{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  display:flex;align-items:center;gap:10px;
  margin-bottom:32px;
}
.emp-logos-label-dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--orange);
  animation:pa-pulse 2.4s ease-in-out infinite;
}

.emp-logo-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
}

.emp-logo-cell{
  display:flex;align-items:center;justify-content:center;
  padding:28px 20px;
  border-right:1px solid rgba(255,255,255,.07);
  border-bottom:1px solid rgba(255,255,255,.07);
  transition:background .25s;
}
.emp-logo-cell:hover{background:rgba(255,255,255,.04)}
/* Quitar borde derecho en última columna */
.emp-logo-cell:nth-child(3n){border-right:1px solid rgba(255,255,255,.07)}
/* Quitar borde inferior en última fila */
.emp-logo-cell:nth-last-child(-n+3){border-bottom:none}


/* Stars rating */
.emp-rating{
  margin-top:32px;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.07);
  display:flex;align-items:center;gap:12px;
}
.emp-stars{display:flex;gap:3px}
.emp-stars svg{width:14px;height:14px;color:var(--orange)}
.emp-rating-txt{
  font-size:13px;line-height:1.45;
  color:rgba(250,250,247,.55);
}

/* Responsive */
@media(max-width:1024px){
  .emp-wrap{grid-template-columns:1fr;gap:60px}
  .emp-left{max-width:none}
}
@media(max-width:640px){
  .pa-empresas{padding:72px 0 72px}
  .emp-wrap{padding:0 24px;gap:48px}
  .emp-title{font-size:36px}
  .emp-desc{font-size:15px;margin-bottom:32px}
  .emp-logo-grid{grid-template-columns:repeat(2,1fr)}
  .emp-logo-cell{padding:22px 12px}
  .emp-logo-cell img{max-width:130px;max-height:46px}
}


/* ── Logo grid: SVG inline + PNG ── */
.emp-logo-svg{
  display:flex;align-items:center;justify-content:center;
  width:100%;height:36px;
}
.emp-logo-svg svg{
  max-width:160px;max-height:56px;
  width:auto;height:auto;
  opacity:.55;
  filter:brightness(0) invert(1);
  transition:opacity .25s,filter .25s;
}
.emp-logo-cell:hover .emp-logo-svg svg{opacity:.85}

/* PNG logos — sin invert, mantienen su fondo negro */
.emp-logo-cell--png{background:transparent}
.emp-logo-png{
  max-width:160px;max-height:56px;
  width:auto;height:auto;
  opacity:.7;
  transition:opacity .25s;
}
.emp-logo-cell--png:hover .emp-logo-png{opacity:1}

/* Audi es muy detallado — darle un poco más de espacio */
.emp-logo-svg[aria-label="Audi"] svg,
.emp-logo-svg[aria-label="Ferrari"] svg{max-width:120px}


/* ══════════════════════════════════════
   ALUMNI · La generación que ya lidera
══════════════════════════════════════ */
.pa-alumni{
  background:var(--cream-pale);
  padding:100px 0 100px;
  position:relative;
  overflow:hidden;
  border-top:1px solid rgba(13,17,23,.06);
}
/* dot grid sutil */
.pa-alumni::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle at 1px 1px, rgba(13,17,23,.032) 1px, transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg,transparent,#000 12%,#000 88%,transparent);
  pointer-events:none;z-index:0;
}

.alm-wrap{
  max-width:1240px;margin:0 auto;padding:0 48px;
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:80px;
  align-items:start;
  padding-bottom:80px;
}

/* ── LEFT ── */
.alm-left{position:sticky;top:100px;padding-top:8px}

.alm-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--orange);
  margin-bottom:28px;
}
.alm-eb-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--orange);
  box-shadow:0 0 0 4px rgba(255,90,31,.12);
  animation:pa-pulse 2.4s ease-in-out infinite;
}

.alm-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(36px,4vw,58px);
  font-weight:400;line-height:1.05;
  letter-spacing:-.022em;
  color:var(--dark);
  margin:0 0 20px;
}
.alm-dot{color:var(--orange)}

.alm-desc{
  font-size:16px;line-height:1.65;
  color:rgba(13,17,23,.6);
  margin:0 0 36px;
  max-width:38ch;
}

.alm-cta{
  border-color:var(--orange) !important;
  color:var(--orange) !important;
  font-weight:600;
}
.alm-cta:hover{
  background:rgba(255,90,31,.06) !important;
}

/* ── RIGHT — columnas ── */
.alm-right{
  /* máscara de fade top/bottom para suavizar el scroll */
  -webkit-mask-image:linear-gradient(180deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
  mask-image:linear-gradient(180deg, transparent 0%, #000 10%, #000 90%, transparent 100%);
  height:420px;
  overflow:hidden;
}

.alm-cols{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
  height:100%;
}

.alm-col{
  display:flex;flex-direction:column;gap:0;
  position:relative;
}

/* flecha naranja arriba */
.alm-arrow{
  font-size:18px;color:var(--orange);
  text-align:center;
  margin-bottom:12px;
  animation:alm-bounce 1.8s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes alm-bounce{
  0%,100%{transform:translateY(0);opacity:.6}
  50%{transform:translateY(-4px);opacity:1}
}

/* track-wrap clip */
.alm-track-wrap{
  overflow:hidden;
  flex:1;
  position:relative;
}

/* la lista que se mueve */
.alm-track{
  list-style:none;padding:0;margin:0;
  display:flex;flex-direction:column;gap:12px;
  animation:alm-scroll 18s linear infinite;
  will-change:transform;
}
/* Cada columna a velocidad ligeramente distinta */
.alm-col:nth-child(1) .alm-track{animation-duration:18s}
.alm-col:nth-child(2) .alm-track{animation-duration:22s}
.alm-col:nth-child(3) .alm-track{animation-duration:20s}
.alm-col:nth-child(4) .alm-track{animation-duration:24s}

@keyframes alm-scroll{
  0%{transform:translateY(0)}
  100%{transform:translateY(-50%)}
}

/* Pausa on hover */
.alm-col:hover .alm-track{animation-play-state:paused}

/* Card individual */
.alm-card{
  background:#fff;
  border:1px solid rgba(13,17,23,.07);
  border-radius:10px;
  padding:16px 18px;
  display:flex;flex-direction:column;gap:3px;
  transition:border-color .2s, box-shadow .2s, transform .2s;
  flex-shrink:0;
}
.alm-card:hover{
  border-color:rgba(255,90,31,.25);
  box-shadow:0 6px 20px -6px rgba(13,17,23,.12);
  transform:translateY(-2px);
}
.alm-card strong{
  font-family:'Inter',sans-serif;
  font-size:13px;font-weight:600;
  color:var(--dark);line-height:1.3;
}
.alm-card span{
  font-size:11.5px;color:rgba(13,17,23,.5);
  line-height:1.3;
}
.alm-card em{
  font-style:normal;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:600;
  letter-spacing:.1em;
  color:var(--orange);
  margin-top:4px;
}

/* ── STATS BAR ── */
.alm-stats{
  position:relative;z-index:2;
  border-top:1px solid rgba(13,17,23,.07);
  display:flex;align-items:center;flex-wrap:wrap;
  padding:24px 48px;
  gap:0;
  background:var(--cream-pale);
}
.alm-stat{
  font-size:13px;color:rgba(13,17,23,.6);
  display:flex;align-items:center;gap:8px;
  padding:8px 0;
  flex:1;min-width:140px;
}
.alm-stat strong{color:var(--dark);font-weight:600}
.alm-stat-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--orange);
  flex-shrink:0;
}
.alm-stat-sep{
  width:1px;height:28px;
  background:rgba(13,17,23,.1);
  margin:0 24px;
  flex-shrink:0;
}

/* ── Responsive ── */
@media(max-width:1024px){
  .alm-wrap{grid-template-columns:1fr;gap:48px;padding-bottom:60px}
  .alm-left{position:static}
  .alm-right{height:360px}
}
@media(max-width:640px){
  .pa-alumni{padding:72px 0 72px}
  .alm-wrap{padding:0 24px 48px}
  .alm-cols{grid-template-columns:repeat(2,1fr)}
  .alm-col:nth-child(n+3){display:none}
  .alm-right{height:380px}
  .alm-stats{padding:20px 24px;gap:0}
  .alm-stat{font-size:12px;min-width:120px}
  .alm-stat-sep{margin:0 14px;height:20px}
}
@media(prefers-reduced-motion:reduce){
  .alm-track{animation:none}
  .alm-arrow{animation:none}
}


/* ══════════════════════════════════════
   FLOATING ISOTIPO — movimiento vertical suave
══════════════════════════════════════ */
@keyframes iso-float{
  0%,100%{transform:translateY(0) rotate(0deg)}
  33%{transform:translateY(-10px) rotate(.4deg)}
  66%{transform:translateY(6px) rotate(-.3deg)}
}
.cm-isotipo-bg,
.ag-isotipo-bg,
.ft-isotipo-bg{
  animation:iso-float 7s ease-in-out infinite;
  will-change:transform;
}
.cm-isotipo-bg{animation-duration:7s;animation-delay:0s}
.ag-isotipo-bg{animation-duration:9s;animation-delay:-2.5s}
.ft-isotipo-bg{animation-duration:8s;animation-delay:-5s}

/* El isotipo del hero ya tiene su propio float via float1/2/3 — no se toca */
/* El isotipo del CTA band flota independiente */
.pa-cta-band .pa-isotipo-bg{
  animation:iso-float 11s ease-in-out infinite;
  animation-delay:-3s;
  will-change:transform;
}

/* ══════════════════════════════════════
   PARALLAX — hero image + secciones oscuras
══════════════════════════════════════ */
/* Hero: la imagen de fondo del hero-right se mueve 0.25× el scroll */
.hero-right .hero-bg-img,
.hero-right .slide-img{
  will-change:transform;
  transition:none;
}

/* Sección oscura (gallery + empresas): isotipo y dot-grid se mueven lento */
.pa-gallery::before,
.pa-empresas::before,
.pa-empresas::after{
  will-change:transform;
}

@media(prefers-reduced-motion:reduce){
  .cm-isotipo-bg,
  .ag-isotipo-bg,
  .ft-isotipo-bg,
  .pa-cta-band .pa-isotipo-bg{
    animation:none;
  }
}


/* ══════════════════════════════════════
   SCROLL REVEAL GLOBAL — sr-reveal
   Reutiliza la lógica de pa-up pero global
══════════════════════════════════════ */
.sr{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .75s cubic-bezier(.22,.61,.36,1),
             transform .75s cubic-bezier(.22,.61,.36,1);
}
.sr.sr-left{transform:translateX(-32px)}
.sr.sr-right{transform:translateX(32px)}
.sr.sr-scale{transform:scale(.97) translateY(16px)}
.sr.is-visible{
  opacity:1;
  transform:none;
}

/* Stagger delays — se aplican con data-sr-delay */
.sr[data-sr-delay="1"]{transition-delay:.08s}
.sr[data-sr-delay="2"]{transition-delay:.16s}
.sr[data-sr-delay="3"]{transition-delay:.24s}
.sr[data-sr-delay="4"]{transition-delay:.32s}
.sr[data-sr-delay="5"]{transition-delay:.40s}

/* ── Counter animado ── */
.alm-stat strong[data-count]{
  display:inline-block;
  transition:none;
}

/* ── Stagger stats bar ── */
.alm-stat{
  opacity:0;
  transform:translateY(12px);
  transition:opacity .5s ease, transform .5s ease;
}
.alm-stats.is-visible .alm-stat:nth-child(1){opacity:1;transform:none;transition-delay:.05s}
.alm-stats.is-visible .alm-stat:nth-child(2){opacity:1;transform:none;transition-delay:.1s}
.alm-stats.is-visible .alm-stat:nth-child(3){opacity:1;transform:none;transition-delay:.2s}
.alm-stats.is-visible .alm-stat:nth-child(4){opacity:1;transform:none;transition-delay:.3s}
.alm-stats.is-visible .alm-stat:nth-child(5){opacity:1;transform:none;transition-delay:.4s}
.alm-stats.is-visible .alm-stat:nth-child(6){opacity:1;transform:none;transition-delay:.5s}
.alm-stats.is-visible .alm-stat:nth-child(7){opacity:1;transform:none;transition-delay:.6s}

@media(prefers-reduced-motion:reduce){
  .sr,.alm-stat{
    opacity:1 !important;
    transform:none !important;
    transition:none !important;
  }
}


/* ══════════════════════════════════════
   TILT CARDS — inclinación 3D sutil al cursor
   Se activa solo en dispositivos con hover real
══════════════════════════════════════ */
@media(hover:hover) and (pointer:fine){
  .tst-card,
  .alm-card{
    transform-style:preserve-3d;
    transition:transform .15s ease, box-shadow .15s ease;
    will-change:transform;
  }
  /* Los estilos de tilt se aplican vía JS con inline style */
}

/* ══════════════════════════════════════
   FADE ENTRE SECCIONES — divisores suavizados
══════════════════════════════════════ */

/* De claro (cream) a oscuro (dark) */
.pa-gallery{
  position:relative;
}
.pa-gallery::after{
  content:"";
  position:absolute;
  top:0;left:0;right:0;
  height:80px;
  background:linear-gradient(180deg, var(--cream-pale) 0%, transparent 100%);
  pointer-events:none;
  z-index:3;
}

/* De oscuro (gallery) a claro (comunidad) — desde abajo */
.pa-gallery{
  padding-bottom:0;
}

/* Divisor pa-fold-divider — ya existe, lo enriquecemos */
.pa-fold-divider{
  height:2px;
  background:linear-gradient(90deg,
    transparent 0%,
    rgba(255,90,31,.18) 20%,
    rgba(255,90,31,.30) 50%,
    rgba(255,90,31,.18) 80%,
    transparent 100%) !important;
  border:none;margin:0;
  position:relative;
  z-index:10;
}

/* Fade de entrada en secciones oscuras — gradient superpuesto top */
.pa-empresas{
  position:relative;
}
.pa-empresas > .emp-wrap{
  position:relative;z-index:2;
}

/* ══════════════════════════════════════
   SLOW HOVER LOGOS — grayscale → color .5s
   Solo para los 7 SVG con invert (no PNG)
══════════════════════════════════════ */
.emp-logo-svg.emp-logo-invert svg{
  transition:opacity .5s ease, filter .5s ease;
  opacity:.5;
  filter:brightness(0) invert(1);
}
.emp-logo-cell:hover 

/* PNG logos — slow hover opacity solamente */


/* Testimonios hover — slow shadow */
.tst-card{
  transition:box-shadow .4s ease, transform .15s ease;
}
.tst-card:hover{
  box-shadow:0 12px 40px -10px rgba(13,17,23,.16);
}

@media(prefers-reduced-motion:reduce){
  .tst-card,.alm-card{
    transition:none !important;
    transform:none !important;
  }
  
}

/* Footer: isotipo watermark de fondo */
.pa-footer{position:relative;overflow:hidden}
.ft-isotipo-bg{
  position:absolute;bottom:-40px;right:-60px;
  width:300px;height:auto;
  color:var(--orange);opacity:.06;
  pointer-events:none;user-select:none;
}

/* ── Mobile collapse/expand behaviours ── */
@media(max-width:640px){

  /* LMS: show ver más button only on mobile */
  #lms-more-btn{display:block !important}

  /* Gallery: hide extra items by default on mobile */
  .gal-extra-hidden{display:none}
  .gal-seemore-wrap{
    text-align:center;
    margin-top:28px;
    padding-bottom:4px
  }
  #gal-more-btn{
    background:transparent;
    border:1.5px solid var(--orange,#e85d04);
    color:var(--orange,#e85d04);
    padding:12px 28px;
    font-size:12px;
    letter-spacing:.1em;
    text-transform:uppercase;
    cursor:pointer;
    font-family:inherit
  }

  /* Logos bar: horizontal scroll */
  .logos-bar{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    padding:12px 0
  }
  .logos-bar::-webkit-scrollbar{display:none}
  .logos-row{
    display:inline-flex;
    flex-wrap:nowrap;
    gap:24px;
    padding:0 20px;
    white-space:nowrap
  }
  .logos-label-inline{display:none}

  /* Empresas: 2-col logo grid */
  .emp-logo-grid{grid-template-columns:repeat(2,1fr) !important}
  .emp-logo-cell:nth-child(2n){border-right:none}
  .emp-logo-cell:nth-child(3n){border-right:1px solid rgba(255,255,255,.07)}
  .emp-logo-cell:nth-last-child(-n+2){border-bottom:none}
  .emp-logo-cell:nth-last-child(-n+3){border-bottom:1px solid rgba(255,255,255,.07)}
}
