* { box-sizing: border-box }
:root{
  --bg:#0b1220; --fg:#0f172a; --muted:#64748b;
  --surface:#0f172a; --card:#ffffff; --alt:#f8fafc; --line:#e2e8f0;
  --brand:#0ea5e9; --brand-ink:#075985;
  --brand-grad: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 35%, #f59e0b 100%);
  --shadow: 0 10px 25px rgba(2,8,23,.10), 0 2px 6px rgba(2,8,23,.06);
}
html,body{ margin:0; font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial; color:var(--fg); background:var(--alt); }
a{ color:var(--brand); text-decoration:none }
a:hover{ text-decoration:underline }
img{ max-width:100%; height:auto; display:block }
.container{ max-width: 1140px; margin: 0 auto; padding: 20px }
.header{ border-bottom:1px solid var(--line) }
.header--pro{ background:
  radial-gradient(1200px 500px at 70% -20%, rgba(14,165,233,.12), transparent 60%),
  radial-gradient(900px 500px at -10% 0%, rgba(245,158,11,.10), transparent 55%),
  linear-gradient(180deg,#ffffff 0%,#f1f5f9 100%);
}
.brand{ display:flex; align-items:center; justify-content:space-between; gap:12px }
.nav a{ margin-left:16px; color:#0f172a; font-weight:600; opacity:.85 }
.nav a:hover{ opacity:1 }
.btn{
  display:inline-block; background: var(--brand-grad); color:#fff;
  padding:12px 18px; border-radius:14px; border:0;
  font-weight:800; letter-spacing:.2px; box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease, opacity .2s;
}
.btn:hover{ transform:translateY(-1px); box-shadow: 0 14px 32px rgba(2,8,23,.12), 0 4px 8px rgba(2,8,23,.07) }
.btn--sm{ padding:9px 14px; border-radius:12px }
.btn--full{ width:100% }
.meta{ color:var(--muted); margin-left:12px }
.hero{ display:grid; grid-template-columns: 1.08fr 0.92fr; gap:26px; align-items:center; padding:30px 0 }
.hero__copy h1{ font-size: clamp(30px, 4.6vw, 54px); line-height:1.05; margin: 0 0 12px }
.hero__copy h1 span{ background: rgba(56,189,248,.18); padding:0 10px; border-radius:10px }
.sub{ font-size: clamp(16px, 2.4vw, 20px); color:#334155; margin: 0 0 14px }
.ticks{ list-style:none; padding:0; margin: 0 0 16px; display:grid; gap:8px }
.ticks li{
  background:#fff; border:1px solid var(--line); padding: 12px 14px; border-radius:12px;
  box-shadow: var(--shadow);
}
.cta-row{ display:flex; align-items:center; gap:12px; margin: 12px 0 10px }
.trust{ display:flex; gap:10px; flex-wrap:wrap }
.badge{ background:#fff; border:1px solid var(--line); padding:8px 12px; border-radius:999px; font-size:14px; box-shadow: var(--shadow) }
.section{ padding: 36px 0 }
.section h2{ margin-top:0; font-size: clamp(22px, 3.2vw, 34px) }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:18px }
.card{
  background: #ffffff; border:1px solid var(--line); border-radius:18px; padding:18px;
  box-shadow: var(--shadow);
}
.alt{ background:#ffffff; border-top:1px solid var(--line); border-bottom:1px solid var(--line) }
.split{ display:grid; grid-template-columns: 1.06fr 0.94fr; gap:22px; align-items:start }
.lead{
  background: rgba(255,255,255,.75);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border:1px solid var(--line); border-radius:18px; padding:18px; position:relative;
  box-shadow: var(--shadow);
}
.lead h3{ margin-top:0 }
.muted{ color:var(--muted) }
.testimonials{ display:grid; grid-template-columns: repeat(3, 1fr); gap:18px }
blockquote{
  background:#fff; border-left:4px solid #38bdf8; margin:0; padding:14px; border-radius:12px; color:#334155;
  box-shadow: var(--shadow);
}
blockquote cite{ display:block; margin-top:6px; color:#0f172a; font-style:normal; font-weight:700 }
.footer{ background:#0b1220; color:#dbeafe; margin-top:16px }
.footer__inner{ display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 0 }
.footnav a{ color:#fde68a; margin-left:14px; font-weight:600 }
.sticky-cta{ position:fixed; bottom:14px; left:0; right:0; display:none }
.sticky__inner{
  background: linear-gradient(180deg, #0b1220, #0f172a);
  color:#e5e7eb; border:1px solid #1f2937; border-radius:14px; padding:12px 14px;
  display:flex; align-items:center; justify-content:space-between; box-shadow: var(--shadow);
}
.hero__art{
  border-radius:20px; overflow:hidden; box-shadow: var(--shadow);
  background: radial-gradient(600px 300px at 20% -10%, rgba(14,165,233,.16), transparent 60%), #fff;
  padding: 10px;
}
@media (max-width: 980px){
  .hero, .split{ grid-template-columns: 1fr }
  .grid-3, .testimonials{ grid-template-columns: 1fr; }
  .nav a{ margin-left:10px }
}


/* Hover motion for "cards" (benefits & proximamente) */
.card{ transition: transform .18s ease, box-shadow .18s ease; will-change: transform; }
.card:hover{ transform: translateY(-6px); box-shadow: 0 18px 40px rgba(2,8,23,.14), 0 6px 14px rgba(2,8,23,.08); }

/* Slightly stronger hover on main buttons */
.btn{ transition: transform .16s ease, box-shadow .16s ease, opacity .2s; }
.btn:hover{ transform: translateY(-2px) scale(1.01); }

/* Proximamente visuals */
#proximamente h2 span{ background: rgba(245,158,11,.12); padding: 0 .35em; border-radius: .5em }
#proximamente .coming{ }


/* Timeline - Programa 4 sesiones */
.steps-pro{ list-style:none; padding:0; margin: 10px 0 0; position:relative }
.steps-pro:before{
  content:""; position:absolute; left:16px; top:0; bottom:0; width:2px;
  background: linear-gradient(180deg, #bae6fd, #93c5fd);
}
.steps-pro li{ display:grid; grid-template-columns: 40px 1fr; gap:12px; position:relative; padding: 8px 0 }
.steps-pro .num{
  display:inline-grid; place-items:center; width:34px; height:34px; border-radius:999px;
  background: linear-gradient(180deg,#38bdf8,#0ea5e9); color:#fff; font-weight:800; box-shadow: var(--shadow);
}
.steps-pro .txt h4{ margin:0 0 4px; font-size:18px }
.steps-pro .txt p{ margin:0; color:#334155 }

/* FAQ styled */
.faq details{
  border:1px solid var(--line); border-radius:14px; background:#fff; padding: 12px 14px; margin-bottom: 10px;
  box-shadow: var(--shadow);
}
.faq summary{
  list-style:none; cursor:pointer; font-weight:700; display:flex; align-items:center; gap:8px;
}
.faq summary::-webkit-details-marker{ display:none }
.faq details[open] summary{ color:#0f172a }
.faq details > *:not(summary){ margin-top:8px; color:#334155 }
.faq summary:after{
  content:"▾"; margin-left:auto; transition: transform .2s ease;
}
.faq details[open] summary:after{ transform: rotate(180deg) }

/* Proximamente locked cards */
.proxi-grid .card{ position:relative }
.proxi-grid .card.locked{
  filter: blur(1px); opacity:.65;
}
.proxi-grid .card.locked .lock{
  position:absolute; top:12px; right:12px; background: rgba(245,158,11,.9); color:#fff;
  padding:6px 10px; border-radius:999px; font-weight:700; font-size:12px;
  box-shadow: var(--shadow);
}


/* Ensure footer sits above sticky if overlapping */
.footer{ position: relative; z-index: 2 }
.sticky-cta{ z-index: 1 }


/* Urgency badge next to meta */
.spots{
  margin-left: 12px;
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px; border-radius:999px;
  background: linear-gradient(135deg,#fde68a,#f59e0b);
  color:#111827; font-weight:800; box-shadow: var(--shadow);
}

/* Bubble list with motion */
.bubble-list li{
  border-radius: 999px;
  background: linear-gradient(180deg,#ffffff,#f1f5f9);
  border:1px solid var(--line);
  padding: 12px 16px;
  box-shadow: var(--shadow);
  animation: floatY 6s ease-in-out infinite;
}
.bubble-list li:nth-child(2){ animation-delay: .8s }
.bubble-list li:nth-child(3){ animation-delay: 1.6s }
@keyframes floatY{
  0%,100%{ transform: translateY(0) }
  50%{ transform: translateY(-4px) }
}

/* Steps: entrance + hover micro-motion */
.steps-pro li{
  animation: rise .5s ease both;
}
.steps-pro li:nth-child(1){ animation-delay: .05s }
.steps-pro li:nth-child(2){ animation-delay: .15s }
.steps-pro li:nth-child(3){ animation-delay: .25s }
.steps-pro li:nth-child(4){ animation-delay: .35s }
@keyframes rise{
  from{ opacity:0; transform: translateY(6px) }
  to{ opacity:1; transform: translateY(0) }
}
.steps-pro li:hover .num{ transform: translateY(-2px); }
.steps-pro .num{ transition: transform .15s ease }

/* Note bubble for steps */
.note-bubble{
  display:inline-block; margin-top: 10px;
  background: linear-gradient(180deg,#ffffff,#f8fafc);
  border:1px solid var(--line); border-radius: 999px; padding: 8px 12px;
  box-shadow: var(--shadow); color:#334155;
}

/* FAQ bubble container */
.faq-bubble{
  background: linear-gradient(180deg,#fff,#f8fafc);
  border:1px solid var(--line);
  border-radius: 18px;
  padding: 14px;
  box-shadow: var(--shadow);
}


/* Animated spots badge */
.spots{
  margin-left: 12px;
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px; border-radius:999px;
  background: linear-gradient(135deg,#fde68a,#f59e0b);
  color:#111827; font-weight:800; box-shadow: var(--shadow);
  animation: pulseGlow 2.4s ease-in-out infinite;
}
.spots--dark{
  background: linear-gradient(135deg,#22d3ee,#f59e0b);
  color:#fff; box-shadow: 0 0 0 rgba(245,158,11,0);
  animation: pulseGlowDark 2.2s ease-in-out infinite;
}
@keyframes pulseGlow{
  0%,100%{ transform: translateY(0) scale(1); box-shadow: var(--shadow) }
  50%{ transform: translateY(-2px) scale(1.03); box-shadow: 0 0 0 8px rgba(245,158,11,.15) }
}
@keyframes pulseGlowDark{
  0%,100%{ transform: translateY(0) scale(1); box-shadow: 0 0 0 0 rgba(245,158,11,0.0) }
  50%{ transform: translateY(-2px) scale(1.04); box-shadow: 0 0 0 8px rgba(245,158,11,.20) }
}


/* Unify "Quedan X cupos" badge to yellow in all contexts */
.spots, .spots--dark{
  margin-left: 12px;
  display:inline-flex; align-items:center; gap:6px;
  padding: 6px 10px; border-radius:999px;
  background: linear-gradient(135deg,#fde68a,#f59e0b);
  color:#111827; font-weight:800; box-shadow: var(--shadow);
  animation: pulseGlow 2.4s ease-in-out infinite;
  border: 1px solid rgba(0,0,0,.05);
}

/* Stronger glow on dark sticky background */
.sticky-cta .spots--dark{ box-shadow: 0 0 0 8px rgba(245,158,11,.18) }

/* FAQ — more attractive cards in a responsive grid */
.faq-bubble{
  background: radial-gradient(600px 200px at 20% -10%, rgba(14,165,233,.08), transparent 60%), linear-gradient(180deg,#fff,#f8fafc);
  border:1px solid var(--line);
  border-radius: 22px;
  padding: 18px;
  box-shadow: var(--shadow);
}
.faq{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px }
@media (max-width: 900px){ .faq{ grid-template-columns: 1fr } }

.faq details{
  border:1px solid var(--line); border-radius:16px; background:#fff; padding: 14px 16px;
  box-shadow: var(--shadow); transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.faq details:hover{ transform: translateY(-2px) }
.faq summary{
  list-style:none; cursor:pointer; font-weight:800; display:flex; align-items:center; gap:10px; color:#0f172a;
}
.faq summary::-webkit-details-marker{ display:none }
.faq summary::before{
  content:"?"; width:26px; height:26px; display:inline-grid; place-items:center;
  border-radius:999px; background: linear-gradient(135deg,#38bdf8,#f59e0b); color:#fff; font-weight:900; font-size:14px;
  box-shadow: 0 4px 10px rgba(2,8,23,.12);
}
.faq details[open]{ border-color:#fde68a; }
.faq details[open] summary::before{ background: linear-gradient(135deg,#22c55e,#16a34a) }
.faq details > p{ margin-top:10px; color:#334155; animation: fadeIn .2s ease both }
@keyframes fadeIn{ from{ opacity:0; transform: translateY(4px) } to{ opacity:1; transform:none } }


/* FAQ Pro */
.faq-pro{
  position: relative;
  border-radius: 24px;
  padding: 24px;
  background:
    radial-gradient(900px 300px at 10% -20%, rgba(56,189,248,.12), transparent 60%),
    radial-gradient(700px 280px at 110% 120%, rgba(245,158,11,.10), transparent 60%),
    linear-gradient(180deg,#ffffff,#f8fafc);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.faq-pro h2{ margin-top:0 }
.faq-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 14px }
@media (max-width: 900px){ .faq-grid{ grid-template-columns: 1fr } }

.faq-grid details{
  border:1px solid var(--line);
  border-radius:16px;
  background:#fff;
  padding: 14px 16px;
  box-shadow: var(--shadow);
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
.faq-grid details:hover{ transform: translateY(-2px) }
.faq-grid summary{
  list-style:none; cursor:pointer; font-weight:800; display:flex; align-items:center; gap:10px; color:#0f172a;
}
.faq-grid summary::-webkit-details-marker{ display:none }
.faq-grid summary:after{ content:"▾"; margin-left:auto; transition: transform .2s ease; opacity:.7 }
.faq-grid details[open] summary:after{ transform: rotate(180deg); opacity:1 }
.faq-grid details[open]{ border-color:#fde68a; background: linear-gradient(180deg,#fff,#f8fafc) }
.faq-grid details > p{ margin-top:10px; color:#334155; animation: fadeIn .2s ease both }

.faq-grid .ico{
  width:28px; height:28px; display:inline-grid; place-items:center; border-radius:999px;
  background: linear-gradient(135deg,#38bdf8,#f59e0b); color:#fff; font-size:14px; box-shadow: 0 4px 10px rgba(2,8,23,.12);
}
@keyframes fadeIn{ from{ opacity:0; transform: translateY(4px) } to{ opacity:1; transform:none } }


/* === Palette adjustments === */
/* Revert site accents to purple/indigo, keep "Próximamente" amber */
:root{
  --brand-grad: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 35%, #6366f1 100%);
}

/* Spots (Quedan X cupos) back to purple */
.spots, .spots--dark{
  background: linear-gradient(135deg,#22d3ee,#6366f1);
  color:#fff; border-color: rgba(0,0,0,.05);
  animation: pulseGlowPurple 2.2s ease-in-out infinite;
}
.sticky-cta .spots--dark{ box-shadow: 0 0 0 8px rgba(99,102,241,.20) }
@keyframes pulseGlowPurple{
  0%,100%{ transform: translateY(0) scale(1); box-shadow: 0 0 0 0 rgba(99,102,241,0.0) }
  50%{ transform: translateY(-2px) scale(1.04); box-shadow: 0 0 0 8px rgba(99,102,241,.20) }
}

/* FAQ back to purple accents */
.faq-pro{
  background:
    radial-gradient(900px 300px at 10% -20%, rgba(56,189,248,.12), transparent 60%),
    radial-gradient(700px 280px at 110% 120%, rgba(99,102,241,.10), transparent 60%),
    linear-gradient(180deg,#ffffff,#f8fafc);
}
.faq-grid details[open]{ border-color:#c7d2fe; }
.faq-grid .ico{ background: linear-gradient(135deg,#38bdf8,#6366f1) }

/* Keep Próximamente yellow/amber */
#proximamente h2 span{ background: #fde68a !important }
.proxi-grid .card.locked .lock{
  background: rgba(245,158,11,.92) !important;
  color:#fff;
}


/* Footer links: back to purple/blue */
.footer .footnav a{ color:#c7d2fe !important; }
.footer .footnav a:hover{ color:#a5b4fc !important; text-decoration:none }

/* Cupos badges: keep both in yellow */
.spots, .sticky-cta .spots--dark{
  background: linear-gradient(135deg,#fde68a,#f59e0b) !important;
  color:#111827 !important; border-color: rgba(0,0,0,.05) !important;
  animation: pulseGlow 2.2s ease-in-out infinite !important;
  box-shadow: 0 0 0 8px rgba(245,158,11,.18);
}

/* Ensure FAQ always styled even if previous CSS conflicts */
#faq .faq-pro{ 
  border-radius: 24px; padding: 24px;
  background:
    radial-gradient(900px 300px at 10% -20%, rgba(56,189,248,.12), transparent 60%),
    radial-gradient(700px 280px at 110% 120%, rgba(99,102,241,.10), transparent 60%),
    linear-gradient(180deg,#ffffff,#f8fafc);
  border: 1px solid var(--line); box-shadow: var(--shadow);
}
#faq .faq-grid{ display:grid; grid-template-columns: 1fr; gap: 14px }
@media (max-width: 900px){ #faq .faq-grid{ display:grid; grid-template-columns: 1fr; gap: 14px } }
#faq details{
  border:1px solid var(--line); border-radius:16px; background:#fff; padding: 14px 16px;
  box-shadow: var(--shadow); transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease, background .15s ease;
}
#faq details:hover{ transform: translateY(-2px) }
#faq summary{ list-style:none; cursor:pointer; font-weight:800; display:flex; align-items:center; gap:10px; color:#0f172a; }
#faq summary::-webkit-details-marker{ display:none }
#faq summary:after{ content:"▾"; margin-left:auto; transition: transform .2s ease; opacity:.7 }
#faq details[open] summary:after{ transform: rotate(180deg); opacity:1 }
#faq details[open]{ border-color:#c7d2fe; background: linear-gradient(180deg,#fff,#f8fafc) }
#faq details > p{ margin-top:10px; color:#334155; animation: fadeIn .2s ease both }
#faq .ico{
  width:26px; height:26px; display:inline-block; border-radius:999px;
  background: linear-gradient(135deg,#38bdf8,#6366f1);
  box-shadow: 0 4px 10px rgba(2,8,23,.12);
}
@keyframes fadeIn{ from{ opacity:0; transform: translateY(4px) } to{ opacity:1; transform:none } }


/* FAQ single-column layout */
#faq .faq-grid{ display:grid; grid-template-columns: 1fr; gap: 14px }

/* Remove emoji content; show a clean gradient dot or '?' */
#faq .ico{
  width:26px; height:26px; display:inline-block; border-radius:999px;
  background: linear-gradient(135deg,#38bdf8,#6366f1);
  box-shadow: 0 4px 10px rgba(2,8,23,.12);
}

