/* ============================================================
   NEUROMENTE — Home rediseñada
   Tipografía: Bricolage Grotesque (display) + IBM Plex Sans (texto)
   Paleta de marca conservada (verde, teal, coral, amarillo)
   ============================================================ */

:root{
  /* Marca — paleta pastel de 4 colores (teal · coral · azul · amarillo) */
  /* Rampa principal = TEAL (también ancla oscura para texto y secciones) */
  --green-900:#15454A; --green-800:#1B5C62; --green-700:#21757C; --green-600:#37A6AC;
  --green-500:#5BC4C4; --green-100:#DBF0F0; --green-50:#EDF8F8;
  /* "teal-*" reutilizado como AZUL suave (categoría Servicios) */
  --teal-700:#3A6FA5; --teal-600:#5E9BD6; --teal-100:#E3EDF8;
  /* Coral (Pacientes) */
  --coral-600:#E8645A; --coral-100:#FBE3DF;
  /* Amarillo (Instalaciones) */
  --yellow-500:#F2CB45; --yellow-100:#FDF3CF;

  /* Acento (compat. retro): ahora apunta al amarillo de la paleta */
  --gold:#F2CB45; --gold-deep:#E0B42E; --ink-on-gold:#2B2410;

  /* Tinta y fondos fríos suaves */
  --ink:#14292B; --fg-1:#1C3133; --fg-2:#4C5F61; --fg-3:#7C8F90;
  --bg:#FBFDFD; --bg-2:#EFF6F6; --bg-tint:#EAF5F5;
  --border:#DDE9E8; --border-strong:#C2D5D4;

  --shadow-sm:0 1px 2px rgba(20,50,52,.05), 0 4px 14px rgba(20,50,52,.06);
  --shadow-md:0 10px 30px rgba(20,50,52,.09);
  --shadow-lg:0 28px 64px rgba(20,50,52,.14);
  --shadow-green:0 12px 28px rgba(33,117,124,.26);

  --maxw:1180px;
  --r-lg:30px; --r-md:22px; --r-sm:16px;

  --font-display:"Bricolage Grotesque", "Segoe UI", system-ui, sans-serif;
  --font-body:"IBM Plex Sans", system-ui, -apple-system, sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--fg-1);
  font-family:var(--font-body); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{display:block; max-width:100%}
a{text-decoration:none; color:inherit}
.container{max-width:var(--maxw); margin:0 auto; padding:0 24px}

h1,h2,h3,h4{font-family:var(--font-display); font-weight:700; color:var(--green-900); margin:0; letter-spacing:-.02em; line-height:1.08}
h1{font-size:clamp(2.6rem,5.2vw,4.3rem); letter-spacing:-.035em}
h2{font-size:clamp(1.95rem,3.2vw,2.7rem)}
h3{font-size:1.3rem; line-height:1.2}
p{margin:0; color:var(--fg-2)}
.lead{font-size:clamp(1.05rem,1.7vw,1.22rem); color:var(--fg-2); max-width:600px}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  border-radius:999px; border:0; padding:15px 26px; cursor:pointer;
  font-family:var(--font-body); font-weight:600; font-size:16px;
  background:var(--green-700); color:#fff; box-shadow:var(--shadow-green);
  transition:transform .18s ease, background .18s ease, box-shadow .18s ease;
}
.btn:hover{background:var(--green-800); transform:translateY(-2px)}
.btn svg{width:19px; height:19px}
.btn-outline{background:#fff; color:var(--green-700); border:1.5px solid var(--border-strong); box-shadow:none}
.btn-outline:hover{background:var(--green-50); border-color:var(--green-600); transform:translateY(-2px)}
.btn-soft{background:var(--green-50); color:var(--green-800); border:1.5px solid var(--border); box-shadow:none}
.btn-soft:hover{background:var(--green-100); color:var(--green-900)}
.btn-wa{background:#1FAF52; color:#fff; box-shadow:0 12px 28px rgba(31,175,82,.28)}
.btn-wa:hover{background:#178c42}

/* ---------- Eyebrow / kicker ---------- */
.eyebrow,.kicker{
  font-family:var(--font-body); font-weight:600; font-size:13px;
  text-transform:uppercase; letter-spacing:.16em; color:var(--green-700);
}
.kicker{color:var(--green-700)}

/* ---------- Header ---------- */
.header-wrap{position:sticky; top:0; z-index:50; padding:14px 0 0;
  background:linear-gradient(180deg, rgba(252,253,252,.92), rgba(252,253,252,.4) 78%, transparent);
  backdrop-filter:blur(10px)}
.header{
  min-height:80px; border:1px solid var(--border); border-radius:var(--r-md);
  background:rgba(255,255,255,.94); box-shadow:var(--shadow-sm);
  display:flex; align-items:center; justify-content:space-between; padding:12px 22px; gap:24px}
.logo{height:46px; width:auto}
.nav{display:flex; align-items:center; gap:28px; font-weight:500; color:var(--fg-2); font-size:15.5px}
.nav a{position:relative; padding:4px 0; transition:color .15s}
.nav a:after{content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px; background:var(--green-600); transition:right .22s ease}
.nav a:hover{color:var(--green-800)}
.nav a:hover:after{right:0}

.mobile-menu{display:none; margin-top:10px}
.mobile-menu details{background:#fff; border:1px solid var(--border); border-radius:var(--r-md); padding:12px 16px; box-shadow:var(--shadow-sm)}
.mobile-menu summary{font-weight:700; color:var(--green-800); cursor:pointer; font-family:var(--font-display)}
.mobile-menu a{display:block; padding:13px 4px; border-top:1px solid var(--border); font-weight:500; color:var(--fg-2)}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse at 8% -5%, rgba(60,182,194,.10), transparent 42%),
    radial-gradient(ellipse at 100% 100%, rgba(55,166,172,.08), transparent 44%),
    linear-gradient(180deg, var(--bg-tint) 0%, var(--bg) 70%)}
.hero-grid{display:grid; grid-template-columns:1.02fr .98fr; gap:52px; align-items:center; padding:42px 24px 54px}
.eyebrow-row{display:flex; align-items:center; gap:10px; margin-bottom:18px}
.eyebrow-dot{width:8px; height:8px; border-radius:50%; background:var(--coral-600)}
.hero h1 em{font-style:normal; color:var(--coral-600)}
.accent-line{width:56px; height:5px; border-radius:999px; background:var(--coral-600); margin:20px 0 22px}
.hero-actions{display:flex; gap:13px; flex-wrap:wrap; margin-top:28px}
.trust{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; margin-top:36px}
.trust-item{display:flex; gap:12px; align-items:flex-start}
.trust-item .ic{width:42px; height:42px; border-radius:13px; background:var(--green-50); color:var(--green-600);
  display:grid; place-items:center; flex-shrink:0; border:1px solid var(--border)}
.trust-item .ic svg{width:21px; height:21px}
.trust-item b{display:block; color:var(--green-900); font-size:14.5px; font-weight:600}
.trust-item span{display:block; color:var(--fg-3); font-size:13px}

/* Hero card con foto + tarjetas flotantes */
.hero-card{position:relative}
.hero-photo-frame{position:relative; border-radius:34px; overflow:hidden; box-shadow:var(--shadow-lg);
  border:1px solid var(--border); background:#fff}
.hero-photo-frame img{width:100%; height:560px; object-fit:cover; object-position:center 28%; display:block}
.hero-photo-frame:after{content:""; position:absolute; inset:0; border-radius:34px; pointer-events:none;
  box-shadow:inset 0 -90px 70px -50px rgba(20,40,30,.22)}
/* Barra de licencia bajo la foto del hero */
.hero-license-bar{display:flex; align-items:center; gap:15px; margin-top:16px;
  background:#fff; border:1px solid var(--border); border-radius:18px; padding:14px 16px 14px 18px;
  box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
  animation:hlbRise .7s cubic-bezier(.16,1,.3,1) both .3s}
.hero-license-bar:before{content:""; position:absolute; left:0; top:0; bottom:0; width:4px;
  background:linear-gradient(180deg, var(--green-600), var(--green-700))}
.hero-license-bar:hover{transform:translateY(-2px); box-shadow:var(--shadow-md)}
.hero-license-bar .hlb-icon{width:48px; height:48px; border-radius:14px; flex-shrink:0; display:grid; place-items:center;
  background:linear-gradient(140deg, var(--green-600) 0%, var(--green-700) 100%); color:#fff;
  box-shadow:0 9px 18px -5px rgba(33,117,124,.55)}
.hero-license-bar .hlb-icon svg{width:26px; height:26px}
.hero-license-bar .hlb-body{flex:1; min-width:0}
.hero-license-bar b{display:block; font-family:var(--font-display); font-size:16.5px; color:var(--green-900); line-height:1.12; letter-spacing:-.01em}
.hero-license-bar .sub{display:block; font-size:13px; color:var(--fg-3); margin-top:3px}
.hero-license-bar .hlb-check{display:inline-flex; align-items:center; gap:6px; flex-shrink:0;
  color:var(--green-800); font-size:11.5px; font-weight:600; letter-spacing:.02em;
  background:var(--green-50); border:1px solid var(--border-strong); padding:6px 12px 6px 9px; border-radius:999px}
.hero-license-bar .hlb-check svg{width:14px; height:14px; color:var(--green-600)}
@keyframes hlbRise{from{opacity:0; transform:translateY(16px)}to{opacity:1; transform:none}}
@media(max-width:480px){
  .hero-license-bar .sub{display:none}
  .hero-license-bar{padding:12px 14px}
}

/* Decoración de cuadritos de marca */
.brand-dots{position:absolute; display:grid; grid-template-columns:repeat(4,14px); gap:7px; opacity:.9}
.brand-dots i{width:14px; height:14px; border-radius:4px; display:block}
.brand-dots.tr{top:24px; right:30px}
.bd-coral{background:var(--coral-600)} .bd-teal{background:var(--teal-600)}
.bd-yellow{background:var(--yellow-500)} .bd-green{background:var(--green-500)}

/* ---------- Trust strip ---------- */
.trust-strip{margin-top:-38px; margin-bottom:30px; position:relative; z-index:6}
.trust-strip-inner{background:#fff; border:1px solid var(--border); border-radius:var(--r-md);
  box-shadow:var(--shadow-lg); display:grid; grid-template-columns:repeat(4,1fr); overflow:hidden}
.trust-mini{padding:22px 22px; display:flex; align-items:center; gap:13px; border-right:1px solid var(--border); transition:background .18s ease}
a.trust-mini{cursor:pointer}
a.trust-mini:hover{background:var(--green-50)}
a.trust-mini:hover .ic{transform:translateY(-2px)}
.trust-mini .ic{transition:transform .18s ease}
.trust-mini:last-child{border-right:0}
.trust-mini .ic{width:40px; height:40px; border-radius:12px; background:var(--green-50); color:var(--green-600);
  display:grid; place-items:center; flex-shrink:0}
.trust-mini .ic svg{width:21px; height:21px}
.trust-mini b{display:block; color:var(--green-900); font-size:14.5px; font-weight:600; font-family:var(--font-display)}
.trust-mini span{display:block; color:var(--fg-3); font-size:12.5px; line-height:1.35}
.trust-mini .ic.green{background:var(--green-100); color:var(--green-700)}
.trust-mini .ic.blue{background:var(--teal-100); color:var(--teal-700)}
.trust-mini .ic.coral{background:var(--coral-100); color:var(--coral-600)}
.trust-mini .ic.yellow{background:var(--yellow-100); color:#B8930C}

/* ---------- Secciones ---------- */
.section{padding:88px 0}
.section-tint{background:var(--bg-tint)}
.center{text-align:center}
.section-head{max-width:720px; margin:0 auto 48px}
.section-head.center{margin-left:auto; margin-right:auto}
.section-head .kicker{margin-bottom:14px; display:inline-block}
.section-head p{margin-top:14px; font-size:1.08rem}

/* ---------- Servicios (iconos SVG reales) ---------- */
.grid-4{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.card{background:#fff; border:1px solid var(--border); border-radius:var(--r-md); box-shadow:var(--shadow-sm);
  padding:28px; transition:transform .2s ease, box-shadow .2s ease}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow-md)}
.svc-icon{width:56px; height:56px; border-radius:16px; display:grid; place-items:center; margin-bottom:18px;
  background:var(--green-50); color:var(--green-600); border:1px solid var(--border)}
.svc-icon svg{width:28px; height:28px}
.card h3{margin-bottom:8px}
.card .more{display:inline-flex; align-items:center; gap:6px; margin-top:14px; font-weight:600;
  color:var(--green-700); font-size:14.5px}
.card .more svg{width:16px; height:16px; transition:transform .18s}
.card:hover .more svg{transform:translateX(3px)}

/* variantes de color en iconos para ritmo visual */
.svc-icon.teal{background:var(--teal-100); color:var(--teal-700)}
.svc-icon.coral{background:var(--coral-100); color:var(--coral-600)}
.svc-icon.yellow{background:var(--yellow-100); color:#B8930C}

/* ---------- Elige tu camino ---------- */
.path-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.path-card{background:#fff; border:1px solid var(--border); border-radius:var(--r-md); padding:26px;
  box-shadow:var(--shadow-sm); transition:transform .2s ease, box-shadow .2s ease; display:flex; gap:16px; align-items:flex-start}
.path-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.path-card .pic{width:48px; height:48px; border-radius:14px; display:grid; place-items:center; flex-shrink:0;
  background:var(--green-50); color:var(--green-600); border:1px solid var(--border)}
.path-card .pic svg{width:24px; height:24px}
/* variantes de color elegantes en iconos de "Elige tu camino" */
.path-card .pic.green{background:var(--green-100); color:var(--green-700)}
.path-card .pic.blue{background:var(--teal-100); color:var(--teal-700)}
.path-card .pic.coral{background:var(--coral-100); color:var(--coral-600)}
.path-card .pic.yellow{background:var(--yellow-100); color:#B8930C}
.path-card strong{display:block; font-family:var(--font-display); color:var(--green-900); font-size:17px; margin-bottom:5px}
.path-card span{color:var(--fg-2); font-size:14.5px; line-height:1.5}

/* ---------- Perfil Dra. ---------- */
.doctor-profile{display:grid; grid-template-columns:.92fr 1.08fr; gap:50px; align-items:center}
.doctor-photo-card{position:relative; border-radius:32px; overflow:hidden; background:#fff;
  border:1px solid var(--border); box-shadow:var(--shadow-lg); padding:12px}
.doctor-photo-card img{width:100%; height:520px; object-fit:cover; object-position:center 20%; border-radius:22px}
.doctor-badge{position:absolute; left:24px; right:24px; bottom:24px; background:rgba(255,255,255,.97);
  border:1px solid var(--border); box-shadow:var(--shadow-md); border-radius:18px; padding:16px 18px}
.doctor-badge .kicker{margin-bottom:4px}
.doctor-badge h3{font-size:1.15rem}
.pill-row{display:flex; gap:9px; flex-wrap:wrap; margin:20px 0}
.pill{display:inline-flex; align-items:center; border:1px solid var(--border); border-radius:999px;
  padding:8px 14px; background:#fff; color:var(--green-800); font-weight:600; font-size:13.5px}
.pill.lead-pill{background:var(--green-600); color:#fff; border-color:var(--green-600)}
.credentials-list{display:grid; gap:12px; margin:24px 0}
.credential-item{display:flex; align-items:center; gap:14px; padding:15px 18px; background:#fff;
  border:1px solid var(--border); border-radius:16px; box-shadow:var(--shadow-sm)}
.credential-item .cic{width:44px; height:44px; border-radius:13px; display:grid; place-items:center; flex-shrink:0;
  background:var(--green-50); color:var(--green-600); border:1px solid var(--border)}
.credential-item .cic svg{width:22px; height:22px}
.credential-item strong{color:var(--green-900); font-weight:600; font-size:15px; display:block}
.credential-item span{color:var(--fg-3); font-size:13.5px}

/* ---------- Proceso / Cómo trabajamos ---------- */
.process-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; counter-reset:step}
.process-step{position:relative; background:#fff; border:1px solid var(--border); border-radius:var(--r-md);
  padding:30px 24px 24px; box-shadow:var(--shadow-sm)}
.process-step .num{counter-increment:step; font-family:var(--font-display); font-weight:700; font-size:1.1rem;
  width:40px; height:40px; border-radius:12px; background:var(--green-600); color:#fff;
  display:grid; place-items:center; margin-bottom:16px}
.process-step .num:before{content:counter(step)}
.process-step h3{font-size:1.12rem; margin-bottom:7px}
.process-step p{font-size:14.5px}

/* ---------- Online ---------- */
.online-grid{display:grid; grid-template-columns:1.02fr .98fr; gap:50px; align-items:center}
.list-check{list-style:none; margin:22px 0 0; padding:0; display:grid; gap:14px}
.list-check li{padding-left:36px; position:relative; color:var(--fg-2); line-height:1.55}
.list-check li:before{content:""; position:absolute; left:0; top:2px; width:23px; height:23px; border-radius:50%;
  background:var(--green-100); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232A6F50' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center}
.about-box{border-radius:var(--r-lg); padding:34px; background:#fff; border:1px solid var(--border); box-shadow:var(--shadow-md)}
.answer-box{background:linear-gradient(140deg, var(--green-900), var(--green-700)); color:#fff;
  border-radius:var(--r-lg); padding:36px; box-shadow:var(--shadow-lg)}
.answer-box h2,.answer-box h3{color:#fff}
.answer-box p,.answer-box li{color:rgba(255,255,255,.86)}

/* ---------- Testimonios ---------- */
.testimonial-card{position:relative; border-top:4px solid var(--green-600); display:flex; flex-direction:column; gap:16px}
.testimonial-card .stars{color:var(--yellow-500); font-size:19px; letter-spacing:2px}
.testimonial-card p{color:var(--fg-1); font-size:16px; line-height:1.6}
.testimonial-card strong{color:var(--green-800); font-size:14px; font-weight:600}

/* ---------- FAQ ---------- */
.faq{display:grid; gap:13px; max-width:880px; margin:0 auto}
details.faq-item{background:#fff; border:1px solid var(--border); border-radius:16px; padding:6px 22px; box-shadow:var(--shadow-sm); transition:box-shadow .2s}
details.faq-item[open]{box-shadow:var(--shadow-md)}
details.faq-item summary{font-family:var(--font-display); font-weight:600; color:var(--green-900); cursor:pointer;
  list-style:none; padding:16px 0; display:flex; justify-content:space-between; align-items:center; gap:16px; font-size:1.02rem}
details.faq-item summary::-webkit-details-marker{display:none}
details.faq-item summary:after{content:""; width:22px; height:22px; flex-shrink:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%233C8C66' stroke-width='2.4' stroke-linecap='round'%3E%3Cpath d='M12 5v14M5 12h14'/%3E%3C/svg%3E");
  transition:transform .2s}
details.faq-item[open] summary:after{transform:rotate(45deg)}
details.faq-item p{padding:0 0 18px; color:var(--fg-2)}

/* ---------- Ubicación / contacto ---------- */
.location-grid{display:grid; grid-template-columns:1fr 1fr; gap:28px; align-items:stretch}
.location-card{background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); padding:32px; box-shadow:var(--shadow-md)}
.nap{display:grid; gap:13px; margin:22px 0}
.nap-item{display:flex; gap:14px; align-items:flex-start; padding:15px 16px; border-radius:15px; background:var(--green-50); border:1px solid var(--border)}
.nap-item .ic{width:40px; height:40px; border-radius:12px; display:grid; place-items:center; background:#fff; color:var(--green-600); border:1px solid var(--border); flex-shrink:0}
.nap-item .ic svg{width:20px; height:20px}
.nap-item b{display:block; color:var(--green-900); font-size:14px; font-weight:600}
.nap-item span{color:var(--fg-2); font-size:14px}
.map-wrap{border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow-md); min-height:420px; background:#fff}
.map-wrap iframe{width:100%; height:100%; min-height:420px; border:0; display:block}

/* ---------- CTA final ---------- */
.cta{background:linear-gradient(150deg, #1E4A5E 0%, #143240 100%); color:#fff; position:relative; overflow:hidden}
.cta:before{content:""; position:absolute; top:-60px; right:-40px; width:260px; height:260px; border-radius:50%;
  background:radial-gradient(circle, rgba(94,155,214,.20), transparent 70%)}
.cta h2{color:#fff}
.cta p{color:rgba(255,255,255,.9); max-width:560px; margin:14px auto 0}
.cta .btn{background:#fff; color:var(--green-800)}
.cta .btn:hover{background:var(--green-50)}

/* ---------- Footer ---------- */
.footer{background:#112A36; color:rgba(255,255,255,.78); padding:60px 0 32px}
.footer-grid{display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:40px}
.footer h4{color:#fff; font-size:1.05rem; margin-bottom:6px}
.footer a{display:block; margin:9px 0; color:rgba(255,255,255,.74); transition:color .15s}
.footer a:hover{color:#fff}
.footer .logo-foot{height:42px; width:auto; filter:brightness(0) invert(1); opacity:.95; margin-bottom:6px}
.footer .fine{font-size:13px; opacity:.7; line-height:1.5}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:40px; padding-top:22px; font-size:13px; opacity:.68; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px}

/* ---------- Flotantes + barra móvil (UNA sola) ---------- */
.floating-actions{position:fixed; right:22px; bottom:22px; z-index:60; display:grid; gap:13px}
.float-btn{width:60px; height:60px; border-radius:50%; display:grid; place-items:center;
  background:#1FAF52; color:#fff; box-shadow:0 16px 34px rgba(20,40,30,.24); transition:transform .18s}
.float-btn:hover{transform:scale(1.06)}
.float-btn svg{width:28px; height:28px}
.float-btn.share{width:52px; height:52px; background:#fff; color:var(--fg-2); border:1px solid var(--border)}
.float-btn.share svg{width:22px; height:22px}

.mobile-cta-bar{display:none}

.lang-toggle{display:inline-flex; align-items:center; justify-content:center; min-width:42px; height:38px; padding:0 13px;
  border-radius:999px; border:1.5px solid var(--border-strong); background:#fff; color:var(--green-700);
  font-family:var(--font-body); font-weight:600; font-size:13px; letter-spacing:.05em; cursor:pointer; transition:.18s}
.lang-toggle:hover{background:var(--green-50); border-color:var(--green-600); transform:translateY(-1px)}
.header-actions{display:flex; align-items:center; gap:10px}

/* ============================================================
   Diferenciador: tecnología con licencia (NeuronUP)
   ============================================================ */
.license{background:linear-gradient(180deg,#fff 0%, var(--green-50) 100%); color:var(--fg-1); position:relative; overflow:hidden}
.license:before{content:""; position:absolute; top:-140px; right:-90px; width:440px; height:440px; border-radius:50%; background:rgba(55,166,172,.08); z-index:0}
.license-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; position:relative; z-index:1}
.license h2{color:var(--green-900)}
.license p{color:var(--fg-2)}
.license .kicker{display:block; margin-top:16px; color:var(--green-700)}
.unique-badge{display:inline-flex; align-items:center; gap:10px; background:#fff; border:1px solid rgba(55,166,172,.28);
  border-radius:999px; padding:9px 16px; font-weight:600; font-size:13.5px; color:var(--green-800); margin-bottom:0; box-shadow:var(--shadow-sm)}
.unique-badge svg{width:18px; height:18px; color:var(--green-600)}
.license-points{list-style:none; padding:0; margin:24px 0 0; display:grid; gap:14px}
.license-points li{display:flex; gap:13px; align-items:flex-start; color:var(--fg-2); line-height:1.5}
.license-points li svg{width:22px; height:22px; flex-shrink:0; color:var(--green-600); margin-top:1px}
.license-panel{background:#fff; border:1px solid rgba(55,166,172,.18); border-radius:26px; padding:32px; box-shadow:0 14px 38px rgba(10,48,58,.08); position:relative; overflow:hidden}
.license-panel:before{content:""; position:absolute; right:-54px; top:-54px; width:140px; height:140px; border-radius:50%; background:rgba(91,196,196,.16); z-index:0}
.license-brand{display:flex; flex-direction:column; align-items:flex-start; gap:12px; padding-bottom:22px; margin-bottom:22px; border-bottom:1px solid var(--border); position:relative; z-index:1}
.neuronup-logo{width:188px; height:auto; display:block}
.license-brand .lb-desc{font-size:13.5px; color:var(--fg-3); line-height:1.45}
.license-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:4px; position:relative; z-index:1}
.license-stat{text-align:center}
.license-stat strong{display:block; font-family:var(--font-display); font-size:1.7rem; color:var(--green-700); line-height:1}
.license-stat span{display:block; margin-top:5px; font-size:12px; color:var(--fg-3)}
.license-note{font-size:12.5px; color:var(--fg-3); margin-top:20px; line-height:1.5; position:relative; z-index:1}
@media(max-width:980px){ .license-grid{grid-template-columns:1fr; gap:34px} }

.skip-link{position:absolute; left:-999px; top:12px; background:#fff; color:var(--green-900);
  padding:12px 16px; border-radius:12px; z-index:999; border:2px solid var(--green-600); font-weight:700}
.skip-link:focus{left:12px}

a:focus-visible,button:focus-visible,summary:focus-visible{outline:3px solid rgba(60,140,102,.4); outline-offset:3px}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:1080px){
  .nav{gap:18px; font-size:14.5px}
  .header .btn{padding:12px 18px; font-size:14.5px}
}
@media(max-width:980px){
  .hero-grid,.doctor-profile,.online-grid,.location-grid{grid-template-columns:1fr}
  .hero-grid{gap:40px; padding-bottom:84px}
  .doctor-photo-card{order:-1}
  .grid-4,.process-grid{grid-template-columns:repeat(2,1fr)}
  .path-grid{grid-template-columns:repeat(2,1fr)}
  .trust-strip-inner{grid-template-columns:repeat(2,1fr)}
  .trust-mini:nth-child(2n){border-right:0}
  .trust-mini{border-bottom:1px solid var(--border)}
  .nav{display:none}
  .mobile-menu{display:block}
  .footer-grid{grid-template-columns:1fr 1fr}
  .float-card.top{right:8px}
  .float-card.bottom{left:8px}
}
@media(max-width:640px){
  body{font-size:16px; padding-bottom:78px}
  .section{padding:60px 0}
  .grid-4,.grid-3,.path-grid,.process-grid,.trust-strip-inner,.footer-grid{grid-template-columns:1fr}
  .trust{grid-template-columns:1fr}
  .trust-mini{border-right:0}
  .hero-photo-frame img{height:440px}
  .doctor-photo-card img{height:420px}
  .hero-actions .btn{width:100%}
  .float-card{transform:scale(.9)}
  .float-card.top{top:14px; right:4px}
  .float-card.bottom{bottom:14px; left:4px}
  .trust-strip{margin-top:0}
  .floating-actions{display:none}
  .mobile-cta-bar{position:fixed; left:12px; right:12px; bottom:12px; z-index:80;
    display:grid; grid-template-columns:1fr 1fr; gap:10px}
  .mobile-cta-bar a{display:grid; place-items:center; border-radius:16px; background:var(--green-700);
    color:#fff; padding:15px 10px; font-weight:600; box-shadow:var(--shadow-lg)}
  .mobile-cta-bar a.alt{background:#fff; color:var(--green-800); border:1px solid var(--border)}
  .footer-bottom{flex-direction:column}
}
@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important; animation:none!important; transition:none!important}
}

/* ============================================================
   Hero refuerzos: marco con borde de marca, stats, booking banner
   ============================================================ */
.hero-photo-frame{background:linear-gradient(135deg, var(--green-600), var(--teal-600) 55%, var(--yellow-500)); padding:7px}
.hero-photo-frame img{border-radius:28px}
.booking-banner{display:inline-flex; align-items:center; gap:13px; padding:8px 18px 8px 8px; background:#fff;
  border:1px solid var(--border); border-radius:999px; box-shadow:var(--shadow-md); margin-bottom:22px;
  color:var(--fg-1); transition:transform .2s, box-shadow .2s}
.booking-banner:hover{transform:translateY(-2px); box-shadow:var(--shadow-lg)}
.booking-banner .bb-avatar{width:42px; height:42px; border-radius:50%; overflow:hidden; flex-shrink:0; border:2px solid #fff; box-shadow:var(--shadow-sm); position:relative}
.booking-banner .bb-avatar img{width:100%; height:100%; object-fit:cover; object-position:center 25%}
.booking-banner .bb-avatar:after{content:""; position:absolute; right:-1px; bottom:-1px; width:11px; height:11px; border-radius:50%; background:#1FAF52; border:2px solid #fff}
.booking-banner .bb-text{display:flex; flex-direction:column; line-height:1.2}
.booking-banner .bb-text b{font-family:var(--font-display); font-size:14px; color:var(--green-900)}
.booking-banner .bb-text span{font-size:12.5px; color:var(--fg-3)}
.booking-banner .bb-arrow{color:var(--green-600); font-weight:700; margin-left:4px}
.hero-stats{display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:32px; max-width:540px}
.hero-stat{padding:16px 18px; border:1px solid var(--border); background:rgba(255,255,255,.7); border-radius:18px; box-shadow:var(--shadow-sm)}
.hero-stat strong{display:block; font-family:var(--font-display); color:var(--green-600); font-size:1.7rem; line-height:1}
.hero-stat span{display:block; margin-top:6px; color:var(--fg-3); font-size:12.5px; font-weight:500}

/* ============================================================
   Tira de recursos
   ============================================================ */
.resource-strip{padding:28px 0; background:#fff; border-top:1px solid var(--border); border-bottom:1px solid var(--border)}
.resource-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px}
.resource-card{display:flex; gap:15px; align-items:center; padding:20px; border:1px solid var(--border); border-radius:var(--r-md);
  background:linear-gradient(180deg,#fff,var(--green-50)); box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s, border-color .2s}
.resource-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--green-500)}
.resource-card .ric{width:48px; height:48px; border-radius:15px; display:grid; place-items:center; flex-shrink:0; background:var(--green-100); color:var(--green-700)}
.resource-card .ric svg{width:24px; height:24px}
.resource-card.coral .ric{background:var(--coral-100); color:var(--coral-600)}
.resource-card.teal .ric{background:var(--teal-100); color:var(--teal-700)}
.resource-card b{display:block; font-family:var(--font-display); font-size:16px; color:var(--green-900); margin-bottom:2px}
.resource-card span{display:block; font-size:13px; color:var(--fg-3)}

/* ============================================================
   Servicios con viñetas
   ============================================================ */
.card ul.svc-list{list-style:none; margin:16px 0 0; padding:0; display:grid; gap:9px}
.card ul.svc-list li{padding-left:26px; position:relative; font-size:14.5px; color:var(--fg-2); line-height:1.45}
.card ul.svc-list li:before{content:""; position:absolute; left:0; top:2px; width:17px; height:17px; border-radius:50%;
  background:var(--green-100); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='11' viewBox='0 0 24 24' fill='none' stroke='%232A6F50' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center}

/* ============================================================
   Artículos / blog grid
   ============================================================ */
.articles-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
.article-card{display:flex; flex-direction:column; background:#fff; border:1px solid var(--border); border-radius:var(--r-md);
  overflow:hidden; transition:transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s, border-color .25s; box-shadow:var(--shadow-sm)}
.article-card:hover{transform:translateY(-5px); box-shadow:var(--shadow-lg); border-color:var(--green-500)}
.article-card.featured{grid-column:span 2; grid-row:span 2}
.art-cover{position:relative; aspect-ratio:16/10; display:grid; place-items:center; overflow:hidden}
.article-card.featured .art-cover{aspect-ratio:16/9}
.art-cover .art-ic{width:64px; height:64px; color:rgba(255,255,255,.95)}
.article-card.featured .art-cover .art-ic{width:92px; height:92px}
.art-tag{position:absolute; top:14px; left:14px; background:rgba(255,255,255,.94); color:var(--green-900); font-size:11px; font-weight:600;
  text-transform:uppercase; letter-spacing:.1em; padding:6px 12px; border-radius:999px}
.art-body{padding:22px; flex:1; display:flex; flex-direction:column; gap:7px}
.article-card.featured .art-body{padding:28px}
.art-cat{font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.14em; color:var(--green-600)}
.art-body h3{font-size:18px; line-height:1.25}
.article-card.featured .art-body h3{font-size:28px; line-height:1.15}
.art-body p{font-size:14px; color:var(--fg-2); line-height:1.5; flex:1}
.art-meta{display:flex; justify-content:space-between; align-items:center; margin-top:12px; font-size:12.5px; font-weight:600; color:var(--fg-3)}
.art-meta .arr{color:var(--green-600)}
@media(max-width:980px){
  .articles-grid{grid-template-columns:repeat(2,1fr)}
  .article-card.featured{grid-column:span 2; grid-row:auto}
}
@media(max-width:560px){
  .articles-grid{grid-template-columns:1fr}
  .article-card.featured{grid-column:auto}
  .article-card.featured .art-body h3{font-size:22px}
}

/* ============================================================
   Barra de reseñas Google (sobre fondo oscuro)
   ============================================================ */
.dark-section{background:linear-gradient(160deg, #1C3E58 0%, #16314A 100%); color:#fff; position:relative; overflow:hidden}
.dark-section h2,.dark-section h3{color:#fff}
.dark-section .kicker{color:#BBD8F2}
.dark-section .section-head p{color:rgba(255,255,255,.78)}
.google-rating{display:flex; align-items:center; gap:20px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14);
  border-radius:var(--r-md); padding:18px 24px; margin-bottom:34px; flex-wrap:wrap}
.google-rating .gr-logo{width:48px; height:48px; border-radius:14px; background:#fff; display:grid; place-items:center; flex-shrink:0; box-shadow:var(--shadow-sm)}
.google-rating .gr-logo svg{width:28px; height:28px}
.google-rating .gr-info{flex:1; min-width:200px}
.google-rating .gr-score{display:flex; align-items:baseline; gap:8px; line-height:1}
.google-rating .gr-score b{font-family:var(--font-display); font-size:30px; color:#fff}
.google-rating .gr-stars{color:var(--yellow-500); font-size:18px; letter-spacing:2px}
.google-rating .gr-meta{color:rgba(255,255,255,.72); font-size:13px; margin-top:4px}
.google-rating .gr-actions{display:flex; gap:10px; flex-wrap:wrap}
.btn-ghost-light{background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.22); box-shadow:none}
.btn-ghost-light:hover{background:rgba(255,255,255,.2)}
.dark-section .testimonial-card{background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.13); border-top:4px solid var(--teal-600)}
.dark-section .testimonial-card p{color:rgba(255,255,255,.92)}
.dark-section .testimonial-card strong{color:#fff}

/* Carrusel de reseñas */
.reviews-carousel{position:relative; display:flex; align-items:center; gap:10px}
.rc-track{display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding:6px 2px 14px; flex:1;
  scrollbar-width:none; -ms-overflow-style:none}
.rc-track::-webkit-scrollbar{display:none}
.review-card{flex:0 0 clamp(280px, 33%, 360px); scroll-snap-align:start; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.14); border-radius:var(--r-md); padding:24px; display:flex; flex-direction:column; gap:14px}
.rc-top{display:flex; align-items:center; gap:12px}
.rc-avatar{width:44px; height:44px; border-radius:50%; display:grid; place-items:center; color:#fff;
  font-family:var(--font-display); font-weight:700; font-size:16px; flex-shrink:0}
.rc-id{flex:1; min-width:0}
.rc-id b{display:block; color:#fff; font-size:14.5px; font-weight:600; line-height:1.2}
.rc-id span{display:block; color:rgba(255,255,255,.6); font-size:12px; margin-top:2px}
.rc-g{flex-shrink:0; opacity:.95}
.rc-stars{display:flex; gap:2px; font-size:16px; color:#FBBC05; letter-spacing:1px}
.rc-star.off{color:rgba(255,255,255,.25)}
.rc-text{color:rgba(255,255,255,.9); font-size:14.5px; line-height:1.6; margin:0}
.rc-nav{flex-shrink:0; width:44px; height:44px; border-radius:50%; cursor:pointer; display:grid; place-items:center;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.22); color:#fff; transition:background .18s, transform .18s}
.rc-nav:hover{background:rgba(255,255,255,.22); transform:scale(1.06)}
.rc-nav svg{width:20px; height:20px}
#reviews-live{min-height:60px}
@media(max-width:760px){
  .rc-nav{display:none}
  .review-card{flex:0 0 84%}
}

/* ============================================================
   Galería: conferencista y medios
   ============================================================ */
.media-head{display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; margin-bottom:34px}
.media-head .section-head{margin:0; max-width:640px; text-align:left}
.media-cred{display:inline-flex; align-items:center; gap:10px; background:var(--green-50); border:1px solid var(--border);
  border-radius:999px; padding:9px 16px; color:var(--green-800); font-size:13px; font-weight:600}
.media-cred svg{width:17px; height:17px; color:var(--green-600); flex-shrink:0}
.media-feature{display:grid; grid-template-columns:330px 1fr; gap:36px; align-items:center; margin-bottom:18px;
  background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); padding:24px}
.mf-video{position:relative; border-radius:var(--r-md); overflow:hidden; background:#000; box-shadow:var(--shadow-md); aspect-ratio:9/16}
.mf-video video{width:100%; height:100%; object-fit:cover; display:block}
.mf-info h3{font-size:1.55rem; margin:10px 0 12px}
.mf-info p{color:var(--fg-2)}
.mf-meta{list-style:none; padding:0; margin:18px 0; display:grid; gap:11px}
.mf-meta li{display:flex; align-items:center; gap:11px; color:var(--fg-1); font-size:15px; font-weight:500}
.mf-meta li svg{width:19px; height:19px; color:var(--green-600); flex-shrink:0}
.media-poster{display:inline-flex; align-items:center; gap:13px; margin-top:4px; padding:9px 16px 9px 9px;
  border:1px solid var(--border); border-radius:15px; background:var(--green-50); transition:transform .18s, border-color .18s; max-width:340px}
.media-poster:hover{border-color:var(--green-500); transform:translateY(-2px)}
.media-poster img{width:48px; height:56px; object-fit:cover; border-radius:9px; flex-shrink:0; box-shadow:var(--shadow-sm)}
.media-poster .mp-txt{display:flex; flex-direction:column; line-height:1.25}
.media-poster b{font-size:14px; color:var(--green-900)}
.media-poster .mp-txt span{font-size:12.5px; color:var(--fg-3)}
@media(max-width:760px){
  .media-feature{grid-template-columns:1fr; gap:22px}
  .mf-video{max-width:280px; margin:0 auto; width:100%}
}
.mf-poster{display:block; border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--border); transition:transform .25s ease}
.mf-poster:hover{transform:translateY(-3px)}
.mf-poster img{width:100%; height:auto; display:block}
@media(max-width:760px){ .mf-poster{max-width:360px; margin:0 auto} }

/* Páginas de servicio */
.svc-chips{display:flex; flex-wrap:wrap; gap:10px; margin:6px 0 4px}
.svc-chip{display:inline-flex; align-items:center; gap:8px; padding:9px 16px; border-radius:999px;
  background:var(--green-50); border:1px solid var(--border); color:var(--green-800); font-weight:600; font-size:14px; transition:.18s}
.svc-chip:hover{border-color:var(--green-500); background:var(--green-100); transform:translateY(-2px)}
.svc-video{margin:8px 0 22px; max-width:320px}
.svc-video video{width:100%; border-radius:var(--r-md); box-shadow:var(--shadow-md); background:#000; display:block; aspect-ratio:9/16; object-fit:cover}
.svc-video-cap{font-size:13px; color:var(--fg-3); margin-top:10px; line-height:1.5}

.media-gallery{display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:300px; gap:16px}
.media-fig{position:relative; overflow:hidden; border-radius:20px; box-shadow:var(--shadow-sm); border:1px solid var(--border); margin:0}
.media-fig img{width:100%; height:100%; object-fit:cover; display:block; transition:transform .6s cubic-bezier(.16,1,.3,1)}
.media-fig:hover img{transform:scale(1.06)}
.media-fig figcaption{position:absolute; left:0; right:0; bottom:0; padding:42px 18px 16px; color:#fff;
  background:linear-gradient(to top, rgba(13,40,42,.88) 0%, rgba(13,40,42,.4) 55%, transparent 100%)}
.media-fig figcaption .tag{display:inline-block; font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:.12em;
  background:rgba(255,255,255,.22); border:1px solid rgba(255,255,255,.34); padding:3px 10px; border-radius:999px; margin-bottom:8px}
.media-fig figcaption b{display:block; font-family:var(--font-display); font-size:16px; line-height:1.2; letter-spacing:-.01em}
.media-fig figcaption span{display:block; font-size:12.5px; color:rgba(255,255,255,.82); margin-top:3px}
.calendly-card{background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-md); overflow:hidden; padding:6px; max-width:1000px; margin:0 auto}
.calendly-card .calendly-inline-widget{border-radius:calc(var(--r-lg) - 8px); overflow:hidden}
.m-a{grid-column:span 5} .m-b{grid-column:span 4} .m-c{grid-column:span 3; grid-row:span 2} .m-d{grid-column:span 9}
@media(max-width:820px){
  .media-gallery{grid-template-columns:repeat(2,1fr); grid-auto-rows:220px}
  .m-a,.m-b,.m-d{grid-column:span 1} .m-c{grid-column:span 1; grid-row:span 2}
}
@media(max-width:480px){
  .media-gallery{grid-template-columns:1fr; grid-auto-rows:240px}
  .m-c{grid-row:auto}
}

/* breadcrumb + artículo (páginas internas) */
.article-hero{padding:52px 0 36px; background:var(--bg-tint)}
.breadcrumb{font-size:14px; color:var(--fg-3); padding:0 0 16px}
.breadcrumb a{color:var(--green-700); font-weight:500}
.article-body{max-width:780px; margin:0 auto; padding:48px 24px}
.article-body h2{font-size:1.7rem; margin:34px 0 12px}
.article-body p{margin-bottom:14px; font-size:1.05rem; line-height:1.7}
.article-body .answer-box{margin-bottom:24px}
.author-review{background:var(--green-50); border:1px solid var(--border); border-radius:var(--r-md); padding:18px 20px; margin-bottom:26px; color:var(--fg-2); font-size:14px; line-height:1.6}
.author-review strong{color:var(--green-900)}

@media(max-width:640px){
  .resource-grid{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:1fr; max-width:none}
  .google-rating .gr-actions{width:100%}
  .google-rating .gr-actions .btn{flex:1}
}

/* ============================================================
   Stats / prueba social
   ============================================================ */
.stats-row{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:8px}
.stat{text-align:center; padding:24px 16px; background:#fff; border:1px solid var(--border); border-radius:var(--r-md); box-shadow:var(--shadow-sm)}
.stat .num{font-family:var(--font-display); font-weight:700; font-size:2.4rem; color:var(--green-600); line-height:1}
.stat .lbl{margin-top:8px; color:var(--fg-2); font-size:14px}
.test-split{display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center}
@media(max-width:820px){ .test-split{grid-template-columns:1fr; gap:28px} }

/* ============================================================
   Franja de costos orientativos
   ============================================================ */
.price-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.price-card{background:#fff; border:1px solid var(--border); border-radius:var(--r-md); padding:28px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s; position:relative}
.price-card:hover{transform:translateY(-3px); box-shadow:var(--shadow-md)}
.price-card.featured{border:2px solid var(--green-600); box-shadow:var(--shadow-md)}
.price-card .tag{position:absolute; top:-12px; left:28px; background:var(--green-600); color:#fff; font-size:12px; font-weight:600; padding:5px 12px; border-radius:999px}
.price-card h3{font-size:1.2rem; margin-bottom:6px}
.price-card .price{font-family:var(--font-display); font-weight:700; color:var(--green-700); font-size:1.9rem; margin:10px 0 4px}
.price-card .price small{font-size:.95rem; color:var(--fg-3); font-weight:500}
.price-card ul{list-style:none; padding:0; margin:18px 0 0; display:grid; gap:10px}
.price-card li{padding-left:28px; position:relative; font-size:14.5px; color:var(--fg-2); line-height:1.45}
.price-card li:before{content:""; position:absolute; left:0; top:1px; width:18px; height:18px; border-radius:50%;
  background:var(--green-100); background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232A6F50' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:center}
.price-note{text-align:center; color:var(--fg-3); font-size:14px; margin-top:24px}

/* respuesta rápida badge */
.response-badge{display:inline-flex; align-items:center; gap:9px; background:var(--green-50); border:1px solid var(--border);
  border-radius:999px; padding:9px 16px; color:var(--green-800); font-weight:500; font-size:14px; margin-top:22px}
.response-badge .dot{width:9px; height:9px; border-radius:50%; background:#1FAF52; position:relative}
.response-badge .dot:before{content:""; position:absolute; inset:-4px; border-radius:50%; background:rgba(31,175,82,.3); animation:pulse 2s infinite}
@keyframes pulse{0%{transform:scale(.8); opacity:.8}70%{transform:scale(1.8); opacity:0}100%{opacity:0}}

/* ============================================================
   TEST / Quiz auto-cribado
   ============================================================ */
.test-page{background:
  radial-gradient(ellipse at 8% -5%, rgba(60,182,194,.12), transparent 42%),
  radial-gradient(ellipse at 100% 100%, rgba(55,166,172,.10), transparent 44%),
  linear-gradient(180deg, var(--bg-tint) 0%, var(--bg) 60%); min-height:100vh; padding:32px 0 70px}
.test-head{text-align:center; max-width:680px; margin:0 auto 28px}
.test-head .kicker{display:inline-block; margin-bottom:12px}
.test-head p{margin-top:12px}
.quiz-shell{max-width:720px; margin:0 auto; background:#fff; border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--shadow-lg); padding:34px}
.quiz-progress{display:flex; align-items:center; gap:14px; margin-bottom:26px}
.quiz-progress .bar{flex:1; height:9px; background:var(--green-100); border-radius:999px; overflow:hidden}
.quiz-progress .bar i{display:block; height:100%; width:0; background:linear-gradient(90deg, var(--green-600), var(--teal-600)); border-radius:999px; transition:width .35s ease}
.quiz-progress .count{font-family:var(--font-display); font-weight:600; color:var(--green-700); font-size:14px; white-space:nowrap}
.quiz-step{display:none}
.quiz-step.active{display:block; animation:fadeIn .35s ease}
@keyframes fadeIn{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
.quiz-q{font-family:var(--font-display); font-weight:600; font-size:1.45rem; color:var(--green-900); line-height:1.2; margin-bottom:4px}
.quiz-hint{color:var(--fg-3); font-size:14.5px; margin-bottom:24px}
.quiz-options{display:grid; gap:12px}
.quiz-opt{display:flex; align-items:center; gap:14px; width:100%; text-align:left; cursor:pointer;
  border:1.5px solid var(--border); border-radius:16px; background:#fff; padding:16px 18px;
  font-family:var(--font-body); font-size:16px; font-weight:500; color:var(--green-900); transition:.16s}
.quiz-opt:hover{border-color:var(--green-500); background:var(--green-50); transform:translateY(-1px)}
.quiz-opt .mark{width:24px; height:24px; border-radius:50%; border:2px solid var(--border-strong); flex-shrink:0; display:grid; place-items:center; transition:.16s}
.quiz-opt:hover .mark{border-color:var(--green-600)}
.quiz-opt .mark svg{width:13px; height:13px; opacity:0; color:#fff}
.quiz-opt.sel{border-color:var(--green-600); background:var(--green-50)}
.quiz-opt.sel .mark{background:var(--green-600); border-color:var(--green-600)}
.quiz-opt.sel .mark svg{opacity:1}
.quiz-nav{display:flex; justify-content:space-between; align-items:center; margin-top:26px}
.quiz-back{background:none; border:0; color:var(--fg-3); font-family:var(--font-body); font-weight:500; font-size:15px; cursor:pointer; padding:8px 4px}
.quiz-back:hover{color:var(--green-700)}
.quiz-back[disabled]{opacity:0; pointer-events:none}

/* Resultado */
.quiz-result{display:none}
.quiz-result.active{display:block; animation:fadeIn .4s ease}
.result-card{border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow-lg); background:#fff}
.result-banner{padding:34px 32px; color:#fff; position:relative; overflow:hidden}
.result-banner.atencion{background:linear-gradient(140deg, var(--green-900), var(--green-600))}
.result-banner.memoria{background:linear-gradient(140deg, #1B3A5C, var(--teal-700))}
.result-banner.lenguaje{background:linear-gradient(140deg, #6E5410, #B8930C)}
.result-banner.emocional{background:linear-gradient(140deg, #6E2C26, var(--coral-600))}
.result-banner .ricon{width:60px; height:60px; border-radius:18px; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.28); display:grid; place-items:center; margin-bottom:16px}
.result-banner .ricon svg{width:30px; height:30px; color:#fff}
.result-banner .rk{font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.14em; opacity:.85}
.result-banner h2{color:#fff; margin:6px 0 10px; font-size:2rem}
.result-banner p{color:rgba(255,255,255,.9); max-width:520px}
.result-body{padding:30px 32px}
.result-bars{display:grid; gap:14px; margin-bottom:26px}
.rbar-row{display:grid; grid-template-columns:130px 1fr 44px; align-items:center; gap:12px}
.rbar-row .rl{font-size:14px; font-weight:600; color:var(--green-900)}
.rbar-track{height:10px; background:var(--bg-2); border-radius:999px; overflow:hidden}
.rbar-track i{display:block; height:100%; border-radius:999px; width:0; transition:width .8s cubic-bezier(.2,.7,.2,1)}
.rbar-track i.atencion{background:var(--green-600)} .rbar-track i.memoria{background:var(--teal-600)}
.rbar-track i.lenguaje{background:#E0B42E} .rbar-track i.emocional{background:var(--coral-600)}
.rbar-row .rv{font-size:13px; font-weight:600; color:var(--fg-3); text-align:right}
.result-rec{background:var(--green-50); border:1px solid var(--border); border-radius:var(--r-md); padding:22px 24px; margin-bottom:22px}
.result-rec .kicker{margin-bottom:8px; display:block}
.result-rec strong{color:var(--green-900); font-family:var(--font-display); font-size:1.15rem}
.result-actions{display:flex; gap:13px; flex-wrap:wrap}
.result-disclaimer{font-size:13px; color:var(--fg-3); margin-top:20px; line-height:1.5}
@media(max-width:640px){
  .quiz-shell{padding:24px 20px}
  .quiz-q{font-size:1.25rem}
  .result-banner,.result-body{padding:26px 22px}
  .rbar-row{grid-template-columns:96px 1fr 38px}
  .result-actions .btn{width:100%}
}
