/* ============================================================
   SERVICE-TEMPLATE.CSS — Páginas de servicio individuales
   ============================================================ */

/* Hero interno (hereda estructura de category) */
.page-hero {
  position: relative; padding: 170px 0 90px; color: #fff;
  background: linear-gradient(180deg, rgba(69,30,65,.76), rgba(69,30,65,.62)), var(--hero-img, none);
  background-size: cover; background-position: center;
}
.page-hero::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 75% 20%, rgba(184,155,110,.2), transparent 55%); }
.page-hero .container { position: relative; z-index: 2; }
.page-hero .breadcrumb { margin-bottom: 22px; }
.page-hero .breadcrumb a, .page-hero .breadcrumb { color: #E6D6E4; }
.page-hero .breadcrumb [aria-current] { color: var(--dorado-claro); }
.page-hero .breadcrumb .sep { color: var(--dorado-claro); }
.page-hero .eyebrow { color: var(--dorado-claro); }
.page-hero .eyebrow::before { background: var(--dorado-claro); }
.page-hero h1 { color: #fff; max-width: 800px; margin-bottom: 18px; }
.page-hero p { color: #F0E6EE; font-size: 1.12rem; max-width: 620px; }
.page-hero .hero-actions { margin-top: 30px; display: flex; flex-wrap: wrap; gap: 14px; }

/* ---------- LAYOUT 2 COLUMNAS ---------- */
.svc-layout { display: grid; grid-template-columns: 1fr 340px; gap: 60px; align-items: start; }
@media (max-width: 960px) { .svc-layout { grid-template-columns: 1fr; gap: 44px; } }

/* Contenido principal */
.svc-main h2 { margin: 38px 0 16px; }
.svc-main h2:first-child { margin-top: 0; }
.svc-main h3 { margin: 26px 0 10px; font-size: 1.4rem; }
.svc-main p { margin-bottom: 16px; }
.svc-main .lead { font-size: 1.18rem; color: var(--malva); margin-bottom: 24px; }
.svc-main img.svc-feature { width: 100%; border-radius: var(--r-lg); box-shadow: var(--shadow-soft); margin: 26px 0; aspect-ratio: 16/9; object-fit: cover; }

.check-list { margin: 20px 0; display: flex; flex-direction: column; gap: 14px; }
.check-list li { display: flex; gap: 12px; align-items: flex-start; }
.check-list .ck {
  width: 24px; height: 24px; border-radius: 50%; background: var(--ciruela); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; margin-top: 2px;
}
.check-list .ck svg { width: 13px; height: 13px; color: var(--dorado-claro); }
.check-list strong { color: var(--ciruela); }

.svc-benefits { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin: 26px 0; }
.svc-benefit { background: var(--blanco); border: 1px solid var(--arena); border-radius: var(--r-md); padding: 24px; }
.svc-benefit .b-ico { width: 48px; height: 48px; border-radius: 12px; background: linear-gradient(135deg, var(--nude), var(--arena)); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.svc-benefit .b-ico svg { width: 24px; height: 24px; color: var(--ciruela); }
.svc-benefit h3 { font-size: 1.12rem; margin: 0 0 6px; }
.svc-benefit p { font-size: 0.88rem; color: var(--malva); margin: 0; }
@media (max-width: 520px) { .svc-benefits { grid-template-columns: 1fr; } }

/* Proceso pasos verticales */
.svc-steps { margin: 26px 0; }
.svc-step { display: flex; gap: 20px; padding-bottom: 26px; position: relative; }
.svc-step:not(:last-child)::before { content: ""; position: absolute; left: 22px; top: 48px; bottom: 0; width: 1px; background: var(--arena); }
.svc-step .n { width: 46px; height: 46px; border-radius: 50%; background: var(--ciruela); color: var(--dorado-claro); font-family: var(--serif); font-size: 1.3rem; display: flex; align-items: center; justify-content: center; flex-shrink: 0; z-index: 2; }
.svc-step h3 { margin: 6px 0 4px; font-size: 1.18rem; }
.svc-step p { margin: 0; font-size: 0.92rem; color: var(--malva); }

/* Precio */
.price-box { background: linear-gradient(135deg, var(--arena), var(--marfil)); border: 1px solid var(--nude); border-radius: var(--r-md); padding: 30px; margin: 28px 0; }
.price-box .eyebrow { margin-bottom: 8px; }
.price-box h3 { font-size: 1.5rem; margin-bottom: 8px; }
.price-box p { color: var(--carbon); margin-bottom: 0; font-size: 0.94rem; }
.price-box .price-note { font-size: 0.82rem; color: var(--malva); font-style: italic; margin-top: 10px; }

/* ---------- SIDEBAR ---------- */
.svc-aside { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 24px; }
@media (max-width: 960px) { .svc-aside { position: static; } }
.aside-card { background: var(--blanco); border: 1px solid var(--arena); border-radius: var(--r-md); padding: 28px; box-shadow: var(--shadow-soft); }
.aside-card--cta { background: linear-gradient(135deg, var(--ciruela), var(--ciruela-medio)); border: none; color: #fff; text-align: center; }
.aside-card--cta h3 { color: #fff; font-size: 1.4rem; margin-bottom: 10px; }
.aside-card--cta p { color: #EDDFEB; font-size: 0.9rem; margin-bottom: 20px; }
.aside-card--cta .btn { width: 100%; justify-content: center; }
.aside-card h4 { font-family: var(--sans); font-size: 0.72rem; letter-spacing: 2px; text-transform: uppercase; color: var(--dorado); margin-bottom: 18px; }
.aside-list li { display: flex; gap: 10px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--arena); font-size: 0.9rem; }
.aside-list li:last-child { border-bottom: none; }
.aside-list svg { width: 18px; height: 18px; color: var(--dorado); flex-shrink: 0; }
.aside-related li a { display: flex; align-items: center; gap: 10px; padding: 11px 0; border-bottom: 1px solid var(--arena); font-size: 0.9rem; color: var(--carbon); transition: all .25s; }
.aside-related li:last-child a { border-bottom: none; }
.aside-related li a:hover { color: var(--ciruela); padding-left: 6px; }
.aside-related svg { width: 16px; height: 16px; color: var(--dorado); flex-shrink: 0; }

/* ---------- FAQ (reutilizado) ---------- */
.faq-wrap { max-width: 820px; margin: 46px auto 0; }
.faq-item { background: var(--blanco); border: 1px solid var(--arena); border-radius: var(--r-md); margin-bottom: 14px; overflow: hidden; transition: box-shadow .3s; }
.faq-item.open { box-shadow: var(--shadow-soft); }
.faq-q { width: 100%; text-align: left; background: none; border: none; cursor: pointer; padding: 22px 26px; font-family: var(--serif); font-size: 1.18rem; color: var(--ciruela); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq-q .plus { width: 24px; height: 24px; flex-shrink: 0; position: relative; }
.faq-q .plus::before, .faq-q .plus::after { content: ""; position: absolute; background: var(--dorado); border-radius: 2px; }
.faq-q .plus::before { top: 11px; left: 2px; width: 20px; height: 2px; }
.faq-q .plus::after { left: 11px; top: 2px; width: 2px; height: 20px; transition: transform .35s var(--ease); }
.faq-item.open .plus::after { transform: rotate(90deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .45s var(--ease); }
.faq-a p { padding: 0 26px 22px; color: var(--carbon); font-size: 0.96rem; }

/* ---------- ZONAS / CTA / MAPA (reutilizados) ---------- */
.zonas { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; justify-content: center; }
.zonas span { font-family: var(--sans); font-size: 0.74rem; color: var(--ciruela-medio); background: var(--blanco); border: 1px solid var(--arena); padding: 8px 16px; border-radius: 50px; transition: all .3s; }
.zonas span:hover { background: var(--ciruela); color: #fff; border-color: var(--ciruela); }

.cta-banner { background: linear-gradient(135deg, var(--ciruela), var(--ciruela-medio)); border-radius: var(--r-lg); padding: clamp(46px, 6vw, 80px); text-align: center; position: relative; overflow: hidden; }
.cta-banner::before { content: ""; position: absolute; top: -60px; right: -60px; width: 240px; height: 240px; border: 1px solid rgba(184,155,110,.3); border-radius: 50%; }
.cta-banner::after { content: ""; position: absolute; bottom: -90px; left: -60px; width: 280px; height: 280px; border: 1px solid rgba(184,155,110,.2); border-radius: 50%; }
.cta-banner .eyebrow { color: var(--dorado-claro); }
.cta-banner .eyebrow::before { background: var(--dorado-claro); }
.cta-banner h2 { color: #fff; margin-bottom: 16px; position: relative; }
.cta-banner p { color: #EDDFEB; max-width: 560px; margin: 0 auto 30px; position: relative; }
.cta-banner .hero-actions { justify-content: center; position: relative; display: flex; flex-wrap: wrap; gap: 14px; }

.maps-embed { width: 100%; border-radius: var(--r-md); overflow: hidden; box-shadow: var(--shadow-soft); }
.maps-embed iframe { width: 100%; height: 420px; border: 0; display: block; }

/* Páginas de soporte (nosotros / contacto) */
.simple-hero { padding: 160px 0 70px; background: linear-gradient(180deg, var(--ciruela), var(--ciruela-medio)); color: #fff; text-align: center; }
.simple-hero h1 { color: #fff; }
.simple-hero p { color: #EDDFEB; max-width: 560px; margin: 14px auto 0; }
.simple-hero .breadcrumb { justify-content: center; margin-bottom: 18px; }
.simple-hero .breadcrumb a, .simple-hero .breadcrumb { color: #E6D6E4; }
.simple-hero .breadcrumb [aria-current] { color: var(--dorado-claro); }
.simple-hero .breadcrumb .sep { color: var(--dorado-claro); }

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: start; }
@media (max-width: 860px) { .contact-grid { grid-template-columns: 1fr; gap: 36px; } }
.contact-card { background: var(--blanco); border: 1px solid var(--arena); border-radius: var(--r-md); padding: 36px; box-shadow: var(--shadow-soft); }
.contact-card .map-info-list { margin-top: 0; }
