/* ================= HERO ================= */
.hero-pro{
  position:relative;
  min-height:64vh;
  padding:160px 0 90px;
  background:
    radial-gradient(900px 500px at 10% 8%, rgba(45,161,175,.22), rgba(45,161,175,0) 60%),
    radial-gradient(900px 500px at 90% 0%, rgba(127,225,239,.20), rgba(127,225,239,0) 62%),
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(13,46,51,.08) 100%);
}
.hero-pro .hero-inner{position:relative;z-index:1;text-align:center;color:#0d2e33}
.hero-title{
  font-size:clamp(1.5rem,7.4vw,4.5rem);
  font-weight:900;margin:0 0 30px;letter-spacing:-.02em;
  text-shadow:0 2px 14px rgba(0,0,0,.04);
  line-height:1.1;
}
.hero-title .brand{color:var(--brand)}
.hero-search{display:flex;justify-content:center}
.hero-stats{margin:28px 0 0;padding:0;list-style:none;display:flex;gap:18px;justify-content:center;color:#0d2e33}
.hero-stats li{display:grid;justify-items:center;gap:4px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow-sm)}
.hero-stats strong{font-size:20px}

/* =========================================================
    ESTILOS DEL BUSCADOR AVANZADO MOVIDOS A /assets/css/search-form.css
    ========================================================= */

/* ================= SECTION HEADERS ================= */
.section--spaced{margin-top:50px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin:18px 0 6px;gap:12px}
.section-title{margin:0;font-weight:900;letter-spacing:-.02em;font-size:clamp(24px,3.6vw,36px);color:#0d2e33}
.section-subtitle{margin:6px 0 0;color:var(--muted);max-width:72ch}
.link-more{
  border:0;background:transparent;color:var(--brand);font-weight:800;cursor:pointer;
  padding:12px 18px;border-radius:14px;font-size:1.05rem;display:inline-flex;align-items:center;gap:.5rem;
}
.link-more::after{content:"▾";transition:transform .22s ease}
.link-more.is-open::after{transform:rotate(180deg)}
.link-more:hover{background:#f0f9fb}

/* ================= SLIDER GENERIC ================= */
.dp-slider{
  --slides:3;
  --gap:18px;
  --speed:950ms;
  position:relative;margin-top:14px;
}
.dp-slider .dp-viewport{overflow:hidden;outline:none;touch-action:pan-y;}
.dp-slider .dp-viewport.is-dragging a{pointer-events:none}
.dp-slider .dp-track{
  display:flex;gap:var(--gap);
  will-change:transform;
  transition:transform var(--speed) cubic-bezier(.22,.61,.36,1);
}
.dp-slider .dp-slide{
  flex:0 0 calc( (100% - (var(--gap) * (var(--slides) - 1))) / var(--slides) );
}
.dp-slider .dp-nav{
  position:absolute;top:40%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  border:1px solid #dbe7ea;background:#fff;
  box-shadow:var(--shadow-sm);cursor:pointer;
  display:grid;place-items:center;font-size:22px;line-height:1;
  transition:transform .15s, box-shadow .2s, background .2s;
  z-index:2;
}
.dp-slider .dp-nav:hover{transform:translateY(-50%) scale(1.06);box-shadow:var(--shadow-md)}
.dp-slider .dp-nav:active{transform:translateY(-50%) scale(0.98)}
.dp-slider .prev{left:-6px}
.dp-slider .next{right:-6px}
.dp-dots{display:none !important}

/* ================= CLUSTERS (tarjetas) ================= */
.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media (max-width:960px){.cluster-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cluster-grid{grid-template-columns:1fr}}

.cluster-card{
  background:#fff;border:1px solid #e6edf0;border-radius:18px;box-shadow:var(--shadow-sm);
  overflow:hidden;display:grid;grid-template-rows:160px auto;transition:transform .18s,box-shadow .18s,border-color .18s;text-decoration:none;
}
.cluster-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:#d7eef2}
.cluster-media{height:160px}
.cluster-media img,.cluster-ph{width:100%;height:100%;object-fit:cover;display:block}
.cluster-ph{background:linear-gradient(135deg,#e9fbfe,#fff)}
.cluster-body{display:grid;grid-template-rows:auto 1fr auto;gap:.55rem;padding:1rem}
.cluster-title{font-weight:800;font-size:1.05rem;margin:0;color:#0d2e33}
.cluster-desc{color:#334155;text-align:justify;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;font-size:.92rem;line-height:1.35}
.cluster-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.25rem}
.cluster-count{color:#64748b}
.cluster-btn{margin-left:auto}

/* ================= COLLAPSIBLE “VER TODAS” ================= */
.all-collapsible{margin-top:16px;overflow:hidden}
.all-collapsible[hidden]{display:block;height:0 !important;padding:0 !important;margin:0 !important;border:0 !important;overflow:hidden}
.reveal-enter{opacity:0;transform:translateY(-6px)}
.reveal-enter-active{opacity:1;transform:none;transition:opacity .24s ease, transform .24s ease}

/* ================= ESPACIADO ENTRE SECCIONES ================= */
.cluster-section,
.home-latest,
.home-seo-section {
  margin-top: 64px;
}

/* ================= RESPONSIVE ================= */
@media (max-width:1160px){
  .dp-slider{--slides:2}
}

@media (max-width:640px){
  .hero-pro{min-height:58vh;padding:120px 0 70px;
    background:
      radial-gradient(700px 380px at 12% 10%, rgba(45,161,175,.22), rgba(45,161,175,0) 60%),
      radial-gradient(700px 380px at 88% 0%, rgba(127,225,239,.18), rgba(127,225,239,0) 62%),
      linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(13,46,51,.08) 100%);
  }
  .dp-slider{--slides:1; padding-inline:10px;}
  .dp-slider .prev{left:2px}
  .dp-slider .next{right:2px}
  .section-head{flex-direction:column;align-items:flex-start;gap:6px}
  .hero-stats{gap:12px}
}

/* =========================================================
    NUEVA SECCIÓN SEO CON 3 COLUMNAS
    ========================================================= */
.home-seo-section {
  padding: 64px 0;
  background-color: transparent;
  margin-bottom: -64px;
}
.home-seo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 48px;
}
.home-seo-card {
  text-align: center;
  padding: 24px;
  background-color: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.seo-card-icon {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  background-color: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  margin: 0 auto 20px;
  box-shadow: 0 4px 12px rgba(45, 161, 175, 0.2);
}
.seo-card-icon svg {
  width: 28px;
  height: 28px;
}
.seo-card-title {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--text);
  margin: 0 0 10px;
}
.seo-card-text {
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0 0 16px;
}
.seo-card-tagline {
  font-weight: 600;
  color: var(--brand-ink);
  font-size: 0.9rem;
}
.seo-result {
  margin-top: 48px;
  padding: 16px;
  background-color: #f8fafc;
  border-radius: var(--radius);
  border: 1px solid var(--line);
}
.seo-result p {
  margin: 0;
  font-size: 1.1rem;
  color: var(--text);
}
@media (max-width: 960px) {
  .home-seo-grid {
    grid-template-columns: 1fr;
  }
}

/* === INICIO MODIFICACIÓN: Estilos para slider de doctores en home === */
.dp-slider--doctor-cards .card-vertical--destacado {
  border-width: 2px;
  box-shadow: 0 0 0 3px var(--brand), var(--elev-2);
}
.dp-slider--doctor-cards .card-vertical--destacado:hover {
  transform: translateY(-6px);
  box-shadow: 0 0 0 3px var(--brand-ink), var(--shadow-lg);
}
/* === FIN MODIFICACIÓN === */

/* =========================================================
    INICIO MODIFICACIÓN: Estilos para Sección SEO/FAQ
    ========================================================= */
.home-faq-section {
    padding: 64px 0;
    background-color: var(--bg);
    border-top: 1px solid var(--line);
}
.home-faq-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 48px;
    align-items: center;
}
.home-faq-content p {
    font-size: 1.1rem;
    line-height: 1.8;
    color: var(--muted);
}
.home-faq-content strong {
    color: var(--text);
}
.home-faq-accordion {
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.faq-item {
    background-color: var(--surface);
    border: 1px solid var(--line);
    border-radius: 14px;
    transition: all 0.2s ease;
}
.faq-item[open] {
    border-color: var(--brand);
    box-shadow: var(--shadow-md);
}
.faq-item summary {
    list-style: none;
    cursor: pointer;
    padding: 16px 20px;
    font-weight: 700;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.faq-item summary::-webkit-details-marker {
    display: none;
}
.faq-item summary::after {
    content: '+';
    font-size: 1.5rem;
    color: var(--brand);
    transition: transform 0.2s ease;
}
.faq-item[open] summary::after {
    transform: rotate(45deg);
}
.faq-content {
    padding: 0 20px 20px;
    color: var(--muted);
    line-height: 1.7;
}
.faq-content p {
    margin: 0;
}
@media (max-width: 960px) {
    .home-faq-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
}
/* =========================================================
    FIN MODIFICACIÓN
    ========================================================= */

/* =========================================================
    INICIO MODIFICACIÓN: Estilos para Badge de Valoración Media
    ========================================================= */
.hero-average-rating {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    margin: -15px auto 30px;
    padding: 10px 20px;
    background-color: rgba(255, 255, 255, 0.85);
    border: 1px solid rgba(0,0,0,0.05);
    border-radius: 999px;
    box-shadow: var(--shadow-md);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}

.hero-average-rating .rating-value {
    font-size: clamp(1.4rem, 2.5vw, 1.8rem);
    font-weight: 900;
    color: var(--text);
    line-height: 1;
}

.hero-average-rating .stars {
    font-size: 1.2rem;
    display: inline-flex;
}

.hero-average-rating .star-full,
.hero-average-rating .star-half {
    color: #f59e0b;
}

.hero-average-rating .rating-count {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--muted);
    line-height: 1;
}

@media (max-width: 640px) {
    .hero-average-rating {
        gap: 8px;
        padding: 8px 16px;
        margin-bottom: 25px;
    }
    .hero-average-rating .rating-value {
        font-size: 1.3rem;
    }
    .hero-average-rating .stars {
        font-size: 1rem;
    }
    .hero-average-rating .rating-count {
        font-size: 0.8rem;
    }
}
/* =========================================================
    FIN MODIFICACIÓN
    ========================================================= */