
/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
ul{list-style:none}

/* ── VARIABLES ── */
:root{
  --bg:#0d0620;
  --surface:rgba(18,8,42,0.6);
  --surface-2:rgba(24,12,54,0.5);
  --surface-3:rgba(34,16,68,0.45);
  --glass:rgba(22,10,50,0.65);
  --border:rgba(138,11,210,0.18);
  --border-h:rgba(178,75,240,0.38);
  --accent:#8A0BD2;
  --accent-soft:#b44bf0;
  --accent-bright:#9b2de0;
  --accent-glow:rgba(138,11,210,0.4);
  --orange:#f97316;
  --green:#22c55e;
  --green-soft:#4ade80;
  --text:#f0eaff;
  --text-soft:#d4c8f0;
  --muted:#9b8ec4;
  --radius:16px;
  --radius-sm:12px;
  --radius-lg:24px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ── BODY ── */
body{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 90% 70% at 12% 18%,rgba(138,11,210,0.5) 0%,transparent 55%),
    radial-gradient(ellipse 75% 55% at 88% 22%,rgba(155,45,224,0.4) 0%,transparent 52%),
    radial-gradient(ellipse 100% 80% at 50% 85%,rgba(138,11,210,0.35) 0%,transparent 58%),
    radial-gradient(ellipse 65% 45% at 72% 68%,rgba(180,75,240,0.3) 0%,transparent 48%),
    radial-gradient(ellipse 55% 50% at 25% 55%,rgba(120,20,200,0.25) 0%,transparent 45%),
    linear-gradient(155deg,#24085a 0%,#180845 25%,#110630 50%,#0d0620 100%);
  background-attachment:fixed;
  color:var(--text);
  overflow-x:hidden;
}

/* ── ANIMATIONS ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ============================================
   INFO BAR (marquee)
   ============================================ */
@keyframes scrollInfoBar{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.info-bar{
  overflow:hidden;white-space:nowrap;
  background:linear-gradient(90deg,#1a0535 0%,rgba(138,11,210,0.35) 30%,rgba(249,115,22,0.18) 70%,#1a0535 100%);
  border-bottom:1px solid rgba(138,11,210,0.25);
  position:relative;
}
.info-bar::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(138,11,210,0.08) 50%,transparent 100%);
  pointer-events:none;
}
.info-bar-content{
  display:inline-block;
  padding:.55rem 0;
  font-size:.85rem;
  color:rgba(255,255,255,0.88);
  animation:scrollInfoBar 20s linear infinite;
}
.info-bar-content:hover{animation-play-state:paused}
.info-bar-text{display:inline-block;padding:0 2rem}
.info-bar-text strong{color:#f59e0b;font-weight:700}

/* ============================================
   NAVBAR
   ============================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(135deg,rgba(26,5,53,0.92) 0%,rgba(48,12,90,0.88) 50%,rgba(26,5,53,0.92) 100%);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(138,11,210,0.25);
  box-shadow:0 4px 24px rgba(138,11,210,0.1),0 1px 0 rgba(138,11,210,0.15) inset;
}
.nav-inner{
  width:95%;max-width:1600px;margin:0 auto;
  padding:.85rem 0;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  flex-wrap:wrap;
}
.nav-brand{
  display:flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:1.1rem;color:var(--text);
  text-decoration:none;transition:all .3s;
}
.nav-brand:hover{opacity:.9}
.nav-brand img{width:40px;height:40px}

.nav-links{display:flex;align-items:center;gap:1rem;font-size:.95rem}
.nav-links a{
  padding:.35rem .9rem;border-radius:999px;
  color:var(--muted);font-weight:500;
  transition:all .25s;text-decoration:none;
}
.nav-links a:hover,
.nav-links a.is-active{
  background:rgba(124,58,237,0.28);color:var(--text);
}
.nav-toggle{
  display:none;
  padding:.35rem .8rem;border-radius:999px;
  border:1px solid var(--border);
  color:var(--text);font-size:1.1rem;
  transition:all .3s;background:transparent;cursor:pointer;
}
.nav-toggle:hover{background:rgba(138,11,210,.12);border-color:var(--accent)}

/* ── Botones genéricos ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  padding:.55rem 1.25rem;border:none;border-radius:999px;
  font-size:.95rem;font-weight:600;cursor:pointer;
  transition:all .25s;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:#fff;
  box-shadow:0 4px 16px rgba(138,11,210,0.15);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(124,58,237,0.35),0 4px 12px rgba(124,58,237,0.2);
}

/* ── Botón usuario logueado — naranja ── */
.btn.is-logged-in,
.btn-primary.is-logged-in,
button.is-logged-in,
#loginBtn.is-logged-in,
#loginButton.is-logged-in,
[data-login-btn].is-logged-in{
  background:linear-gradient(135deg,#ff6b00,#ff8f3d)!important;
  box-shadow:0 4px 16px rgba(255,107,0,0.25),0 2px 6px rgba(255,107,0,0.15)!important;
  border-color:transparent!important;
  animation:none!important;
}
.btn.is-logged-in:hover,
.btn-primary.is-logged-in:hover,
button.is-logged-in:hover,
#loginBtn.is-logged-in:hover,
#loginButton.is-logged-in:hover,
[data-login-btn].is-logged-in:hover{
  background:linear-gradient(135deg,#ff8000,#ffa65d)!important;
  box-shadow:0 8px 24px rgba(255,107,0,0.35),0 4px 10px rgba(255,107,0,0.2)!important;
  transform:translateY(-2px);
}

/* ── Navbar móvil ── */
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-inner{width:90%;padding:.7rem 0}
  .nav-links{
    position:fixed;top:56px;left:0;right:0;
    background:linear-gradient(135deg,rgba(26,5,53,0.97),rgba(48,12,90,0.94));
    backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
    flex-direction:column;padding:1.25rem;gap:.6rem;
    border-bottom:1px solid rgba(138,11,210,0.25);
    box-shadow:0 12px 40px rgba(138,11,210,0.12);
    transform:translateY(-110%);opacity:0;visibility:hidden;
    transition:all .35s var(--ease);
  }
  .nav-links.is-open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links a{width:100%;text-align:center;padding:.75rem 1rem;font-size:1rem}
  .nav-links .btn{width:100%;margin-top:.4rem}
}

/* ============================================
   HERO MEMBRESÍA
   ============================================ */
.membresia-hero{
  text-align:center;
  padding:3.5rem 1.5rem 2rem;
  position:relative;
  overflow:hidden;
}
.membresia-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 30%,rgba(138,11,210,0.2) 0%,transparent 70%);
  pointer-events:none;
}
.membresia-hero-inner{
  position:relative;z-index:1;
  max-width:650px;margin:0 auto;
}
.hero-pill{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(138,11,210,0.15);
  border:1px solid rgba(138,11,210,0.3);
  border-radius:999px;padding:.4rem 1rem;
  font-size:.8rem;color:var(--accent-soft);margin-bottom:1rem;
}
.hero-pill-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--green);
  animation:pulse 2s infinite;
}
.membresia-hero h1{
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:800;line-height:1.15;
  margin-bottom:.8rem;color:var(--text);
}
.membresia-hero h1 span{
  background:linear-gradient(135deg,var(--accent-soft),var(--orange));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.membresia-hero p{
  font-size:1.05rem;color:var(--muted);
  max-width:520px;margin:0 auto;line-height:1.6;
}

/* ============================================
   PLANES — Glass Orb Cards
   ============================================ */
.planes-section{
  width:95%;max-width:1600px;margin:0 auto;
  padding:1rem 0 3rem;
}
.planes-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.25rem;
}

/* ── Card container (Glass Orb) ── */
.plan-card{
  position:relative;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius);
  overflow:visible;
  display:flex;flex-direction:column;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;
}

/* Purple accent layer */
.plan-card::before{
  content:'';position:absolute;
  inset:0;
  background:rgba(138,11,210,0.5);
  z-index:0;
  border-radius:var(--radius);
}

/* Shaped cutout (Glass Orb style) */
.plan-card::after{
  content:'';position:absolute;
  top:3px;left:3px;right:3px;bottom:3px;
  border-radius:13px 60px 13px 13px;
  background:rgba(22,10,50,0.85);
  z-index:0;
}

.plan-card:hover{
  transform:translateY(-8px);
  box-shadow:
    0 20px 50px rgba(0,0,0,0.3),
    0 0 30px rgba(138,11,210,0.15);
  border-color:rgba(255,255,255,0.2);
}

/* Destacado (Premium) — orange glow */
.plan-card.destacado{
  border-color:rgba(255,107,0,0.4);
}
.plan-card.destacado::before{
  background:rgba(255,107,0,0.45);
}
.plan-card.destacado:hover{
  box-shadow:
    0 20px 50px rgba(0,0,0,0.3),
    0 0 40px rgba(255,107,0,0.2);
  border-color:rgba(255,107,0,0.5);
}

/* Elite — purple intense */
.plan-card.elite{
  border-color:rgba(124,58,237,0.35);
}
.plan-card.elite::before{
  background:linear-gradient(135deg,rgba(124,58,237,0.55),rgba(138,11,210,0.5));
}
.plan-card.elite:hover{
  box-shadow:
    0 20px 50px rgba(0,0,0,0.3),
    0 0 40px rgba(124,58,237,0.25);
  border-color:rgba(124,58,237,0.5);
}

/* Badge "Recomendado" */
.plan-badge{
  position:absolute;
  top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,#ff6b00,#ff8c40);
  color:#fff;font-weight:700;
  padding:4px 14px;font-size:.7rem;
  letter-spacing:.5px;text-transform:uppercase;
  border-radius:999px;z-index:5;
  box-shadow:0 4px 12px rgba(255,107,0,0.3);
  white-space:nowrap;
}

/* ── Card inner (content area, above pseudo layers) ── */
.plan-inner{
  position:relative;z-index:1;
  padding:1.5rem 1.25rem;
  display:flex;flex-direction:column;
  flex:1;
}

/* Header */
.plan-header{
  text-align:center;
  padding-bottom:1rem;
  border-bottom:1px solid rgba(138,11,210,0.15);
  margin-bottom:1rem;
}
.plan-icon{
  width:48px;height:48px;
  border-radius:50%;
  background:linear-gradient(135deg,rgba(138,11,210,0.25),rgba(167,139,250,0.15));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .75rem;
  font-size:1.1rem;color:var(--accent-soft);
}
.plan-card.destacado .plan-icon{
  background:linear-gradient(135deg,rgba(255,107,0,0.25),rgba(255,140,64,0.15));
  color:#ff8c40;
}
.plan-card.elite .plan-icon{
  background:linear-gradient(135deg,rgba(124,58,237,0.3),rgba(167,139,250,0.2));
  color:#a78bfa;
}
.plan-name{
  font-size:.7rem;text-transform:uppercase;
  letter-spacing:1.5px;color:var(--muted);
  margin-bottom:.2rem;
}
.plan-title{
  font-size:1.35rem;font-weight:700;
  color:var(--text);margin-bottom:.5rem;
}
.plan-card.destacado .plan-title{
  background:linear-gradient(135deg,#ff6b00,#ff8c40);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.plan-card.elite .plan-title{
  background:linear-gradient(135deg,#a78bfa,#7c3aed);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}

/* Price */
.plan-price{
  display:flex;align-items:baseline;
  justify-content:center;gap:3px;
}
.plan-price .amount{
  font-size:2rem;font-weight:800;
  color:var(--accent-soft);
}
.plan-card.destacado .plan-price .amount{
  color:#ff6b00;
}
.plan-card.elite .plan-price .amount{
  color:#a78bfa;
}
.plan-price .period{
  color:var(--muted);font-size:.9rem;
}
.price-original{
  display:none;margin-bottom:.15rem;
}
.price-original span{
  text-decoration:line-through;
  color:var(--muted);font-size:1rem;
  opacity:.7;
}

/* Features */
.plan-features{
  list-style:none;padding:0;margin:0;
  flex:1;
}
.plan-features li{
  display:flex;align-items:center;gap:.55rem;
  padding:.45rem 0;
  color:rgba(245,243,255,0.85);
  font-size:.82rem;
  border-bottom:1px solid rgba(138,11,210,0.08);
}
.plan-features li:last-child{border-bottom:none}
.plan-features li::before{
  content:'✓';
  color:var(--green);font-weight:700;
  font-size:.8rem;flex-shrink:0;
  width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(34,197,94,0.1);
  border-radius:50%;
}

/* Buttons */
.plan-btn{
  display:block;width:100%;
  padding:.7rem 1rem;
  border:none;border-radius:var(--radius-sm);
  font-size:.88rem;font-weight:600;
  cursor:pointer;text-align:center;
  text-decoration:none;
  transition:all .3s var(--ease);
  margin-top:1rem;
  position:relative;overflow:hidden;
}

/* Shine animation on hover */
.plan-btn::after{
  content:'';position:absolute;
  top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transition:left .5s var(--ease);
}
.plan-btn:hover::after{left:100%}

.plan-btn.primary{
  background:linear-gradient(135deg,#ff6b00,#ff8c40);
  color:#fff;
  box-shadow:0 4px 15px rgba(255,107,0,0.25);
}
.plan-btn.primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 25px rgba(255,107,0,0.35);
}
.plan-btn.secondary{
  background:rgba(138,11,210,0.12);
  color:var(--accent-soft);
  border:1px solid rgba(138,11,210,0.25);
}
.plan-btn.secondary:hover{
  background:rgba(138,11,210,0.22);
  border-color:rgba(138,11,210,0.4);
  transform:translateY(-2px);
}
.plan-btn.elite-btn{
  background:linear-gradient(135deg,#7c3aed,#a78bfa);
  color:#fff;
  box-shadow:0 4px 15px rgba(124,58,237,0.25);
}
.plan-btn.elite-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 25px rgba(124,58,237,0.4);
}

/* ============================================
   GARANTÍA
   ============================================ */
.garantia-section{
  width:95%;max-width:1600px;margin:2rem auto 0;
  padding:2rem 1.5rem;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  text-align:center;
}
.garantia-inner{
  max-width:500px;margin:0 auto;
}
.garantia-icon{
  width:52px;height:52px;border-radius:50%;
  background:rgba(34,197,94,0.12);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .8rem;
  font-size:1.3rem;color:var(--green);
}
.garantia-section h3{
  color:var(--text);font-size:1.15rem;
  font-weight:700;margin-bottom:.4rem;
}
.garantia-section p{
  color:var(--muted);font-size:.9rem;
  line-height:1.6;
}

/* ============================================
   FOOTER
   ============================================ */
.footer{
  border-top:1px solid var(--border);
  padding:1rem 0;
  margin-top:2rem;
}
.footer-inner{
  width:95%;max-width:1600px;margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  font-size:.82rem;color:var(--muted);
}

/* ============================================
   ERROR TOAST
   ============================================ */
.error-toast{
  position:fixed;top:100px;left:50%;
  transform:translateX(-50%);
  background:linear-gradient(135deg,#1a0a2e,#2d1b4e);
  border:2px solid #ff6b00;
  border-radius:var(--radius-sm);
  padding:1.5rem 2rem;
  color:#fff;text-align:center;
  z-index:9999;max-width:90%;
  box-shadow:0 10px 40px rgba(255,107,0,0.3);
  animation:slideDown .5s var(--ease);
}
@keyframes slideDown{
  from{opacity:0;top:50px}
  to{opacity:1;top:100px}
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1100px){
  .planes-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){
  .planes-grid{
    grid-template-columns:1fr;
    max-width:360px;margin:0 auto;
  }
  .membresia-hero{padding:2.5rem 1rem 1.5rem}
  .membresia-hero h1{font-size:1.6rem}
  .plan-inner{padding:1.25rem 1rem}
  .plan-card{border-radius:var(--radius-sm)}
  .plan-card::after{
    top:2px;left:2px;right:2px;bottom:2px;
    border-radius:10px 35px 10px 10px;
  }
  .garantia-section{width:90%;padding:1.5rem 1rem}
}
