/* =========================================================
   SERVICIO.CSS — Estilos para páginas de servicio (3 por categoría)
   Prótesis de rodilla, Displasia pediátrica, Cirugía de columna, etc.
   ========================================================= */

/* ---------- Hero de servicio: más enfocado a conversión ---------- */
.svc-hero {
  position: relative; padding: 120px 0 var(--sp-8);
  background: linear-gradient(160deg, var(--azul-tinta) 0%, var(--azul-naval) 60%, var(--azul-naval-light) 100%);
  color: var(--blanco); overflow: hidden;
}
.svc-hero::before { content: ""; position: absolute; top: -25%; right: -10%; width: 55%; aspect-ratio: 1; border-radius: 50%; background: radial-gradient(circle, rgba(59, 123, 184, 0.35) 0%, transparent 70%); pointer-events: none; }
.svc-hero__inner { position: relative; z-index: 1; }
.svc-hero .breadcrumbs { color: rgba(255, 255, 255, 0.75); padding-top: 0; padding-bottom: var(--sp-5); }
.svc-hero .breadcrumbs a { color: rgba(255, 255, 255, 0.75); }
.svc-hero .breadcrumbs a:hover { color: var(--oro-claro); }
.svc-hero .breadcrumbs__sep { color: rgba(255, 255, 255, 0.4); }
.svc-hero .breadcrumbs__current { color: var(--oro-claro); }

.svc-hero__grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-7); align-items: center; }
@media (min-width: 900px) { .svc-hero__grid { grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr); gap: var(--sp-8); } }

.svc-hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 6px 13px; background: rgba(201, 169, 97, 0.14); border: 1px solid rgba(201, 169, 97, 0.35); border-radius: var(--r-full); font-size: var(--fs-xs); font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--oro-claro); margin-bottom: var(--sp-4); }

.svc-hero__title { font-family: var(--ff-display); font-variation-settings: "opsz" 144, "SOFT" 30; font-size: clamp(2rem, 1.3rem + 2.8vw, 3.5rem); font-weight: 400; line-height: 1.05; letter-spacing: -0.02em; color: var(--blanco); margin-bottom: var(--sp-4); }
.svc-hero__title em { font-style: italic; color: var(--oro-claro); font-variation-settings: "opsz" 144, "SOFT" 100; }

.svc-hero__subtitle { font-size: clamp(1rem, 0.95rem + 0.35vw, 1.15rem); line-height: 1.6; color: rgba(255, 255, 255, 0.85); margin-bottom: var(--sp-5); font-weight: 300; }

.svc-hero__bullets { display: grid; grid-template-columns: 1fr; gap: 10px; margin-bottom: var(--sp-6); max-width: 520px; }
@media (min-width: 520px) { .svc-hero__bullets { grid-template-columns: 1fr 1fr; } }
.svc-hero__bullet { display: flex; align-items: flex-start; gap: 10px; font-size: var(--fs-sm); color: rgba(255, 255, 255, 0.88); line-height: 1.5; }
.svc-hero__bullet svg { width: 18px; height: 18px; color: var(--oro-claro); flex-shrink: 0; margin-top: 1px; }

.svc-hero__ctas { display: flex; flex-wrap: wrap; gap: var(--sp-3); }

.svc-hero__card { background: rgba(255, 255, 255, 0.06); backdrop-filter: blur(18px); border: 1px solid rgba(255, 255, 255, 0.14); border-radius: var(--r-lg); padding: var(--sp-5); box-shadow: var(--sh-xl); }
.svc-hero__card-media { border-radius: var(--r-md); overflow: hidden; aspect-ratio: 4/3; margin-bottom: var(--sp-4); }
.svc-hero__card-media img { width: 100%; height: 100%; object-fit: cover; }
.svc-hero__card-title { font-family: var(--ff-display); font-size: 1.25rem; font-weight: 500; color: var(--blanco); margin-bottom: 6px; line-height: 1.25; }
.svc-hero__card-text { font-size: var(--fs-sm); color: rgba(255, 255, 255, 0.75); line-height: 1.6; margin-bottom: var(--sp-4); }
.svc-hero__card-btn { width: 100%; }

/* ---------- Cuerpo de contenido del servicio: aside + artículo ---------- */
.svc-body { padding: var(--sp-9) 0; }
.svc-body__grid { display: grid; grid-template-columns: 1fr; gap: var(--sp-7); }
@media (min-width: 900px) { .svc-body__grid { grid-template-columns: minmax(0, 1fr) 300px; gap: var(--sp-8); } }

.svc-article { max-width: none; }
.svc-article h2 { font-size: var(--fs-h2); margin: var(--sp-7) 0 var(--sp-4); color: var(--azul-tinta); scroll-margin-top: 100px; }
.svc-article h2:first-child { margin-top: 0; }
.svc-article h3 { font-size: var(--fs-h3); margin: var(--sp-6) 0 var(--sp-3); color: var(--azul-naval); font-family: var(--ff-display); scroll-margin-top: 100px; }
.svc-article p { margin-bottom: var(--sp-4); color: var(--gris-texto); line-height: 1.75; font-size: 1.05rem; }
.svc-article p.lead { font-size: 1.2rem; color: var(--gris-medio); line-height: 1.6; margin-bottom: var(--sp-5); }
.svc-article ul, .svc-article ol { margin: var(--sp-3) 0 var(--sp-5) var(--sp-5); }
.svc-article ul li, .svc-article ol li { margin-bottom: 10px; line-height: 1.7; color: var(--gris-texto); }
.svc-article ul li::marker { color: var(--oro-suave); }
.svc-article ol li::marker { color: var(--azul-naval); font-weight: 600; }
.svc-article strong { color: var(--azul-tinta); }

.svc-article__highlight { background: var(--azul-cielo-light); border-left: 3px solid var(--azul-medio); padding: var(--sp-5); border-radius: var(--r-sm); margin: var(--sp-6) 0; }
.svc-article__highlight p { margin-bottom: 0; color: var(--azul-tinta); font-weight: 500; }

.svc-article__table { width: 100%; border-collapse: collapse; margin: var(--sp-5) 0; font-size: var(--fs-sm); }
.svc-article__table th, .svc-article__table td { padding: 14px 16px; text-align: left; border-bottom: 1px solid var(--gris-borde); }
.svc-article__table th { background: var(--gris-claro); font-weight: 600; color: var(--azul-tinta); }
.svc-article__table tr:hover td { background: var(--hueso); }

/* ---------- Aside sticky con CTAs y puntos clave ---------- */
.svc-aside { display: flex; flex-direction: column; gap: var(--sp-5); }
@media (min-width: 900px) { .svc-aside { position: sticky; top: 100px; align-self: start; } }

.svc-aside__box { background: var(--blanco); border: 1px solid var(--gris-borde); border-radius: var(--r-lg); padding: var(--sp-5); box-shadow: var(--sh-sm); }
.svc-aside__box--dark { background: var(--azul-naval); color: var(--blanco); border-color: var(--azul-naval); }
.svc-aside__box--dark h4 { color: var(--blanco); }
.svc-aside__box--dark p { color: rgba(255, 255, 255, 0.82); }

.svc-aside__title { font-family: var(--ff-display); font-size: 1.2rem; font-weight: 500; color: var(--azul-tinta); margin-bottom: var(--sp-3); line-height: 1.3; }
.svc-aside__title--light { color: var(--blanco); }

.svc-aside__list { display: flex; flex-direction: column; gap: 10px; margin-bottom: var(--sp-4); }
.svc-aside__list-item { display: flex; align-items: flex-start; gap: 10px; font-size: var(--fs-sm); line-height: 1.55; color: var(--gris-texto); }
.svc-aside__list-item svg { width: 16px; height: 16px; color: var(--oro-suave); flex-shrink: 0; margin-top: 2px; }
.svc-aside__box--dark .svc-aside__list-item { color: rgba(255, 255, 255, 0.85); }

.svc-aside__btn { width: 100%; }

/* ---------- Sección síntomas / cuándo consultar ---------- */
.svc-sintomas { padding: var(--sp-8) 0; background: var(--gris-claro); }
.svc-sintomas__head { text-align: center; max-width: 680px; margin: 0 auto var(--sp-6); }
.svc-sintomas__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--sp-4); max-width: 1000px; margin: 0 auto; }
.svc-sintomas__item { background: var(--blanco); padding: var(--sp-5); border-radius: var(--r-md); border: 1px solid var(--gris-borde); display: flex; align-items: flex-start; gap: 14px; transition: all var(--t-base); }
.svc-sintomas__item:hover { border-color: var(--azul-medio); box-shadow: var(--sh-sm); }
.svc-sintomas__icon { width: 38px; height: 38px; border-radius: var(--r-sm); background: rgba(220, 38, 38, 0.08); display: grid; place-items: center; flex-shrink: 0; }
.svc-sintomas__icon svg { width: 18px; height: 18px; color: var(--error); }
.svc-sintomas__text { font-size: var(--fs-sm); color: var(--gris-texto); line-height: 1.55; font-weight: 500; }

/* ---------- Proceso de atención (5 pasos horizontales) ---------- */
.svc-proceso { padding: var(--sp-9) 0; }
.svc-proceso__head { text-align: center; max-width: 680px; margin: 0 auto var(--sp-7); }

/* ---------- FAQ específica del servicio ---------- */
.svc-faq { padding: var(--sp-9) 0; background: var(--gris-claro); }
.svc-faq__head { text-align: center; max-width: 640px; margin: 0 auto var(--sp-6); }
.svc-faq__list { max-width: 820px; margin: 0 auto; }

/* ---------- Servicios relacionados (cross-linking) ---------- */
.svc-related { padding: var(--sp-9) 0; }
.svc-related__head { text-align: center; max-width: 680px; margin: 0 auto var(--sp-6); }
.svc-related__grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-4); }

.svc-related__card { background: var(--blanco); border: 1px solid var(--gris-borde); border-radius: var(--r-md); padding: var(--sp-5); text-decoration: none; color: inherit; transition: all var(--t-base); display: flex; flex-direction: column; gap: 10px; }
.svc-related__card:hover { border-color: var(--azul-naval); background: var(--hueso); transform: translateY(-2px); }
.svc-related__card-tag { font-size: var(--fs-xs); font-weight: 600; color: var(--oro-suave); letter-spacing: 0.1em; text-transform: uppercase; }
.svc-related__card-title { font-family: var(--ff-display); font-size: 1.15rem; font-weight: 500; color: var(--azul-tinta); line-height: 1.25; }
.svc-related__card-link { display: inline-flex; align-items: center; gap: 6px; font-size: var(--fs-sm); font-weight: 600; color: var(--azul-naval); margin-top: 6px; }
.svc-related__card-link svg { width: 14px; height: 14px; transition: transform var(--t-base); }
.svc-related__card:hover .svc-related__card-link svg { transform: translateX(4px); }
