/* ============================================================
   LUNA DORADA — estilos globales
   ============================================================ */
:root{
  --noche:#131022;
  --panel:#1d1832;
  --panel-2:#241d3e;
  --oro:#d4af6a;
  --oro-claro:#ecd9a8;
  --lavanda:#b8a6e0;
  --violeta:#7c5cbf;
  --texto:#ede8f5;
  --texto-suave:#b6adc9;
  --telegram:#2aabee;
  --radius:18px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Karla',sans-serif;background:var(--noche);color:var(--texto);line-height:1.65;overflow-x:hidden}
h1,h2,h3,h4,.display{font-family:'Marcellus',serif;font-weight:400;letter-spacing:.02em}
img{max-width:100%}
a{color:inherit}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
:focus-visible{outline:2px solid var(--oro);outline-offset:3px}

/* ---------- Nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(19,16,34,.85);backdrop-filter:blur(12px);border-bottom:1px solid rgba(212,175,106,.15)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{font-family:'Marcellus',serif;font-size:1.2rem;color:var(--oro-claro);text-decoration:none;display:flex;align-items:center;gap:.5rem}
.logo svg{width:26px;height:26px}
.nav-links{display:flex;gap:1.5rem;list-style:none;align-items:center}
.nav-links a{text-decoration:none;color:var(--texto-suave);font-size:.9rem;transition:color .2s}
.nav-links a:hover,.nav-links a:focus-visible,.nav-links a.activo{color:var(--oro)}
.nav-cta{background:var(--oro);color:#241d10!important;padding:.5rem 1.1rem;border-radius:999px;font-weight:700;transition:transform .2s,box-shadow .2s}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(212,175,106,.35)}
.burger{display:none;background:none;border:none;color:var(--oro);font-size:1.6rem;cursor:pointer}
@media(max-width:960px){
  .nav-links{position:fixed;top:66px;right:0;flex-direction:column;background:var(--panel);padding:1.5rem 2rem;gap:1.1rem;border-radius:0 0 0 var(--radius);transform:translateX(110%);transition:transform .3s;border:1px solid rgba(212,175,106,.15);border-top:none;align-items:flex-start}
  .nav-links.open{transform:translateX(0)}
  .burger{display:block}
}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.55rem;padding:.85rem 1.7rem;border-radius:999px;text-decoration:none;font-weight:700;font-size:1rem;transition:transform .2s,box-shadow .2s;border:none;cursor:pointer;font-family:'Karla'}
.btn-oro{background:linear-gradient(135deg,var(--oro-claro),var(--oro));color:#241d10}
.btn-oro:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(212,175,106,.4)}
.btn-ghost{border:1px solid rgba(212,175,106,.4);color:var(--oro-claro);background:transparent}
.btn-ghost:hover{background:rgba(212,175,106,.08)}
.btn-wa{background:var(--telegram);color:#fff}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(42,171,238,.4)}
.btn-sm{padding:.6rem 1.2rem;font-size:.88rem}

/* ---------- Hero / cabeceras de página ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;padding:110px 0 70px;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(124,92,191,.35),transparent 60%),var(--noche)}
.page-head{position:relative;padding:130px 0 60px;text-align:center;background:radial-gradient(ellipse 70% 90% at 50% -30%,rgba(124,92,191,.32),transparent 65%),var(--noche)}
.page-head h1{font-size:clamp(2rem,4.4vw,3.1rem);color:var(--oro-claro);margin-bottom:.8rem}
.page-head p{color:var(--texto-suave);max-width:56ch;margin:0 auto}
#stars{position:absolute;inset:0;pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center;width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;color:var(--oro);font-size:.8rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:1.2rem}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--oro)}
.hero h1{font-size:clamp(2.3rem,5vw,3.6rem);line-height:1.12;margin-bottom:1.2rem}
.hero h1 em{font-style:normal;color:var(--oro-claro)}
.hero p.lead{color:var(--texto-suave);font-size:1.1rem;max-width:46ch;margin-bottom:2rem}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
@media(max-width:920px){.hero-inner{grid-template-columns:1fr}}

/* ---------- Badges ---------- */
.badge-gratis{display:inline-block;background:rgba(37,211,102,.15);color:#6ee7a0;border:1px solid rgba(37,211,102,.4);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .7rem;border-radius:999px}
.badge-pago{display:inline-block;background:rgba(212,175,106,.15);color:var(--oro-claro);border:1px solid rgba(212,175,106,.45);font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:.2rem .7rem;border-radius:999px}

/* ---------- Secciones ---------- */
section{padding:5rem 0}
.sec-head{max-width:660px;margin:0 auto 3rem;text-align:center}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.4rem);color:var(--oro-claro);margin-bottom:.7rem}
.sec-head p{color:var(--texto-suave)}
.luna-divider{display:flex;justify-content:center;gap:1.1rem;margin:0 auto 1.2rem;color:var(--oro);font-size:1rem;letter-spacing:.4em}

/* ---------- Tarjetas de herramientas gratuitas ---------- */
.grid-tools{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.4rem}
.tool{background:var(--panel);border:1px solid rgba(184,166,224,.16);border-radius:var(--radius);padding:1.9rem 1.6rem;text-decoration:none;display:flex;flex-direction:column;gap:.7rem;transition:transform .25s,border-color .25s;position:relative;overflow:hidden}
.tool:hover{transform:translateY(-6px);border-color:rgba(37,211,102,.5)}
.tool .simbolo{font-size:2.2rem}
.tool h3{font-size:1.2rem;color:var(--texto)}
.tool p{color:var(--texto-suave);font-size:.92rem;flex:1}
.tool .link{color:#6ee7a0;font-weight:700;font-size:.9rem}

/* ---------- Servicios ---------- */
.grid-serv{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.4rem}
.serv{background:var(--panel);border:1px solid rgba(212,175,106,.16);border-radius:var(--radius);padding:2rem 1.6rem;display:flex;flex-direction:column;transition:transform .25s,border-color .25s;position:relative;overflow:hidden}
.serv::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--oro),transparent);opacity:0;transition:opacity .25s}
.serv:hover{transform:translateY(-6px);border-color:rgba(212,175,106,.45)}
.serv:hover::after{opacity:1}
.serv .simbolo{font-size:2rem;margin-bottom:1rem}
.serv h3{font-size:1.25rem;color:var(--oro-claro);margin-bottom:.5rem}
.serv p{color:var(--texto-suave);font-size:.93rem;flex:1;margin-bottom:1.2rem}
.serv .precio{font-family:'Marcellus',serif;font-size:1.5rem;color:var(--texto);margin-bottom:1rem}
.serv .precio span{font-size:.85rem;font-family:'Karla';color:var(--texto-suave)}
.serv .btn{justify-content:center;font-size:.92rem;padding:.7rem 1rem}
.serv ul{list-style:none;margin:0 0 1.2rem}
.serv li{padding-left:1.4rem;position:relative;font-size:.9rem;color:var(--texto-suave);margin-bottom:.4rem}
.serv li::before{content:"✦";position:absolute;left:0;color:var(--oro);font-size:.75rem;top:.15rem}
.destacado{border-color:var(--oro)!important;background:linear-gradient(160deg,var(--panel-2),var(--panel))}
.tag{position:absolute;top:14px;right:-34px;background:var(--oro);color:#241d10;font-size:.7rem;font-weight:700;letter-spacing:.08em;padding:.25rem 2.6rem;transform:rotate(38deg)}

/* ---------- Cartas de tarot ---------- */
.mesa{background:linear-gradient(160deg,var(--panel),var(--panel-2));border:1px solid rgba(212,175,106,.22);border-radius:24px;padding:2.4rem 2rem;text-align:center;box-shadow:0 24px 60px rgba(0,0,0,.45);max-width:820px;margin:0 auto}
.mesa h2{font-size:1.5rem;color:var(--oro-claro);margin-bottom:.4rem}
.mesa .sub{color:var(--texto-suave);font-size:.95rem;margin-bottom:1.6rem}
.modo{display:flex;justify-content:center;gap:.7rem;margin-bottom:1.8rem;flex-wrap:wrap}
.modo button{background:var(--noche);border:1px solid rgba(184,166,224,.3);color:var(--texto-suave);padding:.55rem 1.3rem;border-radius:999px;cursor:pointer;font-family:'Karla';font-size:.9rem;transition:all .2s}
.modo button.on{border-color:var(--oro);color:var(--oro-claro);background:var(--panel-2)}
.cards{display:flex;justify-content:center;gap:1rem;perspective:1000px;flex-wrap:wrap}
.pos-label{font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:var(--lavanda);margin-bottom:.5rem;display:block}
.tcard{width:110px;height:178px;position:relative;cursor:pointer;background:none;border:none;padding:0;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.4,.1,.2,1)}
.tcard:hover:not(.flipped){transform:translateY(-10px) rotateZ(-1deg)}
.tcard.flipped{transform:rotateY(180deg)}
.tcard.apagada{opacity:.3;pointer-events:none}
.tcard .face{position:absolute;inset:0;border-radius:12px;backface-visibility:hidden;display:flex;align-items:center;justify-content:center}
.tcard .back{background:repeating-linear-gradient(45deg,rgba(212,175,106,.12) 0 6px,transparent 6px 12px),linear-gradient(160deg,#2b2250,#1a1433);border:1.5px solid var(--oro)}
.tcard .back svg{width:46px;height:46px;opacity:.85}
.tcard .front{background:linear-gradient(170deg,#f6ecd4,#e6d3a5);color:#3a2d12;transform:rotateY(180deg);flex-direction:column;gap:.4rem;padding:.6rem;border:1.5px solid var(--oro)}
.tcard .front .icon{font-size:2.1rem;line-height:1}
.tcard .front .name{font-family:'Marcellus',serif;font-size:.82rem;text-align:center}
.draw-result{margin-top:1.6rem;font-size:.95rem;color:var(--lavanda);opacity:0;transform:translateY(8px);transition:opacity .5s,transform .5s;text-align:left}
.draw-result.show{opacity:1;transform:none}
.lectura-carta{background:var(--noche);border:1px solid rgba(212,175,106,.25);border-radius:14px;padding:1.2rem 1.4rem;margin-bottom:.9rem}
.lectura-carta strong{color:var(--oro-claro);font-family:'Marcellus',serif;display:block;font-size:1.05rem;margin-bottom:.25rem}
.lectura-carta em{color:var(--lavanda);font-style:normal;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;display:block;margin-bottom:.4rem}
.draw-cta{text-align:center;margin-top:1.4rem}
.reiniciar{background:none;border:none;color:var(--texto-suave);text-decoration:underline;cursor:pointer;font-family:'Karla';font-size:.85rem;margin-top:1rem}
.reiniciar:hover{color:var(--oro)}

/* ---------- Horóscopo ---------- */
.zodiaco{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));gap:.7rem;max-width:780px;margin:0 auto 2rem}
.signo{background:var(--panel);border:1px solid rgba(184,166,224,.18);border-radius:14px;padding:.9rem .3rem;text-align:center;cursor:pointer;transition:all .2s;color:var(--texto);font-family:'Karla'}
.signo .glifo{font-size:1.5rem;display:block;margin-bottom:.25rem;color:var(--lavanda)}
.signo .nom{font-size:.78rem;color:var(--texto-suave)}
.signo:hover{border-color:var(--violeta);transform:translateY(-3px)}
.signo.activo{border-color:var(--oro);background:var(--panel-2)}
.signo.activo .glifo{color:var(--oro)}
.horo-out{max-width:680px;margin:0 auto;background:var(--panel-2);border:1px solid rgba(212,175,106,.25);border-radius:var(--radius);padding:2rem;display:none}
.horo-out.show{display:block;animation:fadeUp .5s}
.horo-out h3{color:var(--oro-claro);font-size:1.35rem;margin-bottom:.4rem;text-align:center}
.horo-out .fecha{font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;color:var(--texto-suave);margin-bottom:1rem;text-align:center}
.horo-out .mensaje{color:var(--texto);margin-bottom:1.4rem;text-align:center}
.horo-extra{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.8rem;margin-bottom:1.4rem}
.horo-extra div{background:var(--noche);border-radius:12px;padding:.9rem;text-align:center;border:1px solid rgba(184,166,224,.15)}
.horo-extra .k{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--texto-suave);display:block;margin-bottom:.2rem}
.horo-extra .v{font-family:'Marcellus',serif;color:var(--oro-claro);font-size:1.05rem}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ---------- Widgets (luna, compatibilidad, numerología) ---------- */
.widget{background:var(--panel);border:1px solid rgba(184,166,224,.18);border-radius:var(--radius);padding:2rem;max-width:680px;margin:0 auto}
.widget h3{color:var(--oro-claro);font-size:1.3rem;margin-bottom:1rem;text-align:center}
.luna-hoy{text-align:center}
.luna-hoy .fase{font-size:4rem;line-height:1;margin-bottom:.6rem;filter:drop-shadow(0 0 24px rgba(236,217,168,.35))}
.luna-hoy .nombre{font-family:'Marcellus',serif;font-size:1.3rem;color:var(--oro-claro)}
.luna-hoy .detalle{color:var(--texto-suave);font-size:.92rem;margin-top:.4rem}
.compat-row{display:flex;gap:1rem;justify-content:center;align-items:center;flex-wrap:wrap;margin-bottom:1.4rem}
.compat-row select,.widget input[type=date],.widget input[type=text]{background:var(--noche);border:1px solid rgba(184,166,224,.3);border-radius:12px;padding:.75rem 1rem;color:var(--texto);font-family:'Karla';font-size:.95rem}
.compat-row select:focus,.widget input:focus{outline:none;border-color:var(--oro)}
.compat-corazon{font-size:1.6rem}
.compat-out,.num-out{text-align:center;display:none}
.compat-out.show,.num-out.show{display:block;animation:fadeUp .5s}
.medidor{height:10px;background:var(--noche);border-radius:999px;overflow:hidden;margin:1rem auto;max-width:340px;border:1px solid rgba(184,166,224,.2)}
.medidor .barra{height:100%;width:0;background:linear-gradient(90deg,var(--violeta),var(--oro));border-radius:999px;transition:width 1.2s cubic-bezier(.3,.8,.3,1)}
.pct{font-family:'Marcellus',serif;font-size:2.2rem;color:var(--oro-claro)}
.num-out .numero{font-family:'Marcellus',serif;font-size:3.4rem;color:var(--oro-claro);line-height:1}
.num-out .titulo-num{font-family:'Marcellus',serif;font-size:1.2rem;color:var(--lavanda);margin:.3rem 0 .8rem}

/* ---------- Blog ---------- */
.grid-blog{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.post{background:var(--panel);border:1px solid rgba(184,166,224,.15);border-radius:var(--radius);overflow:hidden;text-decoration:none;display:flex;flex-direction:column;transition:transform .25s,border-color .25s}
.post:hover{transform:translateY(-6px);border-color:rgba(212,175,106,.4)}
.post .cover{height:150px;display:flex;align-items:center;justify-content:center;font-size:3.4rem;background:radial-gradient(circle at 50% 120%,rgba(124,92,191,.5),transparent 70%),linear-gradient(160deg,#2b2250,#1a1433)}
.post .cuerpo{padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.post .meta{display:flex;gap:.8rem;align-items:center;font-size:.78rem;color:var(--texto-suave)}
.post .cat{color:var(--oro);letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.post h3{font-size:1.15rem;color:var(--texto);line-height:1.35}
.post p{color:var(--texto-suave);font-size:.9rem;flex:1}
.post .leer{color:var(--oro-claro);font-weight:700;font-size:.88rem}

/* ---------- Artículo ---------- */
.articulo{max-width:720px;margin:0 auto}
.articulo .cover-art{height:220px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:5rem;background:radial-gradient(circle at 50% 120%,rgba(124,92,191,.5),transparent 70%),linear-gradient(160deg,#2b2250,#1a1433);border:1px solid rgba(212,175,106,.2);margin-bottom:2rem}
.articulo h2{color:var(--oro-claro);font-size:1.5rem;margin:2rem 0 .8rem}
.articulo p{color:var(--texto-suave);margin-bottom:1.1rem}
.articulo strong{color:var(--texto)}
.articulo a{color:var(--oro-claro)}
.art-cta{background:var(--panel-2);border:1px solid rgba(212,175,106,.3);border-radius:var(--radius);padding:1.8rem;text-align:center;margin-top:2.5rem}
.art-cta h3{color:var(--oro-claro);margin-bottom:.5rem}
.art-cta p{margin-bottom:1.2rem}
.volver{display:inline-block;margin-bottom:1.5rem;color:var(--texto-suave);text-decoration:none;font-size:.9rem}
.volver:hover{color:var(--oro)}

/* ---------- Rituales ---------- */
.grid-rituales{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.ritual{background:var(--panel);border:1px solid rgba(184,166,224,.16);border-radius:var(--radius);padding:2rem;transition:border-color .25s}
.ritual:hover{border-color:rgba(212,175,106,.4)}
.ritual .top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}
.ritual .simbolo{font-size:2.2rem}
.ritual h3{color:var(--oro-claro);font-size:1.25rem;margin-bottom:.6rem}
.ritual .necesitas{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--lavanda);margin:1rem 0 .4rem}
.ritual ol{margin-left:1.2rem;color:var(--texto-suave);font-size:.92rem}
.ritual ol li{margin-bottom:.45rem}
.ritual .mat{color:var(--texto-suave);font-size:.92rem}

/* ---------- Logros / testimonios ---------- */
.logros-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.2rem;margin-bottom:3.5rem}
.stat{text-align:center;padding:1.8rem 1rem;border:1px solid rgba(212,175,106,.18);border-radius:var(--radius);background:radial-gradient(circle at 50% 0%,rgba(212,175,106,.08),transparent 70%)}
.stat .num{font-family:'Marcellus',serif;font-size:2.4rem;color:var(--oro-claro)}
.stat .lab{color:var(--texto-suave);font-size:.9rem}
.testis{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.4rem}
.testi{background:var(--panel);border-radius:var(--radius);padding:1.8rem;border:1px solid rgba(184,166,224,.14);position:relative}
.testi::before{content:"\201C";position:absolute;top:.4rem;left:1.2rem;font-family:'Marcellus',serif;font-size:3.4rem;color:var(--oro);opacity:.45}
.testi p{color:var(--texto);font-style:italic;margin:1rem 0 1.2rem;font-size:.95rem}
.testi .quien{display:flex;align-items:center;gap:.8rem}
.testi .avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--violeta),var(--oro));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.95rem}
.testi .quien strong{display:block;font-size:.92rem}
.testi .quien span{font-size:.8rem;color:var(--texto-suave)}
.estrellas{color:var(--oro);letter-spacing:.15em;font-size:.85rem}

/* ---------- Sobre mí ---------- */
.sobre{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:center}
.retrato{aspect-ratio:4/5;border-radius:50% 50% var(--radius) var(--radius)/38% 38% var(--radius) var(--radius);background:radial-gradient(circle at 50% 30%,rgba(236,217,168,.25),transparent 60%),linear-gradient(170deg,#2b2250,#1a1433);border:1px solid rgba(212,175,106,.35);display:flex;align-items:center;justify-content:center;font-size:5rem}
.retrato::after{content:"🔮";filter:drop-shadow(0 8px 30px rgba(124,92,191,.8))}
.sobre h2{font-size:clamp(1.7rem,3vw,2.2rem);color:var(--oro-claro);margin-bottom:1rem}
.sobre p{color:var(--texto-suave);margin-bottom:1rem}
.sobre ul{list-style:none;margin:1.4rem 0 1.8rem}
.sobre li{padding-left:1.6rem;position:relative;margin-bottom:.6rem;color:var(--texto)}
.sobre li::before{content:"✦";position:absolute;left:0;color:var(--oro)}
@media(max-width:820px){.sobre{grid-template-columns:1fr}.retrato{max-width:300px;margin:0 auto}}

/* ---------- FAQ ---------- */
.faq{max-width:720px;margin:0 auto}
.faq details{background:var(--panel);border:1px solid rgba(184,166,224,.15);border-radius:14px;margin-bottom:.8rem;overflow:hidden}
.faq summary{padding:1.1rem 1.4rem;cursor:pointer;font-weight:700;color:var(--texto);list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"✦";color:var(--oro);transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .resp{padding:0 1.4rem 1.2rem;color:var(--texto-suave);font-size:.94rem}

/* ---------- CTA final / footer ---------- */
.pre-foot{padding:4rem 0 2rem}
.cta-final{background:radial-gradient(ellipse 70% 90% at 50% 110%,rgba(124,92,191,.4),transparent 65%),var(--panel);border-radius:28px;padding:3.2rem 2.5rem;text-align:center;border:1px solid rgba(212,175,106,.25)}
.cta-final h2{font-size:clamp(1.6rem,3vw,2.2rem);color:var(--oro-claro);margin-bottom:.8rem}
.cta-final>p{color:var(--texto-suave);max-width:56ch;margin:0 auto 1.8rem}
footer{border-top:1px solid rgba(212,175,106,.15);padding:3rem 0 1.5rem;margin-top:2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.5rem}
.foot-grid h4{color:var(--oro-claro);font-size:1rem;margin-bottom:.9rem}
.foot-grid a{display:block;color:var(--texto-suave);text-decoration:none;font-size:.9rem;margin-bottom:.5rem}
.foot-grid a:hover{color:var(--oro)}
.foot-txt{color:var(--texto-suave);font-size:.9rem}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--texto-suave);font-size:.8rem;border-top:1px solid rgba(184,166,224,.1);padding-top:1.4rem}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr 1fr}}

/* ---------- WhatsApp flotante ---------- */
.wa-float{position:fixed;bottom:22px;right:22px;z-index:60;width:58px;height:58px;border-radius:50%;background:var(--telegram);display:flex;align-items:center;justify-content:center;box-shadow:0 8px 26px rgba(42,171,238,.5);transition:transform .2s;text-decoration:none}
.wa-float:hover{transform:scale(1.1)}
.wa-float svg{width:30px;height:30px;fill:#fff}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ---------- Aviso de salud / disclaimers ---------- */
.aviso-salud{background:rgba(184,166,224,.08);border:1px solid rgba(184,166,224,.35);border-left:4px solid var(--lavanda);border-radius:12px;padding:1.1rem 1.4rem;font-size:.9rem;color:var(--texto-suave);margin:1.5rem 0}
.aviso-salud strong{color:var(--texto)}

/* ---------- Persona (sobre mí) ---------- */
.marco-foto{position:relative;aspect-ratio:4/5;border-radius:50% 50% var(--radius) var(--radius)/38% 38% var(--radius) var(--radius);overflow:hidden;border:1px solid rgba(212,175,106,.4);box-shadow:0 24px 60px rgba(0,0,0,.5)}
.marco-foto img,.marco-foto svg{width:100%;height:100%;object-fit:cover;display:block}
.firma{font-family:'Marcellus',serif;font-style:italic;font-size:1.6rem;color:var(--oro-claro);margin-top:1rem}
.cita-vega{border-left:3px solid var(--oro);padding:.4rem 0 .4rem 1.2rem;color:var(--lavanda);font-style:italic;margin:1.3rem 0}
.sello{display:inline-flex;align-items:center;gap:.5rem;background:var(--panel-2);border:1px solid rgba(212,175,106,.3);border-radius:999px;padding:.4rem 1rem;font-size:.82rem;color:var(--texto-suave);margin:.25rem .25rem .25rem 0}
.banda-persona{display:grid;grid-template-columns:130px 1fr auto;gap:1.8rem;align-items:center;background:var(--panel);border:1px solid rgba(212,175,106,.22);border-radius:var(--radius);padding:1.6rem 2rem}
.banda-persona .mini-foto{width:130px;height:130px;border-radius:50%;overflow:hidden;border:2px solid var(--oro)}
.banda-persona .mini-foto img,.banda-persona .mini-foto svg{width:100%;height:100%;object-fit:cover}
@media(max-width:760px){.banda-persona{grid-template-columns:1fr;text-align:center;justify-items:center}}

/* ---------- Popup newsletter ---------- */
.nl-overlay{position:fixed;inset:0;background:rgba(10,8,20,.75);backdrop-filter:blur(4px);z-index:90;display:none;align-items:center;justify-content:center;padding:20px}
.nl-overlay.abierto{display:flex;animation:fadeUp .35s}
.nl-modal{position:relative;max-width:440px;width:100%;background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid rgba(212,175,106,.45);border-radius:22px;padding:2.4rem 2.2rem;text-align:center;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.nl-modal .nl-cerrar{position:absolute;top:.8rem;right:1rem;background:none;border:none;color:var(--texto-suave);font-size:1.4rem;cursor:pointer}
.nl-modal .nl-cerrar:hover{color:var(--oro)}
.nl-modal h3{font-size:1.5rem;color:var(--oro-claro);margin:.6rem 0 .4rem}
.nl-modal .nl-regalo{font-size:2.6rem}
.nl-modal p{color:var(--texto-suave);font-size:.94rem;margin-bottom:1.2rem}
.nl-modal input[type=text],.nl-modal input[type=email]{width:100%;background:var(--noche);border:1px solid rgba(184,166,224,.3);border-radius:12px;padding:.8rem 1rem;color:var(--texto);font-family:'Karla';font-size:.95rem;margin-bottom:.8rem}
.nl-modal input:focus{outline:none;border-color:var(--oro)}
.nl-consent{display:flex;gap:.5rem;align-items:flex-start;text-align:left;font-size:.75rem;color:var(--texto-suave);margin:.2rem 0 1rem}
.nl-codigo{font-family:'Marcellus',serif;font-size:1.7rem;letter-spacing:.2em;color:var(--oro-claro);background:var(--noche);border:1px dashed var(--oro);border-radius:12px;padding:.7rem;margin:1rem 0}
.nl-inline{background:linear-gradient(165deg,var(--panel-2),var(--panel));border:1px solid rgba(212,175,106,.35);border-radius:22px;padding:2.4rem;display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
@media(max-width:760px){.nl-inline{grid-template-columns:1fr}}

/* ---------- Chat IA "Estrella" ---------- */
.chat-fab{position:fixed;bottom:92px;right:22px;z-index:60;width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--violeta),#5a3fa0);display:flex;align-items:center;justify-content:center;font-size:1.7rem;box-shadow:0 8px 26px rgba(124,92,191,.55);border:1px solid rgba(212,175,106,.4);cursor:pointer;transition:transform .2s}
.chat-fab:hover{transform:scale(1.08)}
.chat-fab .puntito{position:absolute;top:2px;right:2px;width:14px;height:14px;border-radius:50%;background:#6ee7a0;border:2px solid var(--noche)}
.chat-panel{position:fixed;bottom:92px;right:22px;z-index:80;width:min(370px,calc(100vw - 30px));height:min(540px,calc(100vh - 120px));background:var(--panel);border:1px solid rgba(212,175,106,.35);border-radius:20px;display:none;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.chat-panel.abierto{display:flex;animation:fadeUp .3s}
.chat-cab{background:linear-gradient(135deg,#2b2250,#1a1433);padding:.9rem 1.1rem;display:flex;gap:.8rem;align-items:center;border-bottom:1px solid rgba(212,175,106,.25)}
.chat-cab .avatar-ia{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#b8a6e0,#7c5cbf);display:flex;align-items:center;justify-content:center;font-size:1.3rem;border:2px solid var(--oro)}
.chat-cab .quien strong{display:block;color:var(--oro-claro);font-family:'Marcellus',serif;font-size:1.02rem}
.chat-cab .quien span{font-size:.72rem;color:var(--texto-suave)}
.chat-cab .chat-cerrar{margin-left:auto;background:none;border:none;color:var(--texto-suave);font-size:1.3rem;cursor:pointer}
.chat-msgs{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.7rem}
.msg{max-width:82%;padding:.65rem .95rem;border-radius:16px;font-size:.9rem;line-height:1.5;white-space:pre-line}
.msg.ella{background:var(--panel-2);border:1px solid rgba(184,166,224,.2);border-bottom-left-radius:4px;align-self:flex-start;color:var(--texto)}
.msg.yo{background:linear-gradient(135deg,var(--oro-claro),var(--oro));color:#241d10;border-bottom-right-radius:4px;align-self:flex-end}
.msg.ella a{color:var(--oro-claro)}
.escribiendo{align-self:flex-start;color:var(--lavanda);font-size:1.1rem;letter-spacing:.2em;padding:.2rem .9rem;animation:parpadeo 1.2s infinite}
@keyframes parpadeo{0%,100%{opacity:.3}50%{opacity:1}}
.chips{display:flex;gap:.45rem;flex-wrap:wrap;padding:0 1rem .6rem}
.chips button{background:var(--noche);border:1px solid rgba(184,166,224,.3);color:var(--texto-suave);border-radius:999px;padding:.35rem .8rem;font-size:.78rem;cursor:pointer;font-family:'Karla'}
.chips button:hover{border-color:var(--oro);color:var(--oro-claro)}
.chat-pie{display:flex;gap:.5rem;padding:.8rem;border-top:1px solid rgba(184,166,224,.15)}
.chat-pie input{flex:1;background:var(--noche);border:1px solid rgba(184,166,224,.3);border-radius:999px;padding:.65rem 1rem;color:var(--texto);font-family:'Karla';font-size:.9rem}
.chat-pie input:focus{outline:none;border-color:var(--oro)}
.chat-pie button{width:42px;height:42px;border-radius:50%;border:none;background:var(--oro);color:#241d10;font-size:1.1rem;cursor:pointer}
.chat-aviso{font-size:.68rem;color:var(--texto-suave);text-align:center;padding:0 1rem .6rem}
@media(max-width:520px){.chat-panel{bottom:0;right:0;width:100vw;height:calc(100vh - 60px);border-radius:20px 20px 0 0}}
