/* ═══════════════════════════════════
   RESET & VARIABLES
═══════════════════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root {
  /* Colors — NASA Dark Theme */
  --white:   #FFFFFF;
  --bg:      #070C18;
  --bg-alt:  #0B1220;
  --dark:    #070C18;
  --dark2:   #050A14;
  --ink:     #F0F4FF;
  --ink-2:   #A8B8CC;
  --ink-3:   #6B7F96;
  --blue:    #3AA8D8;
  --blue-d:  #2280AD;
  --blue-lt: rgba(58,168,216,.14);
  --yellow:  #F59E0B;
  --yellow-lt:rgba(245,158,11,.15);
  --teal:    #0D9488;
  --teal-lt: rgba(13,148,136,.15);
  --purple:  #7C3AED;
  --purple-lt:rgba(124,58,237,.15);
  --green:   #059669;
  --border:  rgba(255,255,255,.1);
  --shadow:  0 1px 3px rgba(0,0,0,.4),0 4px 16px rgba(0,0,0,.3);
  --shadow-md:0 4px 12px rgba(0,0,0,.5),0 16px 40px rgba(0,0,0,.4);
  --shadow-lg:0 8px 24px rgba(0,0,0,.6),0 24px 64px rgba(0,0,0,.5);

  /* Typography */
  --font-display: 'Barlow Condensed', 'Barlow', sans-serif;
  --font-body:    'Barlow', 'Inter', sans-serif;

  /* Layout */
  --max:     1180px;
  --nav-h:   72px;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--font-body);
  background:var(--dark);
  color:var(--ink);
  overflow-x:hidden;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ═══════════════════════════════════
   UTILITIES
═══════════════════════════════════ */
.inner{max-width:var(--max);margin:0 auto;padding:0 2rem}
.bg-alt{background:#0F1525}
.bg-dark{background:var(--dark)}

.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-body);font-size:.68rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;color:var(--blue);
  margin-bottom:1rem;
}
.eyebrow::before{content:'';width:18px;height:1.5px;background:var(--blue)}
.eyebrow.light{color:rgba(255,255,255,.5)}
.eyebrow.light::before{background:rgba(255,255,255,.5)}

.sec-h2{
  font-family:var(--font-display);
  font-size:clamp(2rem,3.5vw,3.1rem);
  font-weight:800;line-height:1.1;
  color:var(--ink);letter-spacing:.01em;
  text-transform:uppercase;
}
.sec-h2 em{font-style:normal;color:var(--blue)}
.sec-h2.white{color:#fff}
.sec-h2.white em{color:rgba(147,186,255,.9)}

.sec-p{color:var(--ink-2);font-size:1.02rem;line-height:1.75;max-width:540px;margin-top:.9rem}

.sec-hdr{margin-bottom:3.5rem}
.sec-hdr.center{text-align:center}
.sec-hdr.center .sec-p{margin-left:auto;margin-right:auto}
.sec-hdr.center .eyebrow{justify-content:center}

/* ═══════════════════════════════════
   REVEAL
═══════════════════════════════════ */
.reveal{
  opacity:0;transform:translateY(24px);
  transition:opacity .65s cubic-bezier(.22,.61,.36,1),
             transform .65s cubic-bezier(.22,.61,.36,1);
}
.reveal.vis{opacity:1;transform:none}

/* ═══════════════════════════════════
   BUTTONS
═══════════════════════════════════ */
.btn-primary{
  display:inline-flex;align-items:center;gap:.45rem;
  background:var(--blue);color:#fff;
  padding:.8rem 1.75rem;border-radius:6px;
  font-family:var(--font-body);font-size:.9rem;font-weight:600;
  border:none;cursor:pointer;
  transition:background .22s,transform .2s,box-shadow .22s;
  box-shadow:0 4px 14px rgba(51,86,211,.35);
}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:0 8px 20px rgba(51,86,211,.45)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;color:var(--ink);
  padding:.8rem 1.75rem;border-radius:6px;
  font-family:var(--font-body);font-size:.9rem;font-weight:600;
  border:1.5px solid var(--border);cursor:pointer;
  transition:all .22s;
}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}

.btn-outline{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;color:var(--blue);
  padding:.75rem 1.5rem;border-radius:6px;
  font-family:var(--font-body);font-size:.88rem;font-weight:600;
  border:1.5px solid var(--blue);cursor:pointer;
  margin-top:1.5rem;
  transition:all .22s;
}
.btn-outline:hover{background:var(--blue);color:#fff}

.btn-white{
  display:inline-flex;align-items:center;gap:.45rem;
  background:#fff;color:var(--dark);
  padding:.85rem 2rem;border-radius:6px;
  font-family:var(--font-body);font-size:.92rem;font-weight:700;
  border:none;cursor:pointer;
  box-shadow:0 4px 16px rgba(0,0,0,.15);
  transition:all .22s;
}
.btn-white:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}

.btn-ghost-wh{
  display:inline-flex;align-items:center;gap:.45rem;
  background:transparent;color:rgba(255,255,255,.85);
  padding:.85rem 2rem;border-radius:6px;
  font-family:var(--font-body);font-size:.92rem;font-weight:600;
  border:1.5px solid rgba(255,255,255,.25);cursor:pointer;
  transition:all .22s;
}
.btn-ghost-wh:hover{border-color:rgba(255,255,255,.7);color:#fff;transform:translateY(-2px)}

.btn-submit{
  width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--blue);color:#fff;
  padding:.9rem 2rem;border-radius:6px;
  font-family:var(--font-body);font-size:.95rem;font-weight:700;
  border:none;cursor:pointer;
  box-shadow:0 4px 14px rgba(51,86,211,.35);
  transition:all .22s;margin-top:.5rem;
}
.btn-submit:hover{background:var(--blue-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(51,86,211,.45)}

/* ═══════════════════════════════════
   NAV
═══════════════════════════════════ */
#nav{
  position:fixed;top:0;left:0;width:100%;
  background:rgba(6,10,18,.95);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:2px solid rgba(58,168,216,.5);
  z-index:1000;transition:all .3s ease;
}
#nav.scrolled{
  background:rgba(6,10,18,.99);
  border-bottom-color:var(--blue);
  box-shadow:0 4px 32px rgba(58,168,216,.12);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  padding:0 2rem;height:var(--nav-h);
  display:flex;align-items:center;gap:2rem;
}
.nav-logo{
  font-family:var(--font-display);font-size:1.55rem;font-weight:800;
  color:#fff;cursor:pointer;letter-spacing:.04em;flex-shrink:0;
  text-transform:uppercase;
}
.nav-logo span{color:var(--blue)}

.nav-links{
  display:flex;gap:2rem;list-style:none;margin:0 auto;
}
.nav-links a{
  font-size:.82rem;font-weight:600;color:rgba(255,255,255,.65);
  transition:color .2s;position:relative;padding-bottom:2px;
  text-transform:uppercase;letter-spacing:.08em;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;
  width:0;height:1.5px;background:var(--blue);
  transition:width .25s;
}
.nav-links a:hover,
.nav-links a.active{color:#fff}
.nav-links a:hover::after,
.nav-links a.active::after{width:100%}

.nav-actions{display:flex;gap:.75rem;align-items:center;flex-shrink:0}
.btn-outline-sm{
  font-family:var(--font-body);font-size:.82rem;font-weight:600;
  color:rgba(255,255,255,.7);padding:.5rem 1.1rem;border-radius:5px;
  border:1.5px solid rgba(255,255,255,.2);transition:all .2s;
}
.btn-outline-sm:hover{border-color:var(--blue);color:var(--blue)}
.btn-filled-sm{
  font-family:var(--font-body);font-size:.82rem;font-weight:600;
  color:#fff;padding:.5rem 1.1rem;border-radius:5px;
  background:var(--blue);transition:all .2s;
  box-shadow:0 2px 8px rgba(51,86,211,.3);
}
.btn-filled-sm:hover{background:var(--blue-d);transform:translateY(-1px)}

.hamburger{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-drawer{
  position:fixed;top:0;right:-300px;width:280px;height:100vh;
  background:#060A12;z-index:999;
  display:flex;flex-direction:column;padding:5rem 2rem 2rem;
  gap:.2rem;box-shadow:-8px 0 32px rgba(0,0,0,.6);
  transition:right .35s cubic-bezier(.22,.61,.36,1);
  border-left:1px solid rgba(255,255,255,.08);
}
.mobile-drawer.open{right:0}
.mobile-drawer a{
  color:rgba(255,255,255,.6);font-size:1rem;font-weight:600;
  padding:.75rem 0;border-bottom:1px solid rgba(255,255,255,.07);
  transition:color .2s;cursor:pointer;text-transform:uppercase;letter-spacing:.06em;font-size:.88rem;
}
.mobile-drawer a:hover{color:var(--blue)}
.mobile-drawer a.cta{
  margin-top:.5rem;background:var(--blue);color:#fff;
  text-align:center;border-radius:6px;padding:.85rem 1rem;
  border:none;font-weight:700;
}

/* ═══════════════════════════════════
   HERO
═══════════════════════════════════ */
#hero{
  min-height:100vh;
  padding:calc(var(--nav-h) + 5rem) 2rem 4rem;
  max-width:100%;margin:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:flex-start;
  position:relative;overflow:hidden;
  background:
    linear-gradient(to bottom, rgba(6,10,18,.88) 0%, rgba(6,10,18,.6) 50%, rgba(6,10,18,.95) 100%),
    url('https://images.unsplash.com/photo-1462331940025-496dfbfc7564?w=1600&q=80') center/cover no-repeat;
}
#hero::after{
  content:'';
  position:absolute;bottom:0;left:0;width:100%;height:2px;
  background:linear-gradient(90deg, transparent, var(--blue), transparent);
  pointer-events:none;
}

.hero-bg-grid{
  position:absolute;top:0;left:0;width:100%;height:100%;
  background-image:
    linear-gradient(rgba(58,168,216,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(58,168,216,.03) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;z-index:0;
}

.hero-blob{
  position:absolute;border-radius:50%;filter:blur(100px);
  pointer-events:none;z-index:0;
}
.hero-blob.b1{
  width:700px;height:700px;
  background:radial-gradient(circle,rgba(26,58,107,.7),transparent 70%);
  top:-150px;right:-150px;
}
.hero-blob.b2{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(58,168,216,.12),transparent 70%);
  bottom:0;left:-100px;
}

.hero-content{
  max-width:860px;text-align:center;
  display:flex;flex-direction:column;align-items:center;
  position:relative;z-index:1;
}

.hero-badge{
  display:inline-flex;align-items:center;gap:.55rem;
  background:var(--blue-lt);color:var(--blue);
  padding:.4rem 1.1rem;border-radius:100px;
  font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  margin-bottom:2rem;
}
.badge-dot{width:6px;height:6px;background:var(--blue);border-radius:50%;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

#hero h1{
  font-family:var(--font-display);
  font-size:clamp(3rem,8vw,6.5rem);
  font-weight:800;line-height:1.0;
  color:#fff;letter-spacing:.02em;
  margin-bottom:1.6rem;
  text-transform:uppercase;
}
#hero h1 em{font-style:normal;color:var(--blue)}

.hero-sub{
  font-size:1.1rem;color:rgba(255,255,255,.7);line-height:1.75;
  max-width:560px;margin-bottom:2.4rem;
}

.hero-ctas{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.5rem}

.hero-proof{
  display:flex;align-items:center;gap:1rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:100px;padding:.5rem 1.2rem .5rem .6rem;
  backdrop-filter:blur(8px);
}
.sp-avatars{display:flex}
.av{
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:.6rem;font-weight:700;color:#fff;
  border:2px solid #fff;margin-left:-6px;
}
.av:first-child{margin-left:0}
.av.a1{background:#3356D3}
.av.a2{background:#0D9488}
.av.a3{background:#7C3AED}
.av.a4{background:#F59E0B}
.av.a5{background:var(--ink-3);font-size:.55rem}

.sp-text{display:flex;flex-direction:column;gap:.1rem;margin-left:.5rem}
.sp-stars{color:#F59E0B;font-size:.75rem;letter-spacing:-.02em}
.sp-text>span:last-child{font-size:.78rem;color:rgba(255,255,255,.7);font-weight:500}

/* Dashboard Mockup */
.hero-mockup{
  width:100%;max-width:900px;
  background:#FFFFFF;border:1px solid rgba(255,255,255,.2);
  border-radius:14px;box-shadow:var(--shadow-lg);
  overflow:hidden;margin-top:4rem;
  position:relative;z-index:1;
}
.mockup-bar{
  background:#F0F2F5;border-bottom:1px solid #E0E4EA;
  padding:.65rem 1rem;display:flex;align-items:center;gap:.4rem;
}
.dot{width:10px;height:10px;border-radius:50%}
.dot.red{background:#FF5F57}
.dot.yellow{background:#FEBC2E}
.dot.green{background:#28C840}
.mockup-url{
  margin-left:.75rem;font-size:.72rem;color:var(--ink-3);
  font-family:monospace;background:#E4E8F0;
  padding:.2rem .75rem;border-radius:5px;border:1px solid #D0D5DF;
}

.mockup-body{display:flex;height:280px}

.mockup-sidebar{
  background:#0D1B2E;
  padding:1.2rem .9rem;display:flex;flex-direction:column;gap:1.2rem;
  border-right:1px solid rgba(255,255,255,.08);
}
.sb-logo{
  font-family:var(--font-display);font-size:1rem;font-weight:700;
  color:#fff;letter-spacing:-.01em;
}
.sb-logo span{color:rgba(147,186,255,.85)}
.sb-nav{display:flex;flex-direction:column;gap:.2rem}
.sb-item{
  font-size:.7rem;color:rgba(255,255,255,.45);
  padding:.45rem .6rem;border-radius:5px;
  transition:all .2s;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.sb-item.active{background:rgba(58,168,216,.2);color:rgba(180,225,245,.9)}

.mockup-main{flex:1;padding:1.2rem 1.5rem;overflow:hidden;background:#FFFFFF}
.mockup-header-row{
  display:flex;justify-content:space-between;align-items:flex-start;
  margin-bottom:1rem;
}
.mockup-title{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:#0C1829}
.mockup-date{font-size:.68rem;color:var(--ink-3);margin-top:.1rem}
.mockup-badge-live{
  display:flex;align-items:center;gap:.4rem;
  background:rgba(5,150,105,.1);color:#059669;
  font-size:.68rem;font-weight:600;padding:.25rem .65rem;border-radius:100px;
  border:1px solid rgba(5,150,105,.2);
}
.live-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:blink 1.5s infinite}

.mockup-cards{display:flex;gap:.75rem;margin-bottom:1rem}
.mc{
  flex:1;padding:.8rem;border-radius:8px;border:1px solid #E4E8F0;
  background:#F8F9FC;
}
.mc.blue{background:rgba(58,168,216,.08);border-color:rgba(58,168,216,.2)}
.mc.purple{background:rgba(124,58,237,.08);border-color:rgba(124,58,237,.2)}
.mc.teal{background:rgba(13,148,136,.08);border-color:rgba(13,148,136,.2)}
.mc-label{font-size:.6rem;color:var(--ink-3);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.3rem}
.mc-val{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:#fff;line-height:1}
.mc-delta{font-size:.62rem;color:#34D399;font-weight:600;margin-top:.2rem}

.mockup-chart{background:#F0F2F5;border:1px solid #E0E4EA;border-radius:8px;padding:.8rem}
.chart-label{font-size:.62rem;color:var(--ink-3);font-weight:600;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.6rem}
.chart-bars{display:flex;align-items:flex-end;gap:.3rem;height:60px}
.bar{
  flex:1;background:#D0D8E8;border-radius:3px 3px 0 0;
  height:var(--h,50%);
  display:flex;flex-direction:column;justify-content:flex-end;
  align-items:center;padding-bottom:.2rem;
  transition:background .2s;
}
.bar.hi{background:var(--blue)}
.bar span{font-size:.55rem;color:var(--ink-3);margin-top:.3rem}

/* ═══════════════════════════════════
   TRUST BAR
═══════════════════════════════════ */
.trust-bar{
  border-top:1px solid rgba(255,255,255,.06);border-bottom:1px solid rgba(255,255,255,.06);
  padding:1.4rem 2rem;background:#060A12;
}
.trust-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
}
.trust-label{
  font-size:.7rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-3);white-space:nowrap;flex-shrink:0;
}
.trust-logos{
  display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;
}
.trust-logos span{font-family:var(--font-display);font-size:.95rem;font-weight:700;color:rgba(255,255,255,.3)}
.trust-logos .sep{color:rgba(255,255,255,.1)}

/* ═══════════════════════════════════
   SERVICIOS
═══════════════════════════════════ */
#servicios{padding:6rem 0}

.svc-grid{
  display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;
  gap:1.25rem;align-items:start;
}
.svc-card{
  background:linear-gradient(160deg,#0F1A2E 0%,#0B0F1C 100%);
  border:1px solid rgba(58,168,216,.18);
  border-top:3px solid var(--blue);
  box-shadow:0 0 0 0 rgba(58,168,216,0);
  border-radius:12px;padding:1.8rem;
  position:relative;overflow:hidden;
  transition:box-shadow .3s,transform .3s;
}
.svc-card.big{grid-row:span 1}
.svc-card:hover{box-shadow:0 8px 40px rgba(58,168,216,.2),0 0 0 1px rgba(58,168,216,.15);transform:translateY(-5px)}
.svc-card::after{
  content:'';position:absolute;bottom:0;left:0;
  width:100%;height:1px;
  background:linear-gradient(90deg,var(--blue),transparent);
  opacity:0;transition:opacity .3s;
}
.svc-card:hover::after{opacity:1}

.svc-num{
  font-family:var(--font-display);font-size:1.8rem;font-weight:800;
  color:rgba(255,255,255,.07);line-height:1;margin-bottom:1rem;
}
.svc-icon{
  width:44px;height:44px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;margin-bottom:1.2rem;
}
.svc-icon.blue{background:rgba(58,168,216,.15)}
.svc-icon.yellow{background:rgba(245,158,11,.15)}
.svc-icon.teal{background:rgba(13,148,136,.15)}
.svc-icon.purple{background:rgba(124,58,237,.15)}

.svc-card h3{
  font-family:var(--font-display);font-size:1.1rem;font-weight:700;
  color:#fff;margin-bottom:.6rem;line-height:1.3;text-transform:uppercase;
}
.svc-card p{font-size:.875rem;color:var(--ink-2);line-height:1.7;margin-bottom:1.2rem}

.svc-feats{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.5rem}
.svc-feats li{
  font-size:.8rem;color:var(--ink-2);
  padding-left:1.2rem;position:relative;
}
.svc-feats li::before{
  content:'✓';position:absolute;left:0;
  color:var(--blue);font-weight:700;font-size:.7rem;
}

.svc-lnk{
  display:inline-flex;align-items:center;gap:.3rem;
  font-size:.82rem;font-weight:700;color:var(--blue);
  transition:gap .2s;
}
.svc-lnk:hover gap{gap:.55rem}
.svc-lnk span{transition:transform .2s}
.svc-lnk:hover span{transform:translateX(3px)}

/* ═══════════════════════════════════
   STATS
═══════════════════════════════════ */
.stats-strip{background:linear-gradient(135deg,#1A3A6B 0%,#0E2248 100%);padding:4rem 2rem;border-top:1px solid rgba(58,168,216,.2);border-bottom:1px solid rgba(58,168,216,.2)}
.stats-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-around;
  gap:2rem;
}
.stat-item{text-align:center}
.stat-row{display:flex;align-items:flex-end;justify-content:center;gap:.1rem}
.stat-n{
  font-family:var(--font-display);font-size:3rem;font-weight:800;
  color:#fff;line-height:1;
}
.stat-sign{font-family:var(--font-display);font-size:2rem;font-weight:700;color:rgba(147,186,255,.7);line-height:1.3}
.stat-lbl{font-size:.75rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em;margin-top:.5rem;font-weight:500}
.stat-div{width:1px;height:56px;background:rgba(255,255,255,.08)}

/* ═══════════════════════════════════
   PROCESO
═══════════════════════════════════ */
#proceso{padding:6rem 0}

.proceso-grid{
  display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;
  gap:0;align-items:start;
}
.p-card{
  background:#0B0F1C;border:1px solid rgba(255,255,255,.08);
  border-radius:12px;padding:1.8rem 1.6rem;
  transition:box-shadow .3s,transform .3s;
}
.p-card:hover{box-shadow:0 8px 32px rgba(58,168,216,.12);transform:translateY(-3px)}
.p-num{
  font-family:var(--font-display);font-size:.8rem;font-weight:700;
  color:var(--blue);letter-spacing:.08em;margin-bottom:.75rem;
}
.p-ico{font-size:1.6rem;margin-bottom:.9rem}
.p-card h4{
  font-family:var(--font-display);font-size:1.05rem;font-weight:700;
  color:#fff;margin-bottom:.5rem;text-transform:uppercase;
}
.p-card p{font-size:.84rem;color:var(--ink-2);line-height:1.65}
.p-arr{
  font-family:var(--font-display);font-size:1.5rem;
  color:rgba(255,255,255,.15);align-self:center;padding:0 1rem;
  margin-top:2rem;
}

/* ═══════════════════════════════════
   FEATURE SPLIT
═══════════════════════════════════ */
.feat-split{padding:6rem 0;background:#0B0F1C}
.fs-layout{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:center;
}
.fs-txt .sec-h2{margin:.5rem 0 1rem}
.fs-txt p{font-size:.98rem;color:var(--ink-2);line-height:1.75;margin-bottom:1.8rem}

.fs-list{list-style:none;display:flex;flex-direction:column;gap:.65rem;margin-bottom:2rem}
.fs-list li{display:flex;align-items:flex-start;gap:.75rem;font-size:.9rem;color:var(--ink-2)}
.ck{
  width:20px;height:20px;background:var(--blue-lt);color:var(--blue);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:700;flex-shrink:0;margin-top:.1rem;
}

/* Chat demo */
.chat-demo{
  background:#0B0F1C;border:1px solid rgba(255,255,255,.1);
  border-radius:14px;overflow:hidden;box-shadow:var(--shadow-md);
}
.cd-hdr{
  background:#060A12;border-bottom:1px solid rgba(255,255,255,.07);
  padding:.9rem 1.2rem;display:flex;align-items:center;gap:.9rem;
}
.cd-av{
  width:36px;height:36px;background:var(--blue);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
}
.cd-name{font-size:.9rem;font-weight:600;color:#fff}
.cd-status{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--ink-3)}
.cd-status .live-dot{background:#059669;color:#059669}

.cd-body{padding:1.2rem;display:flex;flex-direction:column;gap:.75rem;min-height:180px;background:#0B0F1C}
.msg{display:flex;max-width:85%}
.msg.bot{align-self:flex-start}
.msg.usr{align-self:flex-end}
.msg span{
  display:inline-block;
  padding:.6rem .9rem;border-radius:10px;
  font-size:.82rem;line-height:1.55;
}
.msg.bot span{background:rgba(255,255,255,.07);color:#fff;border-radius:2px 10px 10px 10px}
.msg.usr span{background:var(--blue);color:#fff;border-radius:10px 2px 10px 10px}

.typing{
  display:flex;align-items:center;gap:.3rem;padding:.6rem .9rem;
  background:rgba(255,255,255,.07);border-radius:2px 10px 10px 10px;
  width:fit-content;
}
.typing span{
  width:6px;height:6px;background:var(--ink-3);border-radius:50%;
  animation:dot 1.4s infinite both;
}
.typing span:nth-child(2){animation-delay:.2s}
.typing span:nth-child(3){animation-delay:.4s}
@keyframes dot{0%,80%,100%{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}

.cd-ftr{
  border-top:1px solid rgba(255,255,255,.07);padding:.75rem 1.2rem;
  display:flex;align-items:center;justify-content:space-between;
  background:#060A12;
}
.cd-input{font-size:.82rem;color:var(--ink-3)}
.cd-send{
  width:28px;height:28px;background:var(--blue);color:#fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.8rem;cursor:pointer;
}

/* ═══════════════════════════════════
   CURSOS
═══════════════════════════════════ */
#cursos{padding:6rem 0}
.cursos-layout{display:grid;grid-template-columns:1.1fr 1fr;gap:5rem;align-items:start}
.c-left .sec-h2{margin:.5rem 0 .8rem}

.curso-list{display:flex;flex-direction:column;margin-top:1.8rem}
.ci{
  display:flex;align-items:center;gap:1.2rem;
  padding:1rem 0;border-bottom:1px solid rgba(255,255,255,.07);
  cursor:pointer;transition:background .2s;
}
.ci:first-child{border-top:1px solid rgba(255,255,255,.07)}
.ci:hover .ci-t{color:var(--blue)}
.ci:hover .ci-arr{transform:translateX(4px);color:var(--blue)}
.ci-n{
  font-family:var(--font-display);font-size:1.2rem;font-weight:700;
  color:rgba(255,255,255,.1);min-width:2.5rem;
}
.ci-info{flex:1}
.ci-t{font-family:var(--font-display);font-size:1rem;font-weight:700;color:#fff;transition:color .2s;text-transform:uppercase;}
.ci-m{font-size:.75rem;color:var(--ink-3);margin-top:.15rem}
.ci-arr{font-size:.9rem;color:var(--ink-3);transition:all .25s}

.cert-card{
  background:#0B0F1C;border:1px solid rgba(255,255,255,.08);
  border-top:3px solid var(--blue);
  border-radius:14px;padding:2.2rem;box-shadow:var(--shadow);
  position:sticky;top:calc(var(--nav-h) + 2rem);
}
.cc-top{text-align:center;margin-bottom:1.5rem}
.cc-icon{font-size:2.5rem;margin-bottom:.75rem}
.cc-title{font-family:var(--font-display);font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:.5rem;text-transform:uppercase}
.cc-sub{font-size:.85rem;color:var(--ink-2);line-height:1.65}
.cc-div{height:1px;background:rgba(255,255,255,.08);margin:1.5rem 0}
.cc-feats{display:flex;flex-direction:column;gap:.65rem}
.ccf{display:flex;align-items:flex-start;gap:.75rem;font-size:.88rem;color:var(--ink-2)}
.ccf span{color:var(--blue);font-weight:700;flex-shrink:0}

/* ═══════════════════════════════════
   CASOS
═══════════════════════════════════ */
#casos{padding:6rem 0}
.casos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.caso{
  background:#0B0F1C;border:1px solid rgba(255,255,255,.08);
  border-top:3px solid var(--blue);
  border-radius:12px;padding:1.8rem;
  transition:box-shadow .3s,transform .3s;
}
.caso:hover{box-shadow:0 8px 32px rgba(58,168,216,.15);transform:translateY(-4px)}
.caso-tag{
  display:inline-block;background:rgba(58,168,216,.12);color:var(--blue);
  font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:.25rem .65rem;border-radius:100px;margin-bottom:1rem;
}
.caso-stat{
  font-family:var(--font-display);font-size:2.6rem;font-weight:800;
  color:#fff;line-height:1;margin-bottom:.4rem;
}
.caso-title{font-size:.78rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.65rem}
.caso p{font-size:.84rem;color:var(--ink-2);line-height:1.6}

/* ═══════════════════════════════════
   TESTIMONIOS
═══════════════════════════════════ */
#testimonios{padding:6rem 0}
.testi-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.5rem}
.testi{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:2rem;display:flex;flex-direction:column;gap:1.2rem;
}
.testi-hi{
  background:rgba(58,168,216,.08);
  border-color:rgba(58,168,216,.25);
  position:relative;
}
.testi-hi::before{
  content:'';position:absolute;top:0;left:0;right:0;
  height:2px;background:var(--blue);border-radius:12px 12px 0 0;
}
.testi-stars{color:#F59E0B;font-size:.9rem;letter-spacing:.05em}
.testi p{font-size:.9rem;color:rgba(255,255,255,.7);line-height:1.7;flex:1}
.testi-who{display:flex;align-items:center;gap:.85rem}
.tav{
  width:40px;height:40px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:.75rem;font-weight:700;flex-shrink:0;
}
.tav.teal{background:var(--teal)}
.tav.purple{background:var(--purple)}
.t-name{font-size:.88rem;font-weight:600;color:#fff}
.t-role{font-size:.75rem;color:rgba(255,255,255,.45);margin-top:.1rem}

/* ═══════════════════════════════════
   FAQ
═══════════════════════════════════ */
#faq{padding:6rem 0}
.faq-layout{
  display:grid;grid-template-columns:1fr 2fr;gap:6rem;align-items:start;
}
.faq-left .sec-h2{margin:.5rem 0 .8rem}
.faq-right{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid rgba(255,255,255,.07)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:1.2rem 0;cursor:pointer;font-size:.93rem;font-weight:600;
  color:#fff;transition:color .2s;gap:1rem;
}
.faq-q:hover{color:var(--blue)}
.faq-ico{
  width:24px;height:24px;border:1.5px solid rgba(255,255,255,.15);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.7rem;color:var(--ink-3);flex-shrink:0;
  transition:all .25s;font-style:normal;
}
.faq-item.open .faq-ico{
  background:var(--blue);border-color:var(--blue);color:#fff;transform:rotate(45deg);
}
.faq-a{
  max-height:0;overflow:hidden;font-size:.88rem;color:var(--ink-2);line-height:1.7;
  transition:max-height .4s ease,padding .3s ease;
}
.faq-item.open .faq-a{max-height:200px;padding-bottom:1.2rem}

/* ═══════════════════════════════════
   CTA BANNER
═══════════════════════════════════ */
.cta-banner{
  background:var(--dark);padding:7rem 2rem;
  position:relative;overflow:hidden;text-align:center;
}
.cta-blob{
  position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;
}
.cta-blob.c1{
  width:500px;height:500px;
  background:radial-gradient(circle,rgba(26,58,107,.5),transparent 70%);
  top:-150px;left:-100px;
}
.cta-blob.c2{
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(58,168,216,.1),transparent 70%);
  bottom:-100px;right:-50px;
}
.cta-content{position:relative;z-index:1;max-width:640px;margin:0 auto}
.cta-content h2{
  font-family:var(--font-display);
  font-size:clamp(1.9rem,4vw,3rem);
  font-weight:800;color:#fff;line-height:1.18;
  letter-spacing:-.02em;margin:.75rem 0 1rem;
}
.cta-content h2 em{font-style:normal;color:var(--blue)}
.cta-content p{font-size:1rem;color:rgba(255,255,255,.55);margin-bottom:2.5rem}
.cta-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ═══════════════════════════════════
   CONTACTO
═══════════════════════════════════ */
#contacto{padding:6rem 0}
.contacto-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:5rem;align-items:start}
.co-left .sec-h2{margin:.5rem 0 .8rem}

.co-details{display:flex;flex-direction:column;gap:1.3rem;margin-top:2rem}
.co-item{display:flex;align-items:flex-start;gap:1rem}
.co-ico{font-size:1.1rem;margin-top:.1rem;flex-shrink:0}
.co-k{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:.2rem}
.co-item a,.co-item span{font-size:.9rem;color:var(--ink-2);transition:color .2s}
.co-item a:hover{color:var(--blue)}

/* Contact form */
.co-right{
  background:#0B0F1C;border:1px solid rgba(255,255,255,.08);
  border-top:3px solid var(--blue);
  border-radius:14px;padding:2.4rem;box-shadow:var(--shadow);
}
.cf{display:flex;flex-direction:column;gap:1.1rem}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-size:.75rem;font-weight:600;color:var(--ink-2);letter-spacing:.04em}
.fg input,.fg select,.fg textarea{
  background:rgba(255,255,255,.05);border:1.5px solid rgba(255,255,255,.1);border-radius:7px;
  padding:.75rem 1rem;font-family:var(--font-body);font-size:.9rem;color:#fff;
  outline:none;transition:border-color .2s,background .2s;width:100%;
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--blue);background:rgba(255,255,255,.07);
}
.fg input::placeholder,.fg textarea::placeholder{color:var(--ink-3)}
.fg textarea{resize:vertical;min-height:110px}
.fg select{cursor:pointer;color:#fff}
.fg select option{background:#0B0F1C;color:#fff}

.chk-lbl{display:flex;align-items:flex-start;gap:.7rem;cursor:pointer;font-size:.83rem;color:var(--ink-2);line-height:1.5}
.chk-lbl input[type="checkbox"]{display:none}
.chkbox{
  width:17px;height:17px;border:1.5px solid var(--border);border-radius:3px;
  flex-shrink:0;margin-top:2px;transition:all .2s;position:relative;
}
.chk-lbl input:checked + .chkbox{background:var(--blue);border-color:var(--blue)}
.chk-lbl input:checked + .chkbox::after{
  content:'✓';position:absolute;top:-2px;left:1px;
  font-size:.65rem;color:#fff;
}

.form-msg{display:none;font-size:.85rem;padding:.7rem 1rem;border-radius:6px;text-align:center;margin-top:.25rem}
.form-msg.ok{background:rgba(5,150,105,.1);color:#059669;border:1px solid rgba(5,150,105,.2)}
.form-msg.err{background:rgba(220,53,69,.1);color:#DC3545;border:1px solid rgba(220,53,69,.2)}

/* ═══════════════════════════════════
   FOOTER
═══════════════════════════════════ */
footer{background:#050A14;padding:4rem 2rem 2rem;border-top:1px solid rgba(58,168,216,.2)}
.ft-inner{max-width:var(--max);margin:0 auto}
.ft-top{
  display:flex;justify-content:space-between;align-items:flex-start;
  gap:3rem;padding-bottom:3rem;
  border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:1.5rem;
}
.ft-logo{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:#fff;margin-bottom:.4rem}
.ft-logo span{color:var(--blue)}
.ft-tag{font-size:.8rem;color:rgba(255,255,255,.3);margin-bottom:1.2rem}
.ft-socials{display:flex;gap:.6rem}
.ft-socials a{
  width:34px;height:34px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.45);transition:all .2s;
}
.ft-socials a:hover{background:var(--blue);border-color:var(--blue);color:#fff;transform:translateY(-2px)}
.ft-socials svg{width:15px;height:15px}

.ft-links{display:flex;gap:4rem}
.ftl-col{display:flex;flex-direction:column;gap:.75rem}
.ftl-h{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:.25rem}
.ftl-col a{font-size:.84rem;color:rgba(255,255,255,.5);transition:color .2s;cursor:pointer}
.ftl-col a:hover{color:#fff}

.ft-bottom{display:flex;justify-content:space-between;align-items:center}
.ft-copy{font-size:.78rem;color:rgba(255,255,255,.35);letter-spacing:.04em}
.ft-legal{display:flex;gap:1.5rem}
.ft-legal a{font-size:.78rem;color:rgba(255,255,255,.22);transition:color .2s}
.ft-legal a:hover{color:rgba(255,255,255,.55)}

/* ═══════════════════════════════════
   RESPONSIVE
═══════════════════════════════════ */
@media(max-width:1100px){
  .svc-grid{grid-template-columns:1fr 1fr}
  .proceso-grid{grid-template-columns:1fr 1fr;gap:1.25rem}
  .p-arr{display:none}
  .fs-layout{grid-template-columns:1fr;gap:3rem}
  .cursos-layout{grid-template-columns:1fr;gap:3rem}
  .c-right{position:static}
  .casos-grid{grid-template-columns:1fr 1fr}
  .testi-grid{grid-template-columns:1fr 1fr}
  .contacto-layout{grid-template-columns:1fr;gap:3rem}
  .ft-links{gap:2.5rem}
}

@media(max-width:768px){
  :root{--nav-h:60px}
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .nav-inner{padding:0 1.5rem}

  #hero{padding:calc(var(--nav-h) + 3rem) 1.5rem 3rem;min-height:auto}
  #hero h1{font-size:clamp(2.2rem,8vw,3.2rem)}
  .hero-sub{font-size:1rem}
  .hero-ctas{flex-direction:column;align-items:center}
  .hero-mockup .mockup-sidebar{display:none}
  .mockup-body{height:220px}

  .svc-grid{grid-template-columns:1fr}
  .proceso-grid{grid-template-columns:1fr}
  .faq-layout{grid-template-columns:1fr;gap:2.5rem}
  .stats-inner{flex-wrap:wrap;gap:2rem;justify-content:center}
  .stat-div{display:none}
  .testi-grid{grid-template-columns:1fr}
  .casos-grid{grid-template-columns:1fr}
  .cf-row{grid-template-columns:1fr}
  .ft-top{flex-direction:column;gap:2rem}
  .ft-links{flex-wrap:wrap;gap:2rem}
  .ft-bottom{flex-direction:column;gap:.75rem;text-align:center}
  .trust-inner{flex-direction:column;gap:.75rem;text-align:center}
  .trust-logos{justify-content:center}
  .inner{padding:0 1.5rem}
  section{padding:4rem 0!important}
  .stats-strip{padding:3rem 1.5rem}
  .cta-banner{padding:5rem 1.5rem}
  footer{padding:3rem 1.5rem 1.5rem}
}

@media(max-width:480px){
  #hero h1{font-size:2.2rem}
  .hero-proof{flex-direction:column;border-radius:12px;text-align:center;padding:.8rem 1rem}
  .cta-btns{flex-direction:column;align-items:center}
}

/* ═══════════════════════════════════
   WHATSAPP WIDGET
═══════════════════════════════════ */
.wsp-widget {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}

/* Botón flotante */
.wsp-btn {
  width: 58px;
  height: 58px;
  background: #25D366;
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(37,211,102,.45), 0 2px 8px rgba(0,0,0,.15);
  transition: transform .25s, box-shadow .25s;
  position: relative;
  flex-shrink: 0;
}
.wsp-btn:hover {
  transform: scale(1.08);
  box-shadow: 0 8px 28px rgba(37,211,102,.55), 0 4px 12px rgba(0,0,0,.15);
}
.ico-wsp { width: 30px; height: 30px; color: #fff; transition: opacity .2s, transform .2s; }
.ico-close { width: 22px; height: 22px; color: #fff; position: absolute; opacity: 0; transition: opacity .2s, transform .2s; transform: rotate(-90deg); }
.wsp-btn.open .ico-wsp { opacity: 0; transform: rotate(90deg); }
.wsp-btn.open .ico-close { opacity: 1; transform: rotate(0deg); }

/* Notificación */
.wsp-notif {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 20px;
  height: 20px;
  background: #FF3B30;
  color: #fff;
  border-radius: 50%;
  font-size: .65rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #fff;
  animation: bounce-in .4s cubic-bezier(.36,.07,.19,.97) 2s both;
}
.wsp-notif.hidden { display: none; }
@keyframes bounce-in {
  0%   { transform: scale(0); }
  60%  { transform: scale(1.2); }
  100% { transform: scale(1); }
}

/* Burbuja */
.wsp-bubble {
  background: #fff;
  border-radius: 14px;
  width: 300px;
  box-shadow: 0 8px 32px rgba(12,24,41,.14), 0 2px 8px rgba(12,24,41,.08);
  overflow: hidden;
  transform-origin: bottom right;
  transform: scale(.85) translateY(12px);
  opacity: 0;
  pointer-events: none;
  transition: transform .3s cubic-bezier(.22,.61,.36,1), opacity .3s ease;
}
.wsp-bubble.show {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}

.wsp-bubble-close {
  position: absolute;
  top: 10px;
  right: 12px;
  font-size: .75rem;
  color: rgba(255,255,255,.7);
  cursor: pointer;
  transition: color .2s;
  z-index: 1;
}
.wsp-bubble-close:hover { color: #fff; }

/* Header burbuja */
.wsp-bubble-hdr {
  background: #075E54;
  padding: 1rem 1.2rem;
  display: flex;
  align-items: center;
  gap: .85rem;
}
.wsp-av {
  width: 42px;
  height: 42px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.wsp-av svg { width: 24px; height: 24px; color: #fff; }
.wsp-name { font-size: .92rem; font-weight: 700; color: #fff; }
.wsp-online { display: flex; align-items: center; gap: .35rem; font-size: .72rem; color: rgba(255,255,255,.7); margin-top: .15rem; }
.wsp-dot { width: 7px; height: 7px; background: #25D366; border-radius: 50%; animation: blink 2s infinite; }

/* Body burbuja */
.wsp-bubble-body {
  background: #ECE5DD;
  padding: 1rem 1.2rem;
}
.wsp-msg-wrap { display: flex; flex-direction: column; gap: .25rem; align-items: flex-start; }
.wsp-msg {
  background: #fff;
  border-radius: 0 10px 10px 10px;
  padding: .65rem .9rem;
  font-size: .85rem;
  color: #111;
  line-height: 1.55;
  box-shadow: 0 1px 2px rgba(0,0,0,.1);
  max-width: 90%;
}
.wsp-msg-time { font-size: .65rem; color: rgba(0,0,0,.45); margin-left: .25rem; }

/* CTA burbuja */
.wsp-bubble-cta {
  display: block;
  background: #25D366;
  color: #fff;
  text-align: center;
  padding: .85rem 1rem;
  font-size: .88rem;
  font-weight: 700;
  transition: background .2s;
}
.wsp-bubble-cta:hover { background: #1EBE5D; }

@media(max-width: 480px) {
  .wsp-widget { bottom: 18px; right: 18px; }
  .wsp-bubble { width: calc(100vw - 40px); }
}
/* ═══════════════════════════════════
   PLANES
═══════════════════════════════════ */
#planes { padding: 6rem 0; }

.planes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  align-items: stretch;
  margin-bottom: 3rem;
}

.plan-card {
  border-radius: 16px;
  padding: 2rem 1.6rem 1.8rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  transition: transform .3s, box-shadow .3s;
}
.plan-card:hover { transform: translateY(-6px); }

.plan-bronze { background: linear-gradient(160deg, #1e4d38, #122e22); box-shadow: 0 8px 32px rgba(30,77,56,.4); }
.plan-silver { background: linear-gradient(160deg, #1a3a6b, #0e2248); box-shadow: 0 8px 32px rgba(26,58,107,.4); transform: scale(1.04); }
.plan-silver:hover { transform: scale(1.04) translateY(-6px); }
.plan-gold   { background: linear-gradient(160deg, #7a5800, #4a3500); box-shadow: 0 8px 32px rgba(122,88,0,.4); }

/* "Más elegido" badge */
.plan-mas-elegido {
  position: absolute;
  top: 14px; right: 14px;
  background: #3b9dd4;
  color: #fff;
  font-size: .6rem; font-weight: 800; letter-spacing: .12em;
  padding: .28rem .8rem; border-radius: 100px;
}

/* Medal circle */
.plan-medal {
  width: 64px; height: 64px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display);
  font-size: 2rem; font-weight: 800; color: #fff;
  line-height: 1;
  margin-bottom: 1rem;
  text-shadow: 0 2px 4px rgba(0,0,0,.3);
}
.plan-medal.bronze { background: radial-gradient(circle at 38% 35%, #e8a060, #8b4513); box-shadow: 0 4px 16px rgba(139,69,19,.5), inset 0 2px 0 rgba(255,255,255,.25); }
.plan-medal.silver { background: radial-gradient(circle at 38% 35%, #ebebeb, #888); box-shadow: 0 4px 16px rgba(100,100,100,.5), inset 0 2px 0 rgba(255,255,255,.35); }
.plan-medal.gold   { background: radial-gradient(circle at 38% 35%, #ffe566, #c8860a); box-shadow: 0 4px 16px rgba(200,134,10,.55), inset 0 2px 0 rgba(255,255,255,.3); }

/* Plan title */
.plan-titulo {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 800;
  text-align: center; text-transform: uppercase;
  letter-spacing: .05em; line-height: 1.25;
  color: #fff; margin-bottom: 1rem;
}

/* Price box — franja de color */
.plan-precio-caja {
  width: calc(100% + 3.2rem);
  padding: .65rem 0;
  text-align: center;
  font-family: var(--font-display);
  font-size: 2.4rem; font-weight: 800; color: #fff;
  margin-bottom: 1.4rem;
}
.bronze-caja { background: rgba(0,0,0,.25); }
.silver-caja { background: rgba(255,255,255,.08); }
.gold-caja   { background: rgba(0,0,0,.3); }

/* Feature list */
.plan-lista {
  list-style: none;
  width: 100%;
  display: flex; flex-direction: column; gap: .65rem;
  margin-bottom: 1.8rem;
  flex: 1;
}
.plan-lista li {
  display: flex; align-items: flex-start; gap: .55rem;
  font-size: .87rem; color: rgba(255,255,255,.9); line-height: 1.5;
}
.pck { color: #4ade80; font-weight: 800; font-size: .85rem; flex-shrink: 0; margin-top: .05rem; }

/* WhatsApp button */
.plan-wsp-btn {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  width: 100%;
  padding: .8rem 1rem;
  border-radius: 8px;
  background: #25D366; color: #fff;
  font-family: var(--font-body); font-size: .92rem; font-weight: 700;
  box-shadow: 0 4px 14px rgba(37,211,102,.4);
  transition: all .22s;
  margin-top: auto;
}
.plan-wsp-btn:hover { background: #1EBE5D; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(37,211,102,.5); }

/* Footer */
.planes-footer { text-align: center; padding: 1.5rem 0; }
.planes-footer p { font-size: 1rem; color: var(--ink-2); margin-bottom: 1.2rem; }
.planes-footer p strong { color: var(--ink); }

.planes-wsp-cta {
  display: inline-flex; align-items: center; gap: .6rem;
  background: #25D366; color: #fff;
  padding: 1rem 2.5rem; border-radius: 100px;
  font-family: var(--font-body); font-size: 1.05rem; font-weight: 700;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  transition: all .25s;
}
.planes-wsp-cta:hover { background: #1EBE5D; transform: translateY(-2px); box-shadow: 0 8px 28px rgba(37,211,102,.5); }

@media(max-width: 900px) {
  .planes-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
  .plan-silver { transform: scale(1); }
  .plan-silver:hover { transform: translateY(-6px); }
  .plan-precio-caja { width: calc(100% + 3.2rem); }
}
/* ═══════════════════════════════════
   PLAN CARDS — aliases para clases HTML
   (plan-name, plan-price, plan-feats, plan-cta, plan-badge-top, plan-featured)
═══════════════════════════════════ */

/* Plan card base sin clase de color → fondo bronce (Plan 3) */
.plan-card:not(.plan-featured):not(.plan-gold) {
  background: linear-gradient(160deg, #1e4d38, #122e22);
  box-shadow: 0 8px 32px rgba(30,77,56,.4);
}

/* Plan destacado (Plan 2) */
.plan-featured {
  background: linear-gradient(160deg, #1a3a6b, #0e2248);
  box-shadow: 0 8px 32px rgba(26,58,107,.4);
  transform: scale(1.04);
}
.plan-featured:hover { transform: scale(1.04) translateY(-6px); }

/* Plan gold (Plan 1) */
.plan-gold {
  background: linear-gradient(160deg, #7a5800, #4a3500);
  box-shadow: 0 8px 32px rgba(122,88,0,.4);
}

/* Badge "Más elegido" */
.plan-badge-top {
  position: absolute;
  top: 14px; right: 14px;
  background: #3b9dd4;
  color: #fff;
  font-size: .6rem; font-weight: 800; letter-spacing: .12em;
  text-transform: uppercase;
  padding: .28rem .8rem; border-radius: 100px;
}

/* Nombre del plan */
.plan-name {
  font-family: var(--font-display);
  font-size: 1.2rem; font-weight: 800;
  text-align: center; text-transform: uppercase;
  letter-spacing: .05em; line-height: 1.25;
  color: #fff; margin-bottom: 1rem;
}

/* Precio */
.plan-price {
  font-family: var(--font-display);
  font-size: 2.4rem; font-weight: 800; color: #fff;
  text-align: center;
  background: rgba(0,0,0,.25);
  width: calc(100% + 3.2rem);
  padding: .65rem 0;
  margin-bottom: 1.4rem;
}

/* Lista de features */
.plan-feats {
  list-style: none;
  width: 100%;
  display: flex; flex-direction: column; gap: .65rem;
  margin-bottom: 1.8rem;
  flex: 1;
}
.plan-feats li {
  display: flex; align-items: flex-start; gap: .55rem;
  font-size: .87rem; color: rgba(255,255,255,.9); line-height: 1.5;
  padding-left: 1.3rem; position: relative;
}
.plan-feats li::before {
  content: '✓'; position: absolute; left: 0;
  color: #4ade80; font-weight: 800; font-size: .85rem;
}

/* Botón CTA de plan */
.plan-cta,
.plan-cta-featured,
.plan-cta-gold {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  width: 100%;
  padding: .8rem 1rem;
  border-radius: 8px;
  background: #25D366; color: #fff;
  font-family: var(--font-body); font-size: .92rem; font-weight: 700;
  box-shadow: 0 4px 14px rgba(37,211,102,.4);
  transition: all .22s;
  margin-top: auto;
  text-align: center;
}
.plan-cta svg,
.plan-cta-featured svg,
.plan-cta-gold svg { width: 18px; height: 18px; flex-shrink: 0; }
.plan-cta:hover,
.plan-cta-featured:hover,
.plan-cta-gold:hover { background: #1EBE5D; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(37,211,102,.5); }

/* Fix planes-footer WhatsApp button */
.planes-wsp-btn {
  display: inline-flex; align-items: center; gap: .6rem;
  background: #25D366; color: #fff;
  padding: 1rem 2.5rem; border-radius: 100px;
  font-family: var(--font-body); font-size: 1.05rem; font-weight: 700;
  box-shadow: 0 4px 20px rgba(37,211,102,.4);
  transition: all .25s;
}
.planes-wsp-btn svg { width: 22px; height: 22px; }
.planes-wsp-btn:hover { background: #1EBE5D; transform: translateY(-2px); }

@media(max-width: 900px) {
  .plan-featured { transform: scale(1); }
  .plan-featured:hover { transform: translateY(-6px); }
}
