/* ═══════════════════════════════════════════════════════════════
   TALK SALUD — Home sections (stats · posicionamiento · pilares ·
   para quién · equipo · logos · cta)
   ═══════════════════════════════════════════════════════════════ */

/* 2 · STATS */
.stats-head { margin-bottom: 40px; display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; flex-wrap: wrap; }
.stats-head .label { display: block; margin-bottom: 10px; }
.stats-head .h2 { color: var(--navy); }
.stats-head .h2 em { color: var(--green-dark); }
.stats-note { font-size: 13px; color: var(--subtext); max-width: 280px; text-align: right; line-height: 1.55; margin: 0; }
@media (max-width: 768px) { .stats-note { text-align: left; max-width: none; } }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
@media (max-width: 900px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
.stat-card { position: relative; border-radius: 14px; padding: 24px 22px; display: flex; flex-direction: column; gap: 6px; transition: transform .25s, box-shadow .25s; }
.stat-card:hover { transform: translateY(-6px); box-shadow: 0 28px 56px rgba(10,46,82,0.13); }
.stat-card .ix { font-size: 11px; letter-spacing: 1.8px; text-transform: uppercase; font-weight: 700; }
.stat-card .num { font-family: var(--font-display); font-weight: 700; font-size: clamp(34px, 4.2vw, 52px); line-height: 1; margin: 4px 0 2px; letter-spacing: -0.02em; }
.stat-card .lbl { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; }
.stat-card .cap { font-size: 13px; line-height: 1.55; margin-top: 4px; }
.stat-card.light { background: #ffffff; border: 1.5px solid var(--border); }
.stat-card.light .ix { color: var(--green-dark); }
.stat-card.light .num { background: linear-gradient(135deg, var(--navy) 0%, var(--green) 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat-card.light .lbl { color: var(--subtext); }
.stat-card.light .cap { color: var(--navy); opacity: 0.7; }
.stat-card.dark { background: var(--navy); color: var(--light); border: 1.5px solid var(--navy); }
.stat-card.dark .ix { color: var(--green); }
.stat-card.dark .num { color: var(--green); }
.stat-card.dark .lbl { color: rgba(244,247,251,0.65); }
.stat-card.dark .cap { color: rgba(244,247,251,0.7); }

/* 3 · POSICIONAMIENTO */
.glow-tr { position: absolute; top: -120px; right: -80px; width: 460px; height: 460px; border-radius: 50%; background: radial-gradient(circle, rgba(46,204,154,0.16), transparent 65%); pointer-events: none; }
.pos { position: relative; }
.pos-h { color: var(--light); margin: 22px 0 36px; max-width: 900px; }
.pos-h em { color: var(--green); font-style: italic; }
.pos-body { display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: start; margin-bottom: 40px; }
@media (max-width: 900px) { .pos-body { grid-template-columns: 1fr; gap: 24px; } }
.pos-body .lead { color: rgba(244,247,251,0.7); font-size: clamp(15px, 1.4vw, 17px); max-width: 620px; margin: 0; }
.pull-quote { position: relative; background: rgba(255,255,255,0.04); border: 1.5px solid var(--green); border-radius: 14px; padding: 22px 26px; box-shadow: 0 0 0 1px rgba(46,204,154,0.20), 0 0 24px rgba(46,204,154,0.15); }
.pull-quote .qmark { position: absolute; left: -8px; top: -22px; font-family: var(--font-display); font-style: italic; font-size: 64px; color: var(--green); line-height: 1; font-weight: 700; }
.pull-quote p { margin: 0; font-family: var(--font-display); font-style: italic; font-weight: 400; color: var(--light); font-size: clamp(16px, 1.5vw, 19px); line-height: 1.55; }
.pos-features { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
@media (max-width: 900px) { .pos-features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .pos-features { grid-template-columns: 1fr; } }
.pos-features li { display: flex; align-items: center; gap: 14px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.12); border-radius: 12px; padding: 16px 18px; transition: transform .25s, background .25s; }
.pos-features li:hover { transform: translateY(-4px); background: rgba(255,255,255,0.07); }
.pos-features .ic { width: 40px; height: 40px; border-radius: 10px; background: var(--green); border: 1.5px solid var(--navy-deep); display: grid; place-items: center; font-size: 20px; flex-shrink: 0; }
.pos-features small { display: block; font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--green); font-weight: 700; margin-bottom: 2px; }
.pos-features strong { font-size: 14px; color: var(--light); font-weight: 600; }

/* 4 · PILARES */
.pilares-head { text-align: center; margin-bottom: 44px; }
.pilares-head .label { display: inline-flex; margin-bottom: 16px; }
.pilares-head .h2 { color: var(--navy); max-width: 720px; margin: 0 auto; }
.pilares-head .h2 em { color: var(--green-dark); font-style: italic; }
.pilares-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-bottom: 40px; }
@media (max-width: 900px) { .pilares-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .pilares-grid { grid-template-columns: 1fr; } }
.pil-card { position: relative; background: #ffffff; border: 1.5px solid var(--border); border-radius: 14px; padding: 32px 24px 28px; display: flex; flex-direction: column; gap: 12px; transition: transform .25s, box-shadow .25s; overflow: hidden; }
.pil-card:hover { transform: translateY(-6px); box-shadow: 0 28px 56px rgba(10,46,82,0.13); }
.pil-card .top-bar { position: absolute; top: 0; left: 22px; right: 22px; height: 2px; background: var(--green); border-radius: 2px; transform: scaleX(.25); transform-origin: left; transition: transform .4s cubic-bezier(.16,1,.3,1); }
.pil-card:hover .top-bar { transform: scaleX(1); }
.pil-card small { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--green-dark); font-weight: 700; }
.pil-card .h3 { color: var(--navy); margin: 0; font-size: 26px; }
.pil-card p { color: var(--subtext); font-size: 14px; line-height: 1.65; margin: 0; }
.pilares-cta { display: flex; justify-content: center; }

/* 5 · PARA QUIÉN */
.who { position: relative; display: grid; grid-template-columns: 0.9fr 1.2fr; gap: 56px; align-items: start; }
@media (max-width: 900px) { .who { grid-template-columns: 1fr; gap: 32px; } }
.who-left { position: sticky; top: 110px; }
@media (max-width: 900px) { .who-left { position: static; } }
.who-left .h2 { color: var(--light); margin: 18px 0 22px; }
.who-left .h2 .u-accent { display: inline-block; }
.who-left .lead { color: rgba(244,247,251,0.65); margin: 0 0 26px; max-width: 380px; }
.who-list { display: flex; flex-direction: column; gap: 12px; }
.who-list li { display: grid; grid-template-columns: 32px 1fr auto; align-items: center; gap: 16px; padding: 16px 20px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.12); border-radius: 12px; transition: transform .25s, background .25s, border-color .25s; }
.who-list li:nth-child(odd) { background: rgba(255,255,255,0.05); }
.who-list li:hover { transform: translateX(4px); border-color: var(--green); background: rgba(46,204,154,0.06); }
.who-list .check { width: 30px; height: 30px; border-radius: 8px; background: var(--green); border: 1.5px solid var(--navy-deep); display: grid; place-items: center; color: var(--navy-deep); font-weight: 700; font-size: 16px; }
.who-list strong { display: flex; align-items: center; gap: 10px; color: var(--light); font-size: 16px; font-weight: 600; }
.who-list .ic { font-size: 22px; }
.who-list small { display: block; margin-top: 4px; color: rgba(244,247,251,0.55); font-size: 13px; }
.who-list .ix { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--green); font-weight: 700; white-space: nowrap; }

/* 6 · EQUIPO */
.team { display: grid; grid-template-columns: 0.85fr 1fr; gap: 64px; align-items: start; }
@media (max-width: 900px) { .team { grid-template-columns: 1fr; gap: 56px; } }
.team-photo { position: relative; aspect-ratio: 4 / 5; margin: 0; }
@media (max-width: 900px) { .team-photo { max-width: 360px; margin: 0 auto; } }
.photo-ph { position: absolute; inset: 0; border-radius: 24px; color: var(--subtext); font-family: 'DM Sans', monospace; font-size: 13px; letter-spacing: 0.5px; border-radius: 24px; }
.badge-years { position: absolute; top: -14px; right: -14px; background: var(--green); border: 2px solid var(--navy); border-radius: 16px; padding: 14px 16px; box-shadow: 0 12px 28px rgba(10,46,82,0.18); text-align: center; color: var(--navy-deep); z-index: 3; }
.badge-years strong { display: block; font-family: var(--font-display); font-weight: 700; font-size: 32px; line-height: 1; }
.badge-years span { display: block; margin-top: 4px; font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; }
.floating-card { position: absolute; left: 20px; right: 20px; bottom: -28px; background: #ffffff; border: 1.5px solid var(--border); border-radius: 14px; padding: 14px 18px; box-shadow: 0 12px 28px rgba(10,46,82,0.13); display: flex; align-items: center; justify-content: space-between; gap: 10px; z-index: 3; }
.floating-card strong { display: block; font-family: var(--font-display); font-weight: 600; color: var(--navy); font-size: 16px; }
.floating-card small { display: block; margin-top: 2px; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--subtext); }
.floating-card .socials { display: flex; gap: 6px; }
.floating-card .socials a { width: 30px; height: 30px; border-radius: 7px; border: 1.5px solid var(--border); display: grid; place-items: center; font-size: 12px; color: var(--navy); font-weight: 600; transition: border-color .2s, color .2s; }
.floating-card .socials a:hover { border-color: var(--green); color: var(--green-dark); }
.team-bio .h2 { color: var(--navy); margin: 16px 0 18px; }
.team-bio .h2 em { color: var(--green-dark); font-style: italic; }
.team-bio .lead { margin: 0 0 24px; max-width: 540px; }
.team-roles { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 28px; }
.team-roles li { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: #ffffff; border: 1.5px solid var(--border); border-radius: 10px; font-size: 14px; color: var(--navy); font-weight: 600; transition: border-color .2s, transform .2s; }
.team-roles li:hover { border-color: var(--green); transform: translateY(-2px); }
.team-roles .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); flex-shrink: 0; }
.team-quote { margin: 0; padding: 18px 22px; border-left: 3px solid var(--green); background: #ffffff; border-radius: 0 12px 12px 0; }
.team-quote p { margin: 0; font-family: var(--font-display); font-style: italic; color: var(--navy); font-size: 17px; line-height: 1.55; }
.team-quote cite { display: block; margin-top: 10px; font-style: normal; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--subtext); font-weight: 600; }

/* 7 · LOGOS */
.logos { position: relative; }
.logos-head { text-align: center; margin-bottom: 32px; }
.logos-head .label { display: inline-flex; margin-bottom: 10px; }
.logos-head p { margin: 0; font-size: 14px; color: rgba(244,247,251,0.6); }
.logos-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
@media (max-width: 900px) { .logos-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .logos-grid { grid-template-columns: 1fr; } }
.logo-cell { display: flex; align-items: center; justify-content: center; padding: 16px 24px; transition: transform .25s; }
.logo-cell:hover { transform: translateY(-4px); }
.logo-cell img { max-width: 100%; max-height: 80px; object-fit: contain; transition: transform .3s ease; }
.logo-cell:hover img { transform: scale(1.15); }

/* 8 · CTA FINAL */
.cta-glow { position: absolute; top: -100px; right: -160px; width: 520px; height: 520px; border-radius: 50%; background: radial-gradient(circle, rgba(46,204,154,0.18), transparent 65%); pointer-events: none; }
.cta { position: relative; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
@media (max-width: 900px) { .cta { grid-template-columns: 1fr; gap: 32px; } }
.cta-left .h2 { color: var(--navy); margin: 18px 0 22px; max-width: 580px; }
.cta-left .h2 em { color: var(--green-dark); font-style: italic; }
.cta-left .lead { margin: 0 0 28px; max-width: 480px; }
.cta-buttons { display: flex; gap: 12px; flex-wrap: wrap; }
.cta-card { background: #ffffff; border: 1.5px solid var(--border); border-radius: 18px; padding: 28px; box-shadow: 0 28px 56px rgba(10,46,82,0.10); display: flex; flex-direction: column; gap: 18px; }
.cta-card-title { display: block; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: var(--green-dark); font-weight: 700; }
.cta-card .step { display: grid; grid-template-columns: 44px 1fr; gap: 16px; align-items: flex-start; padding-bottom: 16px; border-bottom: 1px dashed var(--border); }
.cta-card .step:last-child { padding-bottom: 0; border-bottom: none; }
.cta-card .step-num { width: 42px; height: 42px; border-radius: 10px; background: var(--green); border: 1.5px solid var(--navy); display: grid; place-items: center; color: var(--navy-deep); font-weight: 700; font-size: 14px; font-family: var(--font-body); }
.cta-card .step strong { display: block; color: var(--navy); font-size: 16px; font-weight: 600; }
.cta-card .step small { display: block; margin-top: 4px; color: var(--subtext); font-size: 13px; line-height: 1.55; }

/* ═══════════════════════════════════════════════════════════════
   MOBILE UX OPTIMIZATIONS (Max Width 768px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* 1. Hero */
  .hero-ctas .btn-ghost-light { display: none; }
  .hero-trust { gap: 12px; margin-top: 10px; }
  .hero-trust li:nth-child(n+3) { display: none; }

  /* 2. Stats - Scroll Horizontal */
  .stats-grid { display: flex; overflow-x: auto; padding-bottom: 20px; scroll-snap-type: x mandatory; margin: 0 -20px; padding: 0 20px 20px; -webkit-overflow-scrolling: touch; }
  .stat-card { min-width: 260px; scroll-snap-align: center; flex-shrink: 0; }

  /* 3. Posicionamiento */
  .pull-quote { display: none; }
  .pos-features { grid-template-columns: 1fr; gap: 10px; }

  /* 4. Pilares - Scroll Horizontal */
  .pilares-grid { display: flex; overflow-x: auto; padding-bottom: 20px; scroll-snap-type: x mandatory; margin: 0 -20px; padding: 0 20px 20px; -webkit-overflow-scrolling: touch; }
  .pil-card { min-width: 280px; scroll-snap-align: center; flex-shrink: 0; }

  /* 5. Para Quién */
  .who-list small { display: none; }
  .who-list li { padding: 12px 16px; }

  /* 6. Equipo */
  .team-roles { display: none; }
  .team-photo { width: 100%; max-width: 320px; margin: 0 auto 32px; }
  .floating-card { bottom: -14px; left: 10px; right: 10px; padding: 14px; }

  /* 7. Logos - Scroll Horizontal */
  .logos-grid { display: flex; overflow-x: auto; padding-bottom: 20px; scroll-snap-type: x mandatory; margin: 0 -20px; padding: 0 20px 20px; -webkit-overflow-scrolling: touch; }
  .logo-cell { min-width: 140px; scroll-snap-align: center; flex-shrink: 0; }

  /* 8. CTA Final */
  .cta-card { display: none; }
}
