/* ============================================================
   PRESENTIA — theme.css
   ------------------------------------------------------------
   CSS propio del tema que NO vive en brand.css (que se mantiene
   intacto). Aquí se consolidan los estilos que en el prototipo
   estaban inline en cada .html o inyectados por site-nav.js.
   Se irá ampliando por fases (héroes, secciones, etc.).

   FASE 1: navegación (header + dropdown + drawer móvil) y footer.
   ============================================================ */

/* ============================ Accesibilidad ============================ */
.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.screen-reader-text:focus{position:fixed;top:12px;left:12px;z-index:1000;width:auto;height:auto;clip:auto;padding:.7em 1.2em;background:#fff;color:var(--brand);border-radius:var(--pill);box-shadow:var(--sh)}

/* ============================ Header / Nav (port de site-nav.js) ============================ */
.nav__in{height:74px;gap:28px}
.nav__links{display:flex;align-items:center;gap:26px;margin-left:8px;flex-wrap:nowrap}
.nav__links a{font-weight:500;font-size:.97rem;color:var(--ink-soft);transition:color .2s;position:relative;white-space:nowrap}
.nav__links a:hover{color:var(--brand)}
.npar{position:relative}
.npar>a{display:flex;align-items:center;white-space:nowrap}
.ncaret{display:inline-block;margin-left:.3em;font-size:.6em;opacity:.45;transition:transform .2s;vertical-align:.12em}
.npar:hover .ncaret{transform:rotate(180deg)}
.ndrop{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh);padding:18px 20px;min-width:460px;display:none;grid-template-columns:1fr 1fr;gap:6px;z-index:100}
.ndrop::before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px}
.npar:hover .ndrop,.npar:focus-within .ndrop{display:grid}
.ndrop-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r);transition:background .18s,color .18s;color:var(--ink)}
.ndrop-item:hover{background:var(--tint);color:var(--brand)}
.ndrop-ic{width:34px;height:34px;border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;flex:none;font-size:1.05rem;background:var(--tint)}
.ndrop-title{font-weight:600;font-size:.9rem;line-height:1.2;display:block}
.ndrop-sub{font-size:.78rem;color:var(--muted);line-height:1.25;display:block}
.nav__links a.sep::before{content:"";width:1px;height:16px;background:var(--line-strong);display:inline-block;margin-right:28px;vertical-align:middle}
.nav__links a.is-active,.npar.is-active>a{color:var(--brand);font-weight:600}

/* iconos lupa + carrito; número centrado dentro del carrito */
.nav__right .iconbtn.psn-ic{color:var(--brand)}
.nav__right .iconbtn.psn-ic:hover{background:var(--brand-50);color:var(--brand)}
.nav__right .psn-cart{position:relative}
.nav__right .psn-cart .cartdot{position:absolute;top:48%;left:52%;right:auto;transform:translate(-50%,-50%);width:15px;height:15px;min-width:15px;padding:0;border-radius:50%;background:#E87080;color:#fff;font-size:.54rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px rgba(232,112,128,.5)}
.nav__right .psn-cart .cartdot:empty,.nav__right .psn-cart.is-empty .cartdot{display:none}

/* ============================ Drawer móvil ============================ */
.psn-ov{position:fixed;inset:0;background:rgba(23,19,38,.5);z-index:190;opacity:0;pointer-events:none;transition:opacity .3s;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.psn-ov.open{opacity:1;pointer-events:auto}
.psn-dr{position:fixed;top:0;right:0;bottom:0;width:min(340px,88vw);background:#fff;z-index:200;transform:translateX(100%);transition:transform .34s cubic-bezier(.2,.8,.2,1);display:flex;flex-direction:column}
.psn-dr.open{transform:none}
.psn-dr__head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px 16px;border-bottom:1px solid var(--line)}
.psn-dr__head img{height:22px}
.psn-close{width:40px;height:40px;border-radius:50%;border:1.5px solid var(--line-strong);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:.2s;background:#fff}
.psn-close:hover{border-color:var(--brand);color:var(--brand)}
.psn-links{display:flex;flex-direction:column;padding:6px 22px;overflow-y:auto;flex:1}
.psn-links a{display:flex;align-items:center;justify-content:space-between;padding:14px 2px;font-size:1.02rem;color:var(--ink);border-bottom:1px solid var(--line)}
.psn-links a:hover,.psn-links a.is-active{color:var(--brand)}
.psn-links a.is-active{font-weight:600}
.psn-links a svg{width:16px;height:16px;opacity:.4}
.psn-dr__foot{padding:20px 22px;border-top:1px solid var(--line)}
.psn-dr__foot .btn{width:100%;justify-content:center}
.psn-burger{display:none}
body.psn-lock{overflow:hidden}
@media(max-width:980px){.nav__links{display:none}.psn-burger{display:flex}}

/* ============================ Footer (port del inline de la Home) ============================ */
.foot{background:var(--ink);color:#fff;padding:clamp(52px,7vw,84px) 0 32px}
.foot a{color:rgba(255,255,255,.56);transition:.18s}
.foot a:hover{color:#fff}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:clamp(22px,3vw,44px);margin-bottom:clamp(38px,5vw,60px)}
.foot-h{font-weight:700;font-size:.72rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.36);margin-bottom:14px}
.foot-links{display:flex;flex-direction:column;gap:8px}
.foot-links a{font-size:.9rem}
.foot-brand{font-family:var(--display);font-size:1.8rem;color:#fff;margin-bottom:9px}
.foot-claim{color:rgba(255,255,255,.38);font-size:.87rem;line-height:1.55;max-width:24ch}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;border-top:1px solid rgba(255,255,255,.09);padding-top:26px;font-size:.8rem;color:rgba(255,255,255,.3)}
.foot-social{display:flex;gap:10px;margin-top:18px}
.foot-soc-btn{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.5);font-size:.75rem;font-weight:700;transition:.2s}
.foot-soc-btn:hover{background:var(--brand);color:#fff}
.foot-astro{display:flex;align-items:center;justify-content:center;gap:clamp(10px,1.6vw,20px);padding-bottom:clamp(28px,4vw,44px);border-bottom:1px solid rgba(255,255,255,.07);margin-bottom:clamp(32px,4.5vw,52px);flex-wrap:wrap}
.foot-astro__row{display:flex;gap:clamp(8px,1.2vw,16px);align-items:center}
.foot-astro__link{font-size:.79rem;color:rgba(255,255,255,.28);font-style:italic;transition:color .2s}
.foot-astro__link:hover{color:rgba(255,255,255,.62)}
@media(max-width:880px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.foot-grid{grid-template-columns:1fr}}

/* Isotipo Will con carita superpuesta (footer + landing) */
.will-wrap{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:18px;overflow:hidden;flex:none}
.will-wrap img{display:block;width:100%;height:100%;object-fit:contain}
.will-face{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}

/* ============================================================
   FASE 2 — Home + páginas "v4" (paleta suave Headspace)
   ------------------------------------------------------------
   La paleta se reescribe SOLO en .tema-suave (body de Home y
   servicios core). brand.css queda intacto. El resto del CSS
   son los componentes de la Home portados del prototipo.
   ============================================================ */
.tema-suave{
  --brand:#8B6BE8;--brand-600:#7655D6;--brand-700:#5E3DC4;
  --brand-100:#ECE4FF;--brand-50:#F5F0FF;
  --sh-brand:0 18px 44px -20px rgba(139,107,232,.42);
  --amber:#C8952E;--orange:#D9714E;--shamrock:#4FA88A;--british:#2A6250;
  --ink:#19153A;--ink-soft:#3A3360;--muted:#6A6280;
  --bg:#FEFCF9;--tint:#F5F0FF;--cream:#FBF7EF;
  --line:#EAE4F2;--line-strong:#D5CEEA;
}

/* ── Animaciones de la mascota ─────────────────────── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-13px)}}
@keyframes pulse{0%,100%{opacity:.32;transform:scale(1)}50%{opacity:.58;transform:scale(1.06)}}
@keyframes blink{0%,88%,100%{transform:scaleY(1)}92%{transform:scaleY(.06)}}
.m-float{animation:float 5.5s ease-in-out infinite}
.m-float-d{animation:float 5.5s .9s ease-in-out infinite}
.m-float-e{animation:float 5.5s 1.7s ease-in-out infinite}
.m-aura{animation:spin 22s linear infinite;transform-box:fill-box;transform-origin:center}
.m-glow{animation:pulse 4s ease-in-out infinite;transform-box:fill-box;transform-origin:center}
.m-eye{animation:blink 6s ease-in-out infinite;transform-box:fill-box;transform-origin:50% 100%}
@media(prefers-reduced-motion:reduce){.m-float,.m-float-d,.m-float-e,.m-aura,.m-glow,.m-eye{animation:none}}

/* ── Misc / titulares de sección ───────────────────── */
.ey{color:var(--brand);font-weight:700;font-size:.78rem;letter-spacing:.17em;text-transform:uppercase;display:flex;align-items:center;gap:.55em;margin-bottom:14px}
.sec-h{font-family:var(--display);font-size:clamp(2.1rem,4vw,3.6rem);line-height:1.02;letter-spacing:-.015em}
.sec-sub{color:var(--muted);font-size:clamp(.97rem,1.4vw,1.15rem);line-height:1.62;max-width:50ch}

/* ── Hero ──────────────────────────────────────────── */
.hero{min-height:100vh;display:flex;align-items:center;padding-top:74px;background:linear-gradient(155deg,var(--bg) 0%,var(--tint) 55%,#e5d8ff 100%);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,72px);align-items:center}
.hero-kicker{display:inline-flex;align-items:center;gap:.6em;background:var(--tint);color:var(--brand-700);font-weight:600;font-size:.8rem;letter-spacing:.07em;padding:.5em 1em;border-radius:var(--pill);border:1px solid var(--brand-100);margin-bottom:22px}
.hero-h1{font-family:var(--display);font-size:clamp(3.2rem,7vw,5.8rem);line-height:.93;letter-spacing:-.022em;color:var(--ink)}
.hero-h1 em{font-style:italic;color:var(--brand)}
.hero-sub{font-size:clamp(1.05rem,1.5vw,1.22rem);color:var(--ink-soft);max-width:43ch;margin-top:20px;line-height:1.62}
.hero-ctas{display:flex;gap:12px;margin-top:30px;flex-wrap:wrap}
.hero-stats{display:flex;gap:clamp(22px,3.5vw,44px);margin-top:36px;flex-wrap:wrap}
.hstat-n{font-family:var(--display);font-size:clamp(1.7rem,2.8vw,2.3rem);line-height:1;color:var(--ink)}
.hstat-l{font-size:.84rem;color:var(--muted);margin-top:4px}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;text-align:center}.hero-ctas,.hero-stats{justify-content:center}.hero-sub{margin-inline:auto}}

/* ── Hero emociones (La Familia Astro) ─────────────── */
.emo-grid-wrap{position:relative}
.emo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(7px,1.1vw,12px)}
.emo-card{background:var(--ec-bg,var(--tint));border-radius:var(--r-lg);padding:clamp(11px,1.5vw,17px) 8px;display:flex;flex-direction:column;align-items:center;gap:5px;text-decoration:none;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s,border-color .2s;border:1.5px solid transparent;cursor:pointer;overflow:hidden}
.emo-card:hover{transform:translateY(-5px);box-shadow:0 14px 32px -10px rgba(0,0,0,.16);border-color:var(--ec,var(--brand))}
.emo-char{height:62px;display:flex;align-items:center;justify-content:center}
.emo-name{font-family:var(--display);font-size:.84rem;color:var(--ink);line-height:1;text-align:center}
.emo-label{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ec,var(--brand));text-align:center}
.emo-expr{font-size:.72rem;color:var(--ec,var(--brand));font-family:monospace;opacity:.65;letter-spacing:.03em;text-align:center}
@media(max-width:900px){.emo-grid-wrap{order:-1}}
@media(max-width:500px){.emo-grid{gap:5px}.emo-name{font-size:.72rem}.emo-char{height:50px}}

/* ── Trust strip ───────────────────────────────────── */
.tstrip{background:var(--ink);color:#fff;padding:clamp(26px,4vw,42px) 0}
.tstrip-inner{display:flex;justify-content:center;gap:clamp(14px,2.2vw,40px);flex-wrap:wrap;align-items:center}
.tstat{text-align:center}
.tstat-n{font-family:var(--display);font-size:clamp(1.9rem,3.2vw,2.7rem);color:#fff;line-height:1}
.tstat-l{font-size:.84rem;color:rgba(255,255,255,.5);margin-top:5px}
.tsep{width:1px;height:40px;background:rgba(255,255,255,.14)}

/* ── Selector de intención ─────────────────────────── */
.intent-label{text-align:center;font-weight:700;font-size:.78rem;letter-spacing:.17em;text-transform:uppercase;color:var(--brand);margin-bottom:20px}
.intent-tabs{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-bottom:clamp(28px,4vw,48px)}
.itab{display:flex;align-items:center;gap:.5em;padding:.65em 1.25em;border-radius:var(--pill);font-weight:600;font-size:.94rem;color:var(--ink-soft);background:#fff;border:1.6px solid var(--line);cursor:pointer;transition:.22s}
.itab:hover{border-color:var(--brand);color:var(--brand)}
.itab[aria-selected=true]{background:var(--brand);color:#fff;border-color:var(--brand);box-shadow:var(--sh-brand)}
.ipanel{display:none}
.ipanel.on{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,5vw,62px);align-items:center;background:var(--tint);border-radius:var(--r-xl);padding:clamp(28px,4vw,54px);animation:fadeup .32s ease}
@keyframes fadeup{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.ipanel-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.itab[aria-selected=true][data-i="0"]{background:#B45FAB;border-color:#B45FAB;box-shadow:0 6px 20px -8px rgba(180,95,171,.5)}
.itab[aria-selected=true][data-i="1"]{background:#4FA88A;border-color:#4FA88A;box-shadow:0 6px 20px -8px rgba(79,168,138,.5)}
.itab[aria-selected=true][data-i="2"]{background:#6678AA;border-color:#6678AA;box-shadow:0 6px 20px -8px rgba(102,120,170,.5)}
.itab[aria-selected=true][data-i="3"]{background:#4FA88A;border-color:#4FA88A;box-shadow:0 6px 20px -8px rgba(79,168,138,.5)}
.itab[aria-selected=true][data-i="4"]{background:#C8952E;border-color:#C8952E;box-shadow:0 6px 20px -8px rgba(200,149,46,.5)}
.itab[aria-selected=true][data-i="5"]{background:#8B6BE8;border-color:#8B6BE8;box-shadow:0 6px 20px -8px rgba(139,107,232,.5)}
#ip0.on{background:#F7ECF6}#ip1.on{background:#E4F5EE}#ip2.on{background:#E6E9F4}#ip3.on{background:#E4F5EE}#ip4.on{background:#FBF2D8}
@media(max-width:780px){.ipanel.on{grid-template-columns:1fr}.ipanel-vis{display:none}}

/* ── Tarjetas de servicio ──────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(13px,1.7vw,21px)}
.scard{border-radius:var(--r-xl);padding:clamp(22px,3vw,36px);display:flex;flex-direction:column;min-height:270px;position:relative;overflow:hidden;text-decoration:none;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.scard:hover{transform:translateY(-6px)}
.sc-purple{background:var(--tint);color:var(--ink)}
.sc-green{background:#E0F4EC;color:var(--ink)}
.sc-amber{background:#FBF0D8;color:var(--ink)}
.sc-orange{background:#FAE8DF;color:var(--ink)}
.sc-sky{background:#DEF0FC;color:var(--ink)}
.sc-brit{background:#DCF0E6;color:var(--ink)}
.sc-eyebrow{font-weight:700;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;opacity:.5;margin-bottom:auto}
.sc-title{font-family:var(--display);font-size:clamp(1.3rem,1.9vw,1.72rem);line-height:1.07;margin-bottom:8px}
.sc-text{font-size:.87rem;opacity:.62;max-width:28ch;line-height:1.48}
.sc-footer{display:flex;align-items:flex-end;justify-content:space-between;margin-top:18px}
.sc-arrow{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.08);transition:.22s}
.scard:hover .sc-arrow{background:var(--brand);color:#fff}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.svc-grid{grid-template-columns:1fr}}

/* ── Bloque destacado (feature) ────────────────────── */
.feat{background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:clamp(38px,6vw,78px);overflow:hidden;position:relative}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,68px);align-items:center}
.feat-ey{font-weight:700;font-size:.76rem;letter-spacing:.17em;text-transform:uppercase;color:var(--brand-100);margin-bottom:16px}
.feat-h{font-family:var(--display);font-size:clamp(1.9rem,3.6vw,3.2rem);line-height:1.03;color:#fff;margin-bottom:18px}
.feat-p{color:rgba(255,255,255,.65);line-height:1.65;font-size:1rem;margin-bottom:24px}
.feat-pts{display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.feat-pt{display:flex;align-items:flex-start;gap:11px;color:rgba(255,255,255,.82);font-size:.95rem}
.feat-pt-dot{width:7px;height:7px;border-radius:50%;background:var(--brand);flex:none;margin-top:.45em}
.feat-bg{position:absolute;border-radius:50%;border:1px solid rgba(255,255,255,.06);pointer-events:none}
@media(max-width:820px){.feat-grid{grid-template-columns:1fr}}

/* ── Sección empresas (biz) ────────────────────────── */
.biz{background:linear-gradient(145deg,#19153A 0%,#2D1F5E 100%);color:#fff;border-radius:var(--r-xl);padding:clamp(42px,6vw,84px)}
.biz-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,68px);align-items:center}
.biz-stats{display:grid;grid-template-columns:1fr 1fr;gap:clamp(18px,3vw,34px)}
.biz-n{font-family:var(--display);font-size:clamp(2rem,3.4vw,3rem);line-height:1;color:#fff}
.biz-l{color:rgba(255,255,255,.5);font-size:.88rem;margin-top:6px}
.biz-logos{display:flex;gap:clamp(16px,2vw,28px);flex-wrap:wrap;opacity:.38;margin-top:28px}
.biz-logos span{font-family:var(--display);font-size:clamp(.85rem,1.3vw,1.1rem);color:#fff}
@media(max-width:820px){.biz-grid{grid-template-columns:1fr}}

/* ── Sobre Presentia / fundadora ───────────────────── */
.founder-card{background:linear-gradient(140deg,var(--tint),#dfd4ff);border-radius:var(--r-xl);padding:clamp(20px,2.8vw,32px);display:flex;gap:18px;align-items:center;margin-bottom:16px}
.team-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.team-mini{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-lg);padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:.2s}
.team-mini:hover{border-color:var(--line-strong);box-shadow:var(--sh-sm)}
.team-mini-ic{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.check-row{display:flex;align-items:center;gap:11px;color:var(--ink-soft);font-size:.95rem}
.check-ic{width:26px;height:26px;border-radius:50%;background:var(--tint);display:flex;align-items:center;justify-content:center;flex:none;color:var(--brand)}

/* ── FAQ ───────────────────────────────────────────── */
.faq-wrap{max-width:740px;margin-inline:auto}
.faqi{border-top:1px solid var(--line)}
.faqi:last-child{border-bottom:1px solid var(--line)}
.faq-sum{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 4px;cursor:pointer;font-family:var(--display);font-size:clamp(1.1rem,1.7vw,1.4rem);color:var(--ink);list-style:none;background:none;border:none;text-align:left}
.faq-sum::-webkit-details-marker{display:none}
.faq-pm{flex:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--brand-50);color:var(--brand);transition:.28s;font-size:1.2rem;line-height:0}
details[open] .faq-pm{background:var(--brand);color:#fff;transform:rotate(45deg)}
.faq-body{padding:0 4px 24px;color:var(--muted);max-width:62ch;line-height:1.65}

/* ── CTA final ─────────────────────────────────────── */
.cta-final{background:linear-gradient(155deg,var(--tint) 0%,#e5d8ff 50%,var(--cream) 100%);border-radius:var(--r-xl);padding:clamp(52px,8vw,96px) clamp(30px,5vw,72px);text-align:center;position:relative;overflow:hidden}
.cta-final h2{font-family:var(--display);font-size:clamp(2.3rem,5vw,4.2rem);line-height:.96;letter-spacing:-.02em;max-width:16ch;margin-inline:auto;margin-bottom:18px}
.cta-final h2 em{font-style:italic;color:var(--brand)}
.cta-final-sub{color:var(--muted);font-size:1.05rem;max-width:44ch;margin-inline:auto;margin-bottom:32px;line-height:1.62}

/* ── Newsletter ────────────────────────────────────── */
.nl-strip{background:var(--ink);padding:clamp(36px,5vw,60px) 0}
.nl-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,54px);align-items:center}
.nl-form{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.nl-input{flex:1;min-width:180px;padding:.76em 1.1em;border-radius:var(--pill);border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:.95rem;outline:none;transition:.2s}
.nl-input::placeholder{color:rgba(255,255,255,.3)}
.nl-input:focus{border-color:var(--brand)}
@media(max-width:720px){.nl-inner{grid-template-columns:1fr}}

/* ============================================================
   FASE 3·1 — Psicología Clínica (page-psicologia.php)
   ============================================================ */
.psi-hero{min-height:90vh;display:flex;align-items:center;padding-top:74px;background:linear-gradient(155deg,var(--bg) 0%,var(--tint) 58%,#ddd2ff 100%);overflow:hidden;position:relative}
.psi-hero::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(139,107,232,.08) 0%,transparent 70%);top:5%;right:-5%;pointer-events:none}
.psi-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center;position:relative;z-index:1}
@media(max-width:900px){.psi-hero-grid{grid-template-columns:1fr;text-align:center}}

.journey-scene{background:#fff;border-radius:var(--r-xl);padding:clamp(22px,3vw,36px);box-shadow:var(--sh);position:relative}

.spec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(13px,1.8vw,20px)}
.spec-card{border-radius:var(--r-xl);padding:clamp(22px,3vw,36px);display:flex;flex-direction:column;gap:14px;border:1.5px solid var(--line);background:#fff;transition:transform .3s,box-shadow .3s;cursor:default}
.spec-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.spec-tag{font-weight:700;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}
.spec-ic{width:50px;height:50px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex:none}
@media(max-width:680px){.spec-grid{grid-template-columns:1fr}}

.emo-strip{display:flex;align-items:center;justify-content:center;gap:clamp(8px,2vw,24px);flex-wrap:wrap;padding:clamp(24px,4vw,44px) 0}
.emo-pill{display:flex;flex-direction:column;align-items:center;gap:6px;padding:clamp(14px,2vw,20px) clamp(12px,1.8vw,20px);border-radius:var(--r-xl);border:1.5px solid var(--line);background:#fff;min-width:90px;transition:.25s}
.emo-pill:hover{transform:translateY(-4px);box-shadow:var(--sh-sm)}
.emo-pill-name{font-family:var(--display);font-size:.9rem;color:var(--ink)}
.emo-pill-label{font-size:.64rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.emo-pill-expr{font-family:monospace;font-size:.75rem;opacity:.6}
.emo-arrow{color:var(--muted);font-size:1.4rem;opacity:.4;align-self:center}

.who-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.8vw,20px)}
.who-card{background:var(--tint);border-radius:var(--r-xl);padding:clamp(20px,2.8vw,32px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;transition:.25s}
.who-card:hover{transform:translateY(-3px)}
.who-ic{width:70px;height:70px;border-radius:50%;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.who-title{font-family:var(--display);font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--ink)}
.who-text{font-size:.86rem;color:var(--muted);line-height:1.5}
@media(max-width:780px){.who-grid{grid-template-columns:1fr 1fr}}
@media(max-width:440px){.who-grid{grid-template-columns:1fr}}

.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px)}
.proc-n{font-family:var(--display);font-size:clamp(2rem,3vw,2.8rem);color:var(--brand);line-height:1;margin-bottom:10px}
@media(max-width:820px){.proc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.proc-grid{grid-template-columns:1fr}}

.appr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.appr-card{background:var(--cream);border-radius:var(--r-xl);padding:clamp(22px,3vw,36px)}
@media(max-width:680px){.appr-grid{grid-template-columns:1fr}}

/* Áreas de intervención + tooltips conscientes del borde */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.5vw,16px)}
.area-chip{position:relative;display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-lg);padding:13px 16px;transition:.2s;cursor:default}
.area-chip:hover{border-color:var(--ac,var(--brand));background:color-mix(in srgb,var(--ac,var(--brand)) 9%,#fff)}
.area-chip:hover .area-face{background:var(--ac,var(--brand))!important}
.area-chip:hover .area-face svg{color:#fff!important}
.area-face{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;transition:.2s}
.area-tip{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translateX(-50%) translateY(5px);width:min(264px,82vw);background:var(--ink);color:#fff;font-size:.8rem;line-height:1.45;padding:11px 14px;border-radius:var(--r-sm);box-shadow:var(--sh);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:30}
.area-tip::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:6px solid transparent;border-top-color:var(--ink)}
.area-chip:hover .area-tip{opacity:1;transform:translateX(-50%) translateY(0)}
@media(max-width:760px){.area-tip{display:none}.areas-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.areas-grid{grid-template-columns:1fr}}

/* CTA oscuro (Psicología y otras) */
.cta-dark{background:var(--ink);border-radius:var(--r-xl);padding:clamp(44px,7vw,88px) clamp(28px,5vw,72px);text-align:center;position:relative;overflow:hidden}
.cta-dark::before{content:"";position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;border:1px solid rgba(255,255,255,.05)}

/* ============================================================
   FASE 3·2 — Mindfulness · MBSR (page-mindfulness.php)
   ------------------------------------------------------------
   Acentos verdes scopeados a .page-mbsr (no afectan a otras
   páginas). Componentes propios del programa, globales.
   ============================================================ */
.page-mbsr{--green:#4FA88A;--green-l:#E0F4EC;--green-ll:#F0FAF5;--amber:#F2B84B;--orange:#E5764A;--rose:#E87080}
.page-mbsr .ey{color:var(--green)}
.page-mbsr .faq-pm{background:var(--green-ll);color:var(--green)}
.page-mbsr details[open] .faq-pm{background:var(--green);color:#fff}

/* Animaciones específicas (respiración + flotaciones secundarias) */
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes float3{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes breathe{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.08);opacity:1}}
.f1{animation:float 5.5s ease-in-out infinite}
.f2{animation:float2 5.5s .9s ease-in-out infinite}
.f3{animation:float3 5.5s 1.7s ease-in-out infinite}
.breathe{animation:breathe 4s ease-in-out infinite}
@media(prefers-reduced-motion:reduce){.f1,.f2,.f3,.breathe{animation:none}}

.mbsr-hero{min-height:92vh;display:flex;align-items:center;padding-top:74px;background:linear-gradient(155deg,var(--bg) 0%,var(--green-ll) 55%,#b8e8d4 100%);overflow:hidden;position:relative}
.mbsr-hero::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(79,168,138,.1) 0%,transparent 70%);top:5%;right:5%}
.mbsr-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center;position:relative;z-index:1}
@media(max-width:880px){.mbsr-hero-grid{grid-template-columns:1fr;text-align:center}}
.breath-ring{border-radius:50%;border:2px solid rgba(79,168,138,.25);display:flex;align-items:center;justify-content:center}

.week-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.4vw,16px)}
.week-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-xl);padding:clamp(16px,2.2vw,24px);transition:.25s}
.week-card:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--green)}
.week-n{font-family:var(--display);font-size:clamp(1.8rem,2.5vw,2.2rem);color:var(--green);line-height:1;margin-bottom:8px}
@media(max-width:820px){.week-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.week-grid{grid-template-columns:1fr}}

.stat-row{display:flex;gap:clamp(20px,3.5vw,48px);flex-wrap:wrap}
.stat-item{display:flex;flex-direction:column;gap:4px}
.stat-n{font-family:var(--display);font-size:clamp(2rem,3.5vw,3rem);line-height:1;color:var(--green)}
.stat-l{font-size:.82rem;color:var(--muted)}

.benef-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.8vw,20px)}
.benef-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-xl);padding:clamp(18px,2.5vw,28px);transition:.25s}
.benef-card:hover{border-color:var(--green);box-shadow:var(--sh-sm)}
@media(max-width:760px){.benef-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.benef-grid{grid-template-columns:1fr}}

.whom-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.8vw,20px)}
.whom-card{background:var(--green-ll);border-radius:var(--r-xl);padding:clamp(18px,2.5vw,28px);display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;transition:.25s}
.whom-card:hover{transform:translateY(-3px)}
@media(max-width:760px){.whom-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.whom-grid{grid-template-columns:1fr}}

.sched-card{background:#fff;border:1.5px solid var(--green);border-radius:var(--r-xl);padding:clamp(20px,3vw,36px);position:relative;overflow:hidden}
.sched-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green),var(--amber))}

.tag-green{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35em .85em;border-radius:999px;background:var(--green-ll);color:var(--green)}
.tag-amber{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.35em .85em;border-radius:999px;background:#FEF3D6;color:#C8952E}

/* ============================================================
   FASE 3·3 — Para empresas (page-empresas.php)
   ============================================================ */
.biz-hero{background:linear-gradient(155deg,#19153A 0%,#2D1F5E 55%,#3E2A7A 100%);min-height:88vh;display:flex;align-items:center;padding-top:74px;overflow:hidden;position:relative}
.biz-hero::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(139,107,232,.18) 0%,transparent 70%);top:-100px;right:-100px;pointer-events:none}
.biz-hero::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(200,149,46,.12) 0%,transparent 70%);bottom:-80px;left:-60px;pointer-events:none}
.biz-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center;position:relative;z-index:1}
.biz-kicker{display:inline-flex;align-items:center;gap:.6em;background:rgba(139,107,232,.22);color:var(--brand-100);font-weight:600;font-size:.79rem;letter-spacing:.08em;padding:.5em 1.1em;border-radius:var(--pill);border:1px solid rgba(139,107,232,.3);margin-bottom:22px}
.biz-h1{font-family:var(--display);font-size:clamp(2.8rem,6vw,5.2rem);line-height:.93;letter-spacing:-.022em;color:#fff}
.biz-h1 em{font-style:italic;color:#C8B8FF}
.biz-sub{font-size:clamp(1rem,1.4vw,1.18rem);color:rgba(255,255,255,.62);max-width:46ch;margin-top:18px;line-height:1.65}
.biz-stats-row{display:flex;gap:clamp(20px,3vw,36px);margin-top:32px;flex-wrap:wrap}
.bstat{text-align:left}
.bstat-n{font-family:var(--display);font-size:clamp(1.7rem,2.8vw,2.5rem);line-height:1;color:#fff}
.bstat-l{font-size:.82rem;color:rgba(255,255,255,.45);margin-top:4px}
.biz-sep{width:1px;background:rgba(255,255,255,.14);align-self:stretch}
@media(max-width:860px){.biz-hero-grid{grid-template-columns:1fr;text-align:center}.biz-sub{margin-inline:auto}.biz-stats-row{justify-content:center}.biz-mascot-wrap{order:-1}}

.problem-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.prob-card{border-radius:var(--r-xl);padding:clamp(22px,3vw,36px);background:#fff;border:1.5px solid var(--line);display:flex;flex-direction:column;gap:14px;transition:transform .3s,box-shadow .3s}
.prob-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.prob-ic{width:52px;height:52px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex:none}
@media(max-width:780px){.problem-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.problem-grid{grid-template-columns:1fr}}

.prog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.prog-card{border-radius:var(--r-xl);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;cursor:pointer}
.prog-card:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.prog-head{padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;gap:12px;flex:1}
.prog-n{font-weight:700;font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;opacity:.6}
.prog-title{font-family:var(--display);font-size:clamp(1.2rem,1.8vw,1.55rem);line-height:1.08}
.prog-text{font-size:.88rem;line-height:1.55;opacity:.62;flex:1}
.prog-tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:auto;padding-top:14px}
.prog-foot{padding:16px clamp(22px,3vw,34px);display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(0,0,0,.08)}
.prog-foot-a{font-weight:600;font-size:.86rem;display:flex;align-items:center;gap:.4em;transition:.18s}
.prog-c1{background:var(--tint);color:var(--ink)}
.prog-c1 .prog-foot{background:rgba(139,107,232,.07)}
.prog-c2{background:#E0F4EC;color:var(--ink)}
.prog-c2 .prog-foot{background:rgba(79,168,138,.1)}
.prog-c3{background:#FBF0D8;color:var(--ink)}
.prog-c3 .prog-foot{background:rgba(200,149,46,.1)}
@media(max-width:780px){.prog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.prog-grid{grid-template-columns:1fr}}

.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,24px)}
.how-step{border-top:2.5px solid var(--ink);padding-top:18px;position:relative}
.how-n{font-family:var(--display);font-size:clamp(2rem,3vw,2.8rem);color:var(--brand);line-height:1;margin-bottom:12px}
.how-title{font-family:var(--display);font-size:clamp(1.1rem,1.6vw,1.38rem);color:var(--ink);margin-bottom:9px}
.how-text{color:var(--muted);font-size:.88rem;line-height:1.58}
@media(max-width:820px){.how-grid{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.how-grid{grid-template-columns:1fr}}

.results-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2vw,22px)}
.res-card{background:var(--ink);color:#fff;border-radius:var(--r-xl);padding:clamp(22px,3vw,36px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}
.res-n{font-family:var(--display);font-size:clamp(2.4rem,4vw,3.6rem);line-height:1;color:#fff}
.res-unit{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px}
.res-label{color:rgba(255,255,255,.62);font-size:.88rem;text-align:center;line-height:1.45}
@media(max-width:780px){.results-grid{grid-template-columns:1fr 1fr}}

.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.test-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-xl);padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;gap:14px}
.test-stars{color:var(--amber);font-size:1rem;letter-spacing:.12em}
.test-q{font-family:var(--display);font-size:clamp(1rem,1.5vw,1.28rem);line-height:1.15;color:var(--ink)}
.test-who{display:flex;align-items:center;gap:12px;margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.test-av{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none}
.test-name{font-weight:600;font-size:.88rem;color:var(--ink)}
.test-role{font-size:.76rem;color:var(--muted)}
@media(max-width:780px){.test-grid{grid-template-columns:1fr}}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:start}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-label{font-size:.84rem;font-weight:600;color:var(--ink-soft)}
.form-input,.form-select,.form-textarea{width:100%;padding:.8em 1.1em;border:1.5px solid var(--line);border-radius:var(--r);font-family:var(--body);font-size:.95rem;color:var(--ink);background:#fff;outline:none;transition:.2s;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(139,107,232,.12)}
.form-textarea{resize:vertical;min-height:110px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}}

/* ============================================================
   FASE 4·1 — Nosotras (page-nosotras.php)
   ============================================================ */
.nos-hero{background:linear-gradient(155deg,#19153A 0%,#2D1F5E 60%,#3E2A7A 100%);min-height:72vh;display:flex;align-items:center;padding-top:74px;position:relative;overflow:hidden}
.nos-hero::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(139,107,232,.15) 0%,transparent 70%);top:-100px;right:-60px}
.nos-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,80px);align-items:center;position:relative;z-index:1}
@media(max-width:860px){.nos-hero-grid{grid-template-columns:1fr;text-align:center}}

.timeline{position:relative;padding-left:32px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--line)}
.tl-item{position:relative;margin-bottom:32px}
.tl-item:last-child{margin-bottom:0}
.tl-dot{position:absolute;left:-28px;top:6px;width:14px;height:14px;border-radius:50%;background:var(--brand);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--brand)}
.tl-year{font-weight:700;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);margin-bottom:4px}
.tl-title{font-family:var(--display);font-size:clamp(1rem,1.5vw,1.3rem);color:var(--ink);margin-bottom:5px}
.tl-text{color:var(--muted);font-size:.88rem;line-height:1.55}

.founder-wrap{display:grid;grid-template-columns:1fr 1.6fr;gap:clamp(36px,5.5vw,76px);align-items:center}
.founder-photo{aspect-ratio:3/4;border-radius:var(--r-xl);overflow:hidden;position:relative}
.founder-photo img{width:100%;height:100%;object-fit:cover;object-position:center top}
.founder-badge{position:absolute;bottom:20px;left:20px;background:rgba(25,21,58,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;border-radius:var(--r-lg);padding:14px 18px;border:1px solid rgba(255,255,255,.12)}
@media(max-width:840px){.founder-wrap{grid-template-columns:1fr}}

.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,22px)}
.team-card{border-radius:var(--r-xl);overflow:hidden;background:#fff;border:1.5px solid var(--line);transition:transform .3s,box-shadow .3s}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--sh)}
.team-photo{height:220px;overflow:hidden;position:relative}
.team-photo img{width:100%;height:100%;object-fit:cover;object-position:top}
.team-astro{position:absolute;bottom:-18px;right:14px;width:54px;height:54px;background:#fff;border-radius:50%;border:2.5px solid var(--line);display:flex;align-items:center;justify-content:center;box-shadow:var(--sh-sm)}
.team-info{padding:clamp(18px,2.5vw,26px);padding-top:26px}
.team-role{font-size:.72rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--brand);margin-bottom:4px}
.team-name{font-family:var(--display);font-size:clamp(1.1rem,1.7vw,1.45rem);color:var(--ink);margin-bottom:8px}
.team-bio{color:var(--muted);font-size:.86rem;line-height:1.55}
.team-specs{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}
@media(max-width:860px){.team-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.team-grid{grid-template-columns:1fr}}

.vals-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(10px,1.5vw,18px)}
.val-card{border-radius:var(--r-xl);padding:clamp(18px,2.5vw,28px) 14px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;transition:.28s}
.val-card:hover{transform:translateY(-4px)}
.val-ic{height:72px;display:flex;align-items:center;justify-content:center}
.val-title{font-family:var(--display);font-size:clamp(.95rem,1.4vw,1.18rem);color:var(--ink);line-height:1.1}
.val-text{font-size:.8rem;color:var(--muted);line-height:1.5}
@media(max-width:860px){.vals-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:480px){.vals-grid{grid-template-columns:1fr 1fr}}

.astro-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.5vw,18px)}
.astro-card{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-xl);padding:clamp(16px,2.2vw,26px) 12px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;transition:.28s}
.astro-card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.astro-char{height:80px;display:flex;align-items:center;justify-content:center}
.astro-name{font-family:var(--display);font-size:clamp(1rem,1.5vw,1.2rem);color:var(--ink)}
.astro-emo{font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.astro-desc{font-size:.8rem;color:var(--muted);line-height:1.45}
.astro-expr{font-family:monospace;font-size:.78rem;opacity:.6}
@media(max-width:480px){.astro-grid{grid-template-columns:1fr 1fr}}

.join-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
@media(max-width:780px){.join-grid{grid-template-columns:1fr}}

/* ============================================================
   FASE 5 — Blog: Diario (home.php) + Artículo (single.php)
   ------------------------------------------------------------
   Paleta corporativa (brand.css). Clases con prefijo blog-/art-
   para no colisionar con los componentes de la Home (.feat, .post…).
   ============================================================ */
.blog-eyebrow{color:var(--muted);font-weight:500;letter-spacing:.18em;font-size:.76rem;text-transform:uppercase}
.blog-eyebrow .ast{color:var(--brand);display:inline-block;width:.9em;height:.9em;vertical-align:-.05em}
.blog-lead{color:var(--muted)}

/* Portada — destacado */
.blog-feat{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,70px);align-items:center;padding-bottom:clamp(40px,5vw,64px);border-bottom:1px solid var(--line);text-decoration:none;color:inherit}
@media(max-width:860px){.blog-feat{grid-template-columns:1fr;gap:28px}}
.blog-feat__media{border-radius:var(--r-lg) var(--r-lg) 0 var(--r-lg);overflow:hidden;aspect-ratio:4/3;position:relative;background:var(--brand-50)}
.blog-feat__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.blog-feat__media::after{content:"";position:absolute;inset:0;background:var(--brand);mix-blend-mode:color;opacity:.75}
.blog-feat__cat{display:inline-flex;align-items:center;gap:.5em;font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--brand);margin-bottom:12px}
.blog-feat__cat .ast{width:.9em;height:.9em}
.blog-feat__t{font-family:var(--display);font-size:clamp(2rem,4vw,3.2rem);line-height:1.0;letter-spacing:-.02em;color:var(--ink);margin-bottom:14px}
.blog-feat__sub{font-size:1.05rem;color:var(--muted);max-width:52ch;margin-bottom:20px}
.blog-feat__by{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.9rem}
.blog-feat__av{width:34px;height:34px;border-radius:50%;overflow:hidden;flex:none;background:var(--brand-50)}
.blog-feat__av img{width:100%;height:100%;object-fit:cover}

/* Pills de categoría */
.cat-pills{display:flex;gap:8px;flex-wrap:wrap;margin-block:clamp(32px,4vw,48px) clamp(24px,3vw,36px)}
.cpill{padding:.6em 1.1em;border-radius:var(--pill);font-weight:600;font-size:.88rem;color:var(--ink-soft);background:#fff;box-shadow:inset 0 0 0 1.4px var(--line-strong);cursor:pointer;transition:.2s;text-decoration:none}
.cpill:hover{color:var(--brand);box-shadow:inset 0 0 0 1.4px var(--brand)}
.cpill[aria-pressed="true"],.cpill.is-current{background:var(--ink);color:#fff;box-shadow:none}

/* Grid de artículos */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,32px)}
@media(max-width:920px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.blog-post{display:flex;flex-direction:column;text-decoration:none;color:inherit}
.blog-post__media{border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/3;position:relative;margin-bottom:18px;background:var(--brand-50)}
.blog-post__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1)}
.blog-post:hover .blog-post__media img{transform:scale(1.05)}
.blog-post__media::after{content:"";position:absolute;inset:0;background:var(--duoc,var(--brand));mix-blend-mode:color;opacity:.75}
.blog-post__cat{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.blog-post__t{font-family:var(--display);font-size:clamp(1.2rem,1.8vw,1.55rem);line-height:1.05;color:var(--ink);margin-bottom:8px;transition:color .2s}
.blog-post:hover .blog-post__t{color:var(--brand)}
.blog-post__meta{font-size:.84rem;color:var(--muted)}
.blog-post__date{font-size:.74rem;color:var(--muted);margin-top:6px}

/* Newsletter del blog */
.blog-nl{background:var(--tint);border-radius:var(--r-lg);padding:clamp(28px,4vw,48px);display:flex;align-items:center;gap:clamp(24px,4vw,56px);flex-wrap:wrap}
.blog-nl>.ast{width:44px;height:44px;color:var(--brand);flex:none}
.blog-nl__form{display:flex;gap:10px;flex:1;min-width:260px;flex-wrap:wrap}
.blog-nl__form input{flex:1;min-width:200px;font:inherit;padding:1em 1.2em;border-radius:var(--pill);border:1.5px solid var(--line-strong);background:#fff}
.blog-nl__form input:focus{outline:none;border-color:var(--brand)}

/* ── Artículo (single) ── */
.art-head{padding-top:clamp(26px,4vw,44px)}
.crumbs{font-size:.86rem;color:var(--muted);margin-bottom:clamp(20px,3vw,30px)}
.crumbs a{color:var(--muted);transition:color .2s}
.crumbs a:hover{color:var(--brand)}
.art-cat{display:inline-flex;align-items:center;gap:.55em;font-weight:700;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
.art-cat .ast{width:.95em;height:.95em}
.art-title{font-family:var(--display);font-weight:400;font-size:clamp(2.3rem,5.2vw,4.1rem);line-height:1.0;letter-spacing:-.02em;color:var(--ink);margin:16px 0 20px;max-width:17ch}
.art-lede{font-size:clamp(1.12rem,1.8vw,1.4rem);line-height:1.5;color:var(--ink-soft);max-width:58ch}
.art-meta{display:flex;align-items:center;gap:14px;margin-top:clamp(24px,3vw,32px);flex-wrap:wrap}
.art-av{width:48px;height:48px;border-radius:50%;overflow:hidden;flex:none;background:var(--brand-50)}
.art-av img{width:100%;height:100%;object-fit:cover}
.art-byline{font-size:.95rem;line-height:1.35}
.art-byline strong{color:var(--ink);font-weight:600}
.art-byline span{color:var(--muted)}
.art-dot{width:4px;height:4px;border-radius:50%;background:var(--line-strong);flex:none}
.art-rt{font-size:.88rem;color:var(--muted)}
.art-hero{position:relative;margin:clamp(30px,4.5vw,54px) 0 0;border-radius:var(--r-xl) var(--r-xl) 0 var(--r-xl);overflow:hidden;aspect-ratio:16/8;background:var(--brand-50)}
.art-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.art-hero::after{content:"";position:absolute;inset:0;background:var(--brand);mix-blend-mode:color;opacity:.55}

.article{max-width:744px;margin-inline:auto}
.prose>p{font-size:1.13rem;line-height:1.78;color:var(--ink-soft);margin-bottom:1.35em}
.prose>p:first-of-type{font-size:1.22rem;color:var(--ink)}
.prose strong{color:var(--ink);font-weight:600}
.prose em{font-style:italic}
.prose h2{font-family:var(--display);font-weight:400;font-size:clamp(1.6rem,2.8vw,2.15rem);line-height:1.08;letter-spacing:-.01em;color:var(--ink);margin:1.75em 0 .5em}
.prose h3{font-family:var(--display);font-weight:400;font-size:clamp(1.3rem,2vw,1.55rem);line-height:1.12;color:var(--ink);margin:1.5em 0 .45em}
.prose ul{list-style:none;padding:0;margin:0 0 1.45em;display:flex;flex-direction:column;gap:.72em}
.prose ul li{position:relative;padding-left:1.9em;color:var(--ink-soft);line-height:1.62}
.prose ul li::before{content:"✳";position:absolute;left:0;top:.05em;color:var(--brand);font-size:1.05em;line-height:1.4}
.prose ul li .ast{position:absolute;left:0;top:.28em;width:1.05em;height:1.05em;color:var(--brand)}
.prose ul li .ast+*{margin-left:0}
.prose a{color:var(--brand);font-weight:600;box-shadow:inset 0 -1.4px 0 rgba(128,79,255,.35);transition:box-shadow .2s}
.prose a:hover{box-shadow:inset 0 -1.4px 0 var(--brand)}
.pullquote{font-family:var(--display);font-weight:400;font-size:clamp(1.55rem,2.8vw,2.1rem);line-height:1.18;letter-spacing:-.01em;color:var(--ink);margin:1.5em 0;padding:.1em 0 .1em 28px;border-left:3px solid var(--brand)}
figure.art-fig{margin:1.9em 0}
figure.art-fig img{border-radius:var(--r-lg);width:100%;display:block}
figure.art-fig figcaption{font-size:.84rem;color:var(--muted);margin-top:11px;text-align:center}
.callout{display:flex;gap:18px;align-items:flex-start;background:var(--tint);border-radius:var(--r-lg);padding:clamp(24px,3vw,34px);margin:2em 0}
.callout .ast{width:34px;height:34px;flex:none;color:var(--brand)}
.callout h3{font-family:var(--display);font-weight:400;font-size:1.35rem;color:var(--ink);margin-bottom:8px;line-height:1.1}
.callout p{color:var(--ink-soft);line-height:1.6;margin-bottom:16px}
.art-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:2.4em;padding-top:24px;border-top:1px solid var(--line)}
.art-tags{display:flex;gap:8px;flex-wrap:wrap}
.art-share{display:flex;align-items:center;gap:10px}
.art-share span{font-size:.84rem;color:var(--muted)}
.shb{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:inset 0 0 0 1.4px var(--line-strong);transition:.2s}
.shb:hover{color:var(--brand);box-shadow:inset 0 0 0 1.4px var(--brand)}
.shb svg{width:17px;height:17px}
.author-card{display:flex;gap:20px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,2.6vw,30px);margin-top:2.4em;box-shadow:var(--sh-sm)}
.author-card__av{width:78px;height:78px;border-radius:50%;overflow:hidden;flex:none;background:var(--brand-50)}
.author-card__av img{width:100%;height:100%;object-fit:cover}
.author-card h4{font-family:var(--display);font-weight:400;font-size:1.4rem;color:var(--ink);margin-bottom:4px}
.author-card .role{font-size:.82rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin-bottom:8px}
.author-card p{color:var(--muted);line-height:1.55;font-size:.96rem}
.rel-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:clamp(22px,3vw,34px)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2.4vw,32px)}
@media(max-width:920px){.grid3{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid3{grid-template-columns:1fr}}

/* ============================================================
   FASE 6 — WooCommerce: Tienda + Carrito
   ------------------------------------------------------------
   Todo scopeado bajo .shop (lo añaden las plantillas Woo) para no
   colisionar con .feat/.stat-n/.prod de otras páginas. Paleta corporativa.
   ============================================================ */
.shop .t-hero{font-size:clamp(2.6rem,6vw,4.6rem);line-height:1.0;letter-spacing:-.025em}
.shop .eyebrow,.shop .blog-eyebrow{color:var(--muted);font-weight:500;letter-spacing:.18em;font-size:.76rem;text-transform:uppercase}
.shop .crumbs{font-size:.86rem;color:var(--muted)}
.shop .crumbs a:hover{color:var(--brand)}

/* Duotono de marca */
.shop .duo{position:relative;overflow:hidden;background:var(--duo,#804FFF)}
.shop .duo>img{width:100%;height:100%;object-fit:cover;display:block}
.shop .duo::after{content:"";position:absolute;inset:0;background:var(--duo,#804FFF);mix-blend-mode:color;opacity:.9;pointer-events:none}
.shop .duo::before{content:"";position:absolute;inset:0;z-index:2;background:var(--duo,#804FFF);opacity:.16;pointer-events:none}

/* Cabecera/hero tienda */
.shop-head{padding-top:clamp(28px,4vw,52px)}
.shop-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,72px);align-items:center}
@media(max-width:900px){.shop-hero-grid{grid-template-columns:1fr;gap:34px}}
.shop .hk{display:inline-flex;align-items:center;gap:.6em;background:var(--brand-50);color:var(--brand);font-weight:600;font-size:.79rem;letter-spacing:.07em;padding:.5em 1.1em;border-radius:var(--pill);border:1px solid var(--brand-100);margin-bottom:18px}
.shop .hk .ast{width:.85em;height:.85em}
.shop-hero-grid h1{font-family:var(--display);font-weight:400;font-size:clamp(2.8rem,6vw,5rem);line-height:.94;letter-spacing:-.022em;color:var(--ink);margin-bottom:18px}
.shop-hero-grid h1 em{font-style:italic;color:var(--brand)}
.shop-hero-grid .sub{font-size:clamp(1rem,1.4vw,1.18rem);color:var(--ink-soft);max-width:46ch;line-height:1.65;margin-bottom:26px}
.shop .hero-ctas{display:flex;gap:11px;flex-wrap:wrap;margin-bottom:clamp(24px,3vw,32px)}
.shop .stat-row{display:flex;align-items:stretch;gap:clamp(16px,2.4vw,28px)}
.shop .stat-row>div:not(.stat-sep){display:flex;flex-direction:column}
.shop .stat-n{font-family:var(--display);font-weight:400;font-size:clamp(1.8rem,3vw,2.4rem);line-height:1;color:var(--ink)}
.shop .stat-l{font-size:.8rem;color:var(--muted);margin-top:5px;max-width:15ch}
.shop .stat-sep{width:1px;background:var(--line-strong)}
.shop .hero-visual{position:relative}
.shop .hero-visual .frame{position:relative;border-radius:var(--r-xl) var(--r-xl) 0 var(--r-xl);overflow:hidden;aspect-ratio:4/3}
.shop .hero-visual .frame img{width:100%;height:100%;object-fit:cover}
.shop .hero-badge{position:absolute;left:clamp(14px,2vw,20px);right:clamp(14px,2vw,20px);bottom:clamp(14px,2vw,20px);background:#fff;border-radius:var(--r-lg);padding:15px 18px;box-shadow:var(--sh);display:flex;align-items:center;gap:14px}
.shop .hero-badge .ic{width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}

/* Destacado */
.shop-feat{position:relative;border-radius:var(--r-xl);overflow:hidden;color:#fff;min-height:clamp(380px,46vw,460px);display:flex;text-decoration:none}
.shop-feat .duo{position:absolute;inset:0}
.shop-feat__in{position:relative;z-index:4;padding:clamp(28px,4vw,56px);display:flex;flex-direction:column;justify-content:flex-end;gap:18px;max-width:640px}
.shop-feat__tags{display:flex;gap:10px;flex-wrap:wrap}
.shop .badge{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.78rem;padding:.5em .9em;border-radius:var(--pill);background:rgba(255,255,255,.18);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.shop .badge--solid{background:#fff;color:var(--brand)}
.shop-feat h2{color:#fff;font-family:var(--display);font-size:clamp(2.1rem,4vw,3.4rem);line-height:.98}
.shop-feat .meta{display:flex;gap:22px;flex-wrap:wrap;color:rgba(255,255,255,.9);font-size:.95rem}
.shop-feat .buy{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:6px}
.shop-feat .price{font-family:var(--display);font-size:2.2rem}
.shop-feat .price s{opacity:.6;font-size:1.3rem;margin-left:8px}

/* Filtros */
.shop .filters{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-block:clamp(28px,4vw,44px) clamp(22px,3vw,32px)}
.shop .fpill{padding:.62em 1.15em;border-radius:var(--pill);font-weight:600;font-size:.92rem;color:var(--ink-soft);background:#fff;box-shadow:inset 0 0 0 1.4px var(--line-strong);cursor:pointer;transition:.2s;text-decoration:none}
.shop .fpill:hover{color:var(--brand);box-shadow:inset 0 0 0 1.4px var(--brand)}
.shop .fpill[aria-pressed="true"],.shop .fpill.is-current{background:var(--ink);color:#fff;box-shadow:none}
.shop .fcount{margin-left:auto;color:var(--muted);font-size:.9rem}

/* Rejilla de productos */
.shop .cat,.shop ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px);list-style:none;margin:0;padding:0}
@media(max-width:920px){.shop .cat,.shop ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.shop .cat,.shop ul.products{grid-template-columns:1fr;max-width:420px;margin-inline:auto}}
.shop .prod{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .3s cubic-bezier(.2,.8,.2,1),box-shadow .3s;text-decoration:none;color:inherit}
.shop .prod:hover{transform:translateY(-6px);box-shadow:var(--sh)}
.shop .prod__media{position:relative;aspect-ratio:4/3}
.shop .prod__media .duo{position:absolute;inset:0}
.shop .prod__cat{position:absolute;z-index:4;top:14px;left:14px;font-weight:600;font-size:.74rem;letter-spacing:.04em;padding:.45em .85em;border-radius:var(--pill);background:rgba(255,255,255,.92);color:var(--ink);white-space:nowrap}
.shop .prod__fmt{position:absolute;z-index:4;top:14px;right:14px;font-weight:600;font-size:.7rem;padding:.42em .8em;border-radius:var(--pill);background:rgba(0,0,0,.32);color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap}
.shop .prod__bd{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.shop .prod__bd h3{font-family:var(--display);font-size:1.35rem;line-height:1.05;margin-bottom:8px}
.shop .prod__meta{color:var(--muted);font-size:.9rem;margin-bottom:18px}
.shop .prod__foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px}
.shop .prod__price{font-family:var(--display);font-size:1.5rem;color:var(--ink);white-space:nowrap}
.shop .prod__price small,.shop .prod__price .woocommerce-Price-currencySymbol{font-family:var(--body);font-size:.78rem;color:var(--muted);font-weight:500}
.shop .prod__price del{opacity:.5;font-size:1rem;margin-right:6px}
.shop .prod__add{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:.9rem;color:#fff;background:var(--brand);padding:.66em 1em;border-radius:var(--pill);transition:.2s;white-space:nowrap}
.shop .prod:hover .prod__add{background:var(--brand-700)}

/* Franja FUNDAE */
.shop .strip{background:var(--tint);border-radius:var(--r-lg);padding:clamp(24px,3vw,40px);display:flex;align-items:center;gap:clamp(20px,3vw,40px);flex-wrap:wrap}
.shop .strip .ast{width:46px;height:46px;color:var(--brand);flex:none}
.shop .strip h3{font-family:var(--display);font-size:clamp(1.4rem,2vw,1.9rem);margin-bottom:6px}
.shop .strip p{color:var(--muted);max-width:60ch}

/* ── Carrito ── */
.shop .steps{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:.85rem;margin-bottom:clamp(26px,3vw,40px)}
.shop .steps b{color:var(--brand)}
.shop .steps .sep{width:24px;height:1px;background:var(--line-strong)}
.shop .layout{display:grid;grid-template-columns:1.6fr .9fr;gap:clamp(24px,3vw,44px);align-items:start}
@media(max-width:900px){.shop .layout{grid-template-columns:1fr}}
.shop .item{display:grid;grid-template-columns:96px 1fr auto;gap:18px;padding:20px 0;border-bottom:1px solid var(--line);align-items:center}
.shop .item__media{width:96px;height:96px;border-radius:var(--r);overflow:hidden;position:relative;background:var(--brand-50)}
.shop .item__media .duo{position:absolute;inset:0}
.shop .item__t{font-family:var(--display);font-size:1.18rem;line-height:1.05;margin-bottom:4px}
.shop .item__cat{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--brand);margin-bottom:6px}
.shop .item__m{color:var(--muted);font-size:.86rem}
.shop .item__right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.shop .qty input{width:64px;text-align:center;font:inherit;font-weight:600;padding:.5em;border:1.5px solid var(--line-strong);border-radius:var(--pill)}
.shop .item__price{font-family:var(--display);font-size:1.3rem;white-space:nowrap}
.shop .item__rm{font-size:.8rem;color:var(--muted);text-decoration:underline}
.shop .item__rm:hover{color:var(--orange)}
@media(max-width:520px){.shop .item{grid-template-columns:72px 1fr;grid-template-rows:auto auto}.shop .item__media{width:72px;height:72px}.shop .item__right{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center}}
.shop .empty{text-align:center;padding:60px 0;color:var(--muted)}
.shop .empty .ast{width:46px;height:46px;color:var(--brand);opacity:.5}
.shop .summary{border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(22px,2.4vw,30px);box-shadow:var(--sh-sm);position:sticky;top:96px}
.shop .sumline{display:flex;justify-content:space-between;gap:12px;margin-bottom:12px;color:var(--ink-soft)}
.shop .sumtotal{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);margin-top:8px;padding-top:16px}
.shop .sumtotal .big{font-family:var(--display);font-size:2rem}
.shop .promo{display:flex;gap:8px;margin:16px 0}
.shop .promo input{flex:1;font:inherit;padding:.7em .9em;border:1.5px solid var(--line-strong);border-radius:var(--r-sm)}
.shop .promo input:focus{outline:none;border-color:var(--brand)}
.shop .promo button{padding:.7em 1.1em;border-radius:var(--r-sm);background:var(--ink);color:#fff;font-weight:600;font-size:.9rem}
.shop .promo button:hover{background:#000}
.shop .note{display:flex;gap:9px;align-items:flex-start;color:var(--muted);font-size:.84rem;margin-top:14px}
.shop .note .ast{width:15px;height:15px;color:var(--brand);flex:none;margin-top:3px}
.shop .trust{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:.82rem;margin-top:18px;justify-content:center}
