/* =================================================================
   Psicología Interactiva — sistema de diseño v2
   Paleta: verde petróleo + blanco + arena suave
   Tipografía: Plus Jakarta Sans (display+body) — moderna, geométrica,
   limpia. Mismo espíritu que Reguera/VrainStudio.
   Construido por VrainStudio.
   ================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,500&display=swap');

:root{
  --paper:#F6F9FB;
  --paper-2:#E5F0F6;
  --card:#FFFFFF;
  --ink:#1C2B33;
  --ink-soft:#516670;
  --line:#D5E3EC;
  --teal:#1F5970;
  --teal-deep:#164456;
  --teal-soft:#E5F3FB;
  --sage:#47B6E2;
  --gold:#5B93A8;
  --wa:#25D366;
  --shadow:0 20px 44px -22px rgba(26,36,32,.38);
  --radius:16px;
  --radius-s:10px;
  --maxw:1120px;
  --space:clamp(60px,8vw,110px);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:"Plus Jakarta Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:clamp(15.5px,1.05vw,17.5px);line-height:1.68;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal-deep);text-decoration-thickness:1px;text-underline-offset:3px}

h1,h2,h3,h4{
  font-family:"Plus Jakarta Sans",sans-serif;
  font-weight:700;line-height:1.1;color:var(--ink);
  letter-spacing:-.025em;margin:0 0 .4em
}
h1{font-size:clamp(2.2rem,5.2vw,3.8rem);font-weight:800;letter-spacing:-.035em}
h2{font-size:clamp(1.75rem,3.4vw,2.6rem);font-weight:700}
h3{font-size:clamp(1.15rem,1.9vw,1.45rem);font-weight:700}
p{margin:0 0 1.1em}

.wrap{width:min(100% - 40px,var(--maxw));margin-inline:auto}
.narrow{width:min(100% - 40px,760px);margin-inline:auto}
section{padding-block:var(--space)}

.eyebrow{
  font-family:"Plus Jakarta Sans";font-weight:700;text-transform:uppercase;
  letter-spacing:.18em;font-size:.68rem;color:var(--teal);
  margin:0 0 .9em;display:flex;align-items:center;gap:.6em
}
.eyebrow::before{content:"";width:22px;height:1.5px;background:var(--sage)}
.lead{font-size:clamp(1.05rem,1.6vw,1.28rem);color:var(--ink-soft);line-height:1.62;font-weight:400}

/* ---------- enlace de salto ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--teal);color:#fff;
  padding:10px 16px;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* ---------- header ---------- */
.site-head{position:sticky;top:0;z-index:100;
  background:rgba(247,245,242,.88);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:20px;padding-block:13px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;
  color:var(--ink);font-family:"Plus Jakarta Sans";font-size:1.08rem;
  font-weight:800;letter-spacing:-.02em;margin-right:auto}
.brand img{width:36px;height:auto}
.brand span small{display:block;font-weight:500;font-size:.6rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--teal);margin-top:1px}
.menu{display:flex;gap:4px;list-style:none;margin:0;padding:0}
.menu a{display:inline-block;padding:8px 13px;border-radius:8px;text-decoration:none;
  color:var(--ink-soft);font-weight:600;font-size:.88rem;transition:background .18s,color .18s}
.menu a:hover,.menu a[aria-current="page"]{background:var(--teal-soft);color:var(--teal-deep)}
.nav-toggle{display:none;background:none;border:1px solid var(--line);
  border-radius:9px;width:44px;height:40px;cursor:pointer;
  align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{
  content:"";display:block;width:19px;height:1.5px;background:var(--ink);
  position:relative;transition:.25s}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}

/* ---------- botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;border:0;cursor:pointer;
  font-family:"Plus Jakarta Sans";font-weight:700;font-size:.92rem;text-decoration:none;
  padding:13px 24px;border-radius:999px;
  transition:transform .18s var(--ease),box-shadow .2s,background .2s;line-height:1}
.btn svg{width:18px;height:18px;flex:none}
.btn-primary{background:var(--teal);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:var(--teal-deep);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--teal-deep);border:1.5px solid var(--sage)}
.btn-ghost:hover{background:var(--teal-soft)}
.btn-lg{padding:15px 28px;font-size:1rem}
.cta-row{display:flex;flex-wrap:wrap;gap:12px}

/* ---------- hero ---------- */
.hero{position:relative;padding-top:clamp(44px,6.5vw,86px);
  padding-bottom:var(--space);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .9fr;
  gap:clamp(28px,5vw,66px);align-items:center}
.hero-copy{position:relative;z-index:2}
.hero h1{margin-bottom:.22em}
.hero h1 em{font-style:italic;color:var(--teal);font-weight:700}
.hero .sub{font-size:clamp(1rem,1.7vw,1.22rem);color:var(--ink-soft);
  max-width:32ch;margin-bottom:1.5em;font-weight:400}
.hero-meta{display:flex;flex-wrap:wrap;gap:8px 20px;margin-top:1.5em;
  font-size:.86rem;color:var(--ink-soft)}
.hero-meta b{color:var(--ink);font-weight:700}
.hero-figure{position:relative}
.hero-figure img{border-radius:var(--radius);box-shadow:var(--shadow);
  aspect-ratio:4/5;object-fit:cover;width:100%}
.hero-badge{position:absolute;left:-14px;bottom:22px;background:var(--card);
  border:1px solid var(--line);border-radius:12px;padding:11px 15px;
  box-shadow:var(--shadow);max-width:205px}
.hero-badge .stars{color:var(--gold);font-size:.9rem;letter-spacing:2px}
.hero-badge small{display:block;color:var(--ink-soft);font-size:.76rem;margin-top:2px}
.breath{position:absolute;z-index:0;top:-60px;right:-40px;
  width:min(54vw,520px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(71,182,226,.28),rgba(71,182,226,0) 70%);
  animation:breathe 12s var(--ease) infinite;pointer-events:none}
@keyframes breathe{
  0%,100%{transform:scale(.8);opacity:.5}
  48%{transform:scale(1.06);opacity:.82}
}

/* ---------- franja de confianza ---------- */
.trust{background:var(--teal);color:#fff}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust .num{font-family:"Plus Jakarta Sans";font-size:clamp(1.9rem,3vw,2.6rem);
  font-weight:800;line-height:1;margin-bottom:.2em;color:#fff}
.trust .num .g{color:#C0DFED}
.trust p{color:rgba(255,255,255,.78);font-size:.86rem;margin:0}
.trust .stars{color:#C0DFED;letter-spacing:2px}

/* ---------- bloques genéricos ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(26px,5vw,60px);align-items:center}
.split.alt{direction:rtl}.split.alt>*{direction:ltr}
.split img{border-radius:var(--radius);box-shadow:var(--shadow);
  width:100%;object-fit:cover}
.band{background:var(--paper-2)}
.center{text-align:center;max-width:680px;margin-inline:auto}

/* precios */
.prices{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2.2em}
.price{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:26px 24px}
.price h3{margin-bottom:.1em}
.price .amount{font-family:"Plus Jakarta Sans";font-size:2.3rem;
  font-weight:800;color:var(--teal-deep);line-height:1}
.price .amount span{font-size:.95rem;color:var(--ink-soft);font-weight:400}
.price .when{color:var(--ink-soft);font-size:.88rem}

/* servicios */
.svc-list{display:grid;gap:16px;margin-top:2em}
.svc{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px 26px}
.svc .idx{font-family:"Plus Jakarta Sans";font-size:1.5rem;font-weight:800;
  color:var(--sage);line-height:1}
.svc h3{margin-bottom:.28em}
.svc ul{margin:.5em 0 0;padding-left:1.1em;color:var(--ink-soft);columns:2;gap:22px}
.svc.single ul{columns:1}

/* lista síntomas */
.symptoms{display:grid;grid-template-columns:repeat(2,1fr);
  gap:12px;margin:1.5em 0 1.9em;list-style:none;padding:0}
.symptoms li{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius-s);padding:14px 16px 14px 42px;
  position:relative;color:var(--ink-soft);font-size:.95rem}
.symptoms li::before{content:"";position:absolute;left:15px;top:20px;
  width:12px;height:12px;border-radius:50%;border:2px solid var(--sage)}

/* propuesta única */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:2em}
.feat{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:24px}
.feat .ico{width:40px;height:40px;border-radius:10px;
  background:var(--teal-soft);color:var(--teal-deep);
  display:flex;align-items:center;justify-content:center;margin-bottom:13px}
.feat .ico svg{width:20px;height:20px}

/* proceso */
.steps{display:grid;grid-template-columns:repeat(4,1fr);
  gap:16px;margin-top:2em;counter-reset:s}
.step{position:relative;padding-top:42px}
.step::before{counter-increment:s;content:"0" counter(s);
  position:absolute;top:0;left:0;
  font-family:"Plus Jakarta Sans";font-size:1.45rem;
  font-weight:800;color:var(--gold)}
.step h3{font-size:1.08rem}

/* testimonios */
.quotes{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:2em}
.quote{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px}
.quote p{font-style:italic;font-size:1.08rem;color:var(--ink);
  line-height:1.5;font-weight:400}
.quote .who{font-style:normal;font-weight:700;font-size:.82rem;
  color:var(--teal);margin-top:.9em}
.quote .stars{color:var(--gold);letter-spacing:2px;font-size:.88rem}

/* FAQ */
.faq{max-width:780px;margin-inline:auto}
.faq details{border-bottom:1px solid var(--line);padding:4px 0}
.faq summary{cursor:pointer;list-style:none;padding:15px 0;
  font-family:"Plus Jakarta Sans";font-size:1.08rem;font-weight:600;
  display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--teal);font-size:1.4rem;
  transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft);padding-bottom:12px;margin:0}

/* CTA final */
.cta-final{background:var(--teal);color:#fff;text-align:center}
.cta-final h2{color:#fff}
.cta-final p{color:rgba(255,255,255,.82);max-width:540px;margin-inline:auto}
.cta-final .btn-primary{background:#fff;color:var(--teal-deep)}
.cta-final .btn-primary:hover{background:var(--paper)}

/* ---------- blog / artículos ---------- */
.post-head{padding-top:clamp(38px,5.5vw,68px);padding-bottom:0}
.post-meta{display:flex;gap:12px;align-items:center;
  color:var(--ink-soft);font-size:.86rem;margin-bottom:1.3em}
.tag{background:var(--teal-soft);color:var(--teal-deep);font-weight:700;
  font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;
  padding:4px 10px;border-radius:999px;text-decoration:none}
.post-hero-img{border-radius:var(--radius);box-shadow:var(--shadow);
  margin:1.4em 0;aspect-ratio:16/9;object-fit:cover;width:100%}
.article{font-size:1.04rem}
.article h2{margin-top:1.55em}
.article h3,.article h4{margin-top:1.35em}
.article ul,.article ol{padding-left:1.3em;margin-bottom:1.2em}
.article li{margin-bottom:.5em}
.article figure{margin:1.7em 0}
.article figcaption{font-size:.85rem;color:var(--ink-soft);
  font-style:italic;text-align:center;margin-top:.5em}
.article .note{background:var(--teal-soft);border-left:3px solid var(--teal);
  border-radius:0 10px 10px 0;padding:16px 20px;margin:1.5em 0}
.post-cta{background:var(--paper-2);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px;text-align:center;margin:2.2em 0}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:2.2em}
.card{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .2s var(--ease),box-shadow .2s}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card img{aspect-ratio:16/10;object-fit:cover}
.card .body{padding:20px 22px;display:flex;flex-direction:column;gap:7px;flex:1}
.card h3{font-size:1.12rem;margin:0}
.card a.title{text-decoration:none;color:var(--ink)}
.card a.title:hover{color:var(--teal)}
.card .excerpt{color:var(--ink-soft);font-size:.92rem;flex:1}
.post-nav{display:flex;justify-content:space-between;gap:12px;
  border-top:1px solid var(--line);margin-top:2.2em;
  padding-top:1.5em;font-size:.9rem}

/* ---------- contacto ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;
  gap:clamp(28px,5vw,58px);align-items:start}
.info-list{list-style:none;padding:0;margin:0 0 1.7em;display:grid;gap:16px}
.info-list li{display:flex;gap:13px;align-items:flex-start}
.info-list .ico{width:40px;height:40px;border-radius:10px;
  background:var(--teal-soft);color:var(--teal-deep);
  display:flex;align-items:center;justify-content:center;flex:none}
.info-list .ico svg{width:19px;height:19px}
.info-list b{display:block;font-weight:700}
.info-list a{color:var(--ink);text-decoration:none}
.info-list a:hover{color:var(--teal)}
form.lead{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px}
.field{margin-bottom:14px}
.field label{display:block;font-weight:600;font-size:.88rem;margin-bottom:5px}
.field input,.field textarea,.field select{width:100%;padding:12px 14px;
  border:1px solid var(--line);border-radius:9px;
  font:inherit;background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:2px solid var(--sage);border-color:transparent}
.field textarea{min-height:115px;resize:vertical}
.consent{display:flex;gap:9px;font-size:.82rem;
  color:var(--ink-soft);align-items:flex-start}
.consent input{width:auto;margin-top:4px}
.form-msg{margin-top:12px;font-size:.88rem;font-weight:700;min-height:1.2em}
.map-embed{margin-top:1.7em;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);aspect-ratio:16/10}
.map-embed iframe{width:100%;height:100%;border:0}

/* ---------- footer ---------- */
.site-foot{background:var(--ink);color:#bfc9c4;padding-block:56px 28px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
.site-foot h4{color:#fff;font-family:"Plus Jakarta Sans";font-weight:700;
  font-size:.76rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:1em}
.site-foot a{color:#bfc9c4;text-decoration:none}
.site-foot a:hover{color:#fff}
.site-foot ul{list-style:none;padding:0;margin:0;display:grid;gap:9px;font-size:.92rem}
.foot-brand p{color:#8a9792;font-size:.9rem;max-width:34ch}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:20px;
  display:flex;justify-content:space-between;flex-wrap:wrap;
  gap:10px;font-size:.8rem;color:#6e817a}
.foot-bottom a{color:#6e817a}

/* ---------- WhatsApp flotante ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:120;
  display:flex;align-items:center;gap:0;
  background:var(--wa);color:#fff;border-radius:999px;padding:13px;
  box-shadow:0 10px 28px -8px rgba(0,0,0,.4);
  text-decoration:none;font-weight:700;
  transition:padding .25s var(--ease),transform .2s}
.wa-float svg{width:24px;height:24px;flex:none}
.wa-float .lbl{max-width:0;overflow:hidden;white-space:nowrap;
  transition:max-width .3s var(--ease),margin .3s}
.wa-float:hover{transform:translateY(-2px)}
.wa-float:hover .lbl{max-width:160px;margin-left:9px;margin-right:5px}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .nav-toggle{display:inline-flex}
  .menu{position:fixed;inset:62px 0 auto 0;background:var(--paper);
    flex-direction:column;gap:0;padding:8px 18px 22px;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .3s var(--ease)}
  .menu.open{transform:translateY(0)}
  .menu li{width:100%}
  .menu a{display:block;padding:13px 11px;border-radius:8px}
  .nav .btn{display:none}
  .hero-grid,.split,.contact-grid{grid-template-columns:1fr}
  .split.alt{direction:ltr}
  .hero-figure{order:-1;max-width:360px}
  .trust .wrap{grid-template-columns:1fr 1fr;gap:28px 14px}
  .prices,.feats,.steps,.quotes,.blog-grid{grid-template-columns:1fr}
  .symptoms{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr}
  .svc ul{columns:1}
  .foot-grid{grid-template-columns:1fr;gap:26px}
  .breath{opacity:.4;right:-30%}
}
@media (max-width:520px){
  .trust .wrap{grid-template-columns:1fr 1fr}
  .hero-badge{position:static;margin-top:14px;max-width:none}
}

/* accesibilidad */
:focus-visible{outline:2px solid var(--sage);outline-offset:2px;border-radius:5px}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ---------- Banner de cookies (afable, RGPD + Consent Mode) ---------- */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:200;
  max-width:560px;margin-inline:auto;
  background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:0 24px 60px -18px rgba(28,43,51,.45);
  padding:24px 26px;
  transform:translateY(140%);opacity:0;
  transition:transform .5s var(--ease),opacity .4s;
}
.cookie-banner.show{transform:translateY(0);opacity:1}
.cookie-banner h3{font-size:1.12rem;margin:0 0 .5em;display:flex;align-items:center;gap:.5em}
.cookie-banner h3 .leaf{width:22px;height:22px;color:var(--sage);flex:none}
.cookie-banner p{font-size:.92rem;color:var(--ink-soft);margin:0 0 1.1em;line-height:1.6}
.cookie-banner .cookie-actions{display:flex;flex-wrap:wrap;gap:10px}
.cookie-banner .btn{font-size:.88rem;padding:11px 20px}
.cookie-banner .btn-text{background:none;border:0;color:var(--ink-soft);
  text-decoration:underline;text-underline-offset:3px;cursor:pointer;
  font-family:inherit;font-weight:600;font-size:.85rem;padding:11px 8px}
.cookie-banner .btn-text:hover{color:var(--teal)}
.cookie-banner .cookie-links{margin-top:.9em;font-size:.78rem}
.cookie-banner .cookie-links a{color:var(--ink-soft);text-decoration:underline}
/* Panel de configuración */
.cookie-config{display:none;margin:0 0 1.1em;border-top:1px solid var(--line);padding-top:14px}
.cookie-banner.configuring .cookie-config{display:block}
.cookie-banner.configuring .cookie-intro{display:none}
.cookie-opt{display:flex;gap:11px;align-items:flex-start;padding:9px 0}
.cookie-opt input{width:auto;margin-top:3px;accent-color:var(--teal)}
.cookie-opt label{font-size:.86rem}
.cookie-opt label b{display:block;color:var(--ink);font-weight:700;margin-bottom:1px}
.cookie-opt label span{color:var(--ink-soft)}
.cookie-opt input:disabled+label b::after{content:" · siempre activas";
  font-weight:400;color:var(--sage);font-size:.78rem}
@media (max-width:520px){
  .cookie-banner{padding:20px;left:10px;right:10px;bottom:10px}
  .cookie-banner .cookie-actions{flex-direction:column}
  .cookie-banner .cookie-actions .btn{width:100%;justify-content:center}
}
