/* ============================================================
   HOLOACADEMIA · SISTEMA DE DISEÑO (fuente única)
   Tomado de la HOME nueva de .tv (index.html) — tema OSCURO.
   Toda página nueva enlaza este archivo:
     <link rel="stylesheet" href="/assets/theme.css">
   + fuente Plus Jakarta Sans + header/footer (partials) + favicon.
   NO definir colores/fonts/estilos fuera de aquí.
   ============================================================ */

:root{
  --bg:#0a0a12; --bg2:#0b0f1c;
  --panel:rgba(255,255,255,.03); --panel-bd:rgba(255,255,255,.08); --line:rgba(255,255,255,.10);
  --teal:#5eead4; --teal2:#16b8b0; --pur:#7c3aed; --pur2:#a78bfa; --pur-d:#6d28d9; --mag:#db2777;
  --ink:#fff; --text:#cdd2e6; --mut:#9aa0bd;
  --bar:#0b0f1c;
  --radius:22px; --radius-sm:14px; --maxw:1100px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Plus Jakarta Sans',system-ui,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ---- contenedores y tipografía ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.eyebrow{display:inline-block;font-size:12px;font-weight:800;letter-spacing:2.6px;text-transform:uppercase;color:var(--teal);border:1px solid rgba(94,234,212,.3);background:rgba(94,234,212,.06);padding:7px 16px;border-radius:999px;margin-bottom:22px}
.h1{font-size:clamp(30px,5.2vw,56px);line-height:1.05;font-weight:800;letter-spacing:-1.6px;color:#fff;margin:0}
.h2{font-size:clamp(28px,4.4vw,46px);line-height:1.06;font-weight:800;letter-spacing:-1.3px;color:#fff;margin:0}
.grad{background:linear-gradient(100deg,#5eead4,#a78bfa);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---- secciones ---- */
.sec{position:relative;padding:clamp(60px,9vw,110px) 0;overflow:hidden}
.sec.alt{background:#0c0c16}
.sec-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(640px 380px at 50% 6%,rgba(124,58,237,.16),transparent 70%),radial-gradient(560px 360px at 88% 96%,rgba(22,184,176,.10),transparent 70%)}
.sec-head{position:relative;text-align:center;max-width:740px;margin:0 auto 44px}
.sec-head p{color:var(--mut);font-size:clamp(15px,2.2vw,18px);line-height:1.55;margin:16px auto 0}

/* ---- hero (oscuro con glow, como las secciones de la home) ---- */
.hero{position:relative;overflow:hidden;background:#0a0a12;text-align:center;padding:clamp(72px,11vw,130px) 0 clamp(60px,8vw,96px);border-bottom:1px solid var(--panel-bd)}
.hero-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(640px 380px at 50% 12%,rgba(124,58,237,.24),transparent 70%),radial-gradient(560px 360px at 85% 95%,rgba(22,184,176,.14),transparent 70%)}
.hero .wrap{position:relative}
.hero h1{font-size:clamp(32px,5.4vw,58px);line-height:1.04;font-weight:800;letter-spacing:-1.8px;color:#fff;margin:0 0 16px}
.hero p{max-width:620px;margin:0 auto 30px;font-size:clamp(15px,2.2vw,18px);line-height:1.55;color:var(--mut)}

/* ---- buscador (oscuro) ---- */
.search{display:flex;max-width:560px;margin:0 auto;background:rgba(255,255,255,.05);border:1px solid var(--panel-bd);border-radius:999px;padding:6px 6px 6px 20px}
.search input{flex:1;border:0;outline:0;font:inherit;font-size:15px;color:#fff;background:transparent}
.search input::placeholder{color:#7d83a0}
.search button{background:linear-gradient(135deg,#16b8b0,#7c3aed);color:#fff;border:0;font:inherit;font-weight:800;font-size:14px;padding:12px 24px;border-radius:999px;cursor:pointer;transition:.18s}
.search button:hover{filter:brightness(1.08)}

/* ---- grid + tarjetas ---- */
.grid{position:relative;display:grid;grid-template-columns:repeat(auto-fit,minmax(322px,1fr));gap:22px}
.grid.wide{grid-template-columns:repeat(auto-fit,minmax(440px,1fr))}
.card{background:var(--panel);border:1px solid var(--panel-bd);border-radius:var(--radius);padding:clamp(26px,3.2vw,36px);transition:.22s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);border-color:rgba(167,139,250,.4);background:rgba(255,255,255,.05)}
.card h3{font-size:clamp(19px,2.4vw,23px);font-weight:800;color:#fff;margin:0 0 10px;letter-spacing:-.4px}
.card .lead{color:var(--text);font-size:14.5px;line-height:1.6;margin:0 0 16px}

/* ícono en cuadro (acento morado) */
.ic{width:50px;height:50px;border-radius:var(--radius-sm);display:grid;place-items:center;background:rgba(124,58,237,.16);border:1px solid rgba(167,139,250,.28);color:var(--pur2);margin-bottom:18px}
.ic svg{width:23px;height:23px}

/* etiqueta píldora (teal, como .wh-tag de la home) */
.tag{display:inline-block;font-size:11px;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;color:var(--teal);background:rgba(94,234,212,.08);border:1px solid rgba(94,234,212,.25);padding:6px 12px;border-radius:999px;margin:0 0 14px}

/* listas con check morado */
.list{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:11px}
.list li{position:relative;padding-left:26px;font-size:14.5px;line-height:1.5;color:var(--text)}
.list li:before{content:'';position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;background:var(--pur) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/10px no-repeat}

.meta{border-top:1px solid var(--line);padding-top:15px;margin-top:auto;display:flex;flex-direction:column;gap:5px;font-size:13.5px;color:var(--mut)}
.meta b{color:#fff}

/* ---- botones ---- */
.btn-pur{display:inline-flex;align-items:center;gap:8px;margin-top:4px;background:linear-gradient(135deg,#16b8b0,#7c3aed);color:#fff;font-weight:800;font-size:14.5px;padding:13px 24px;border-radius:999px;transition:.18s;align-self:flex-start;box-shadow:0 14px 34px rgba(124,58,237,.32)}
.btn-pur:hover{transform:translateY(-2px);filter:brightness(1.08)}
.wa{display:inline-flex;align-items:center;gap:9px;margin-top:16px;background:#25d366;color:#fff;font-weight:800;font-size:13.5px;padding:11px 18px;border-radius:999px;transition:.18s;align-self:flex-start}
.wa:hover{filter:brightness(.95)}
.wa svg{width:16px;height:16px}
.wa.center{align-self:auto;margin:0 auto}

/* ---- pasos numerados ---- */
.steps{counter-reset:s;display:flex;flex-direction:column;gap:16px;margin:6px 0 0}
.step{position:relative;padding-left:52px}
.step:before{counter-increment:s;content:counter(s);position:absolute;left:0;top:-1px;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#16b8b0,#7c3aed);color:#fff;font-weight:800;display:grid;place-items:center;font-size:14px}
.step h4{margin:3px 0 5px;font-size:15.5px;font-weight:800;color:#fff}
.step p{margin:0;color:var(--mut);font-size:14px;line-height:1.55}
.docs{list-style:none;padding:0;margin:9px 0 0;display:flex;flex-wrap:wrap;gap:8px}
.docs li{background:rgba(124,58,237,.12);border:1px solid rgba(167,139,250,.25);border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:700;color:#cdbcf7}

/* ---- chips de redes ---- */
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:2px}
.chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.04);border:1px solid var(--panel-bd);border-radius:11px;padding:10px 15px;font-size:13px;font-weight:700;color:var(--text);transition:.18s}
.chip:hover{border-color:rgba(167,139,250,.45);color:#fff;transform:translateY(-1px)}
.chip svg{width:16px;height:16px}

/* ---- banda de acento (degradado morado, como Planes de la home) ---- */
.band-sec{padding:clamp(50px,7vw,90px) 0}
.band{position:relative;overflow:hidden;background:linear-gradient(180deg,#13111f 0%,#0c0c16 100%);border:1px solid var(--panel-bd);color:#fff;border-radius:26px;padding:clamp(36px,5vw,52px) clamp(26px,4vw,44px);text-align:center}
.band-glow{position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 55% at 18% 6%,rgba(124,58,237,.30),transparent 62%),radial-gradient(55% 50% at 92% 30%,rgba(22,184,176,.18),transparent 62%)}
.band>*{position:relative}
.band .ic{background:rgba(124,58,237,.18);border-color:rgba(167,139,250,.30);color:var(--pur2);margin:0 auto 18px}
.band h2{color:#fff;margin:0 0 10px}
.band p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 22px;font-size:15.5px;line-height:1.55}
.cband{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px;font-size:14.5px;color:rgba(255,255,255,.92);margin-bottom:22px}
.cband b{color:#fff}
.remember{max-width:640px;margin:28px auto 0;text-align:left;display:flex;flex-direction:column;gap:10px;padding:0}
.remember li{list-style:none;position:relative;padding-left:28px;font-size:13.5px;color:rgba(255,255,255,.82);line-height:1.5}
.remember li:before{content:'';position:absolute;left:0;top:1px;width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M12 8v5'/%3E%3Cpath d='M12 16.5v.5'/%3E%3C/svg%3E") center/14px no-repeat}
.thanks{margin:26px auto 0;font-size:13.5px;color:rgba(255,255,255,.65)}

/* ---- documento legal (Términos, Privacidad) ---- */
.legal{position:relative;max-width:860px;margin:0 auto;padding:clamp(44px,6vw,80px) 0}
.legal-intro{color:var(--mut);font-size:15px;line-height:1.75;margin:0 0 10px}
.legal h2{color:#fff;font-size:clamp(18px,2.3vw,23px);font-weight:800;letter-spacing:-.4px;margin:40px 0 12px}
.legal h2:first-child{margin-top:0}
.legal h3{color:#fff;font-size:16px;font-weight:800;margin:26px 0 10px}
.legal p{color:var(--text);font-size:15px;line-height:1.78;margin:0 0 14px}
.legal b{color:#fff}
.legal a{color:var(--pur2);font-weight:600}
.legal ul{margin:0 0 16px;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px}
.legal ul li{position:relative;padding-left:24px;color:var(--text);font-size:15px;line-height:1.65}
.legal ul li:before{content:'';position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
.legal .upd{color:var(--mut);font-size:13px;margin-top:4px}
.legal .data-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin:6px 0 16px}
.legal .data-grid span{background:rgba(124,58,237,.12);border:1px solid rgba(167,139,250,.25);border-radius:10px;padding:10px 14px;font-size:13.5px;font-weight:700;color:#cdbcf7;text-align:center}

/* ---- iframes de encabezado/pie estándar ---- */
.site-hd{display:block;width:100%;height:96px;border:0;position:sticky;top:0;z-index:60;background:var(--bar)}
.site-ft{display:block;width:100%;height:720px;border:0}
