/*
 * Theme Name:  Directorio Residencias Child
 * Template:    generatepress
 * Description: Child theme del directorio de centros de mayores — Vivela.
 * Version:     1.0.0
 * Text Domain: residencias-child
 */

/* ============================================================
   VARIABLES GLOBALES — PALETA VIVELA
   ============================================================ */

:root {
	/* Naranja atardecer */
	--color-primary:       #E8621A;
	--color-primary-light: #F5874A;
	--color-primary-pale:  #FEF0E8;
	--color-primary-borde: #F5C4A0;

	/* Gris azulado profundo */
	--color-dark:          #1a2b4a;
	--color-dark-mid:      #4A5568;

	/* Crema */
	--color-warm:          #FAF7F2;
	--color-warm-mid:      #F0EBE1;
	--color-warm-borde:    #E2D9CC;

	/* Texto */
	--color-text:          #1a2b4a;
	--color-text-mid:      #4A5568;
	--color-text-soft:     #718096;
	--color-text-inv:      #FFFFFF;

	/* Aliases para compatibilidad con templates existentes */
	--color-accent:        #E8621A;
	--color-accent-light:  #FEF0E8;
	--color-border:        #E2D9CC;
	--color-border-light:  #EDE8E3;

	/* Badges */
	--color-badge-verified: #1A6B42;
	--color-badge-premium:  #A84010;

	/* Estado */
	--color-success:       #1A6B42;
	--color-warning:       #B7770D;

	/* Tipografía */
	--font-serif:   'DM Sans', 'Helvetica Neue', Arial, sans-serif;
	--font-sans:    'DM Sans', 'Helvetica Neue', Arial, sans-serif;

	/* Espaciado */
	--space-xs:  0.25rem;
	--space-sm:  0.5rem;
	--space-md:  1rem;
	--space-lg:  1.5rem;
	--space-xl:  2rem;
	--space-2xl: 3rem;
	--space-3xl: 4.5rem;

	/* Radios */
	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 12px;

	/* Sombras */
	--shadow-sm:  0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);
	--shadow-md:  0 4px 12px rgba(0,0,0,.09), 0 2px 4px rgba(0,0,0,.05);
	--shadow-lg:  0 8px 24px rgba(0,0,0,.10), 0 4px 8px rgba(0,0,0,.05);

	/* Layout */
	--container-max:  1300px;
	--sidebar-width:  300px;

	/* Transición */
	--transition: 200ms ease;
}

/* ============================================================
   RESET Y BASE
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }

body {
	font-family:  var(--font-sans);
	font-size:    1rem;
	line-height:  1.65;
	color:        var(--color-text);
	background:   #fff;
	-webkit-font-smoothing: antialiased;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--color-primary); text-decoration: none; }
a:hover { color: var(--color-primary-light); text-decoration: underline; }

/* ============================================================
   UTILIDADES
   ============================================================ */

.container {
	max-width: var(--container-max);
	margin:    0 auto;
	padding:   0 var(--space-lg);
}

.sr-only {
	position: absolute; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0,0,0,0); border: 0;
}

/* ── Badges ── */
.badge {
	display:        inline-flex;
	align-items:    center;
	gap:            4px;
	padding:        3px 10px;
	border-radius:  var(--radius-sm);
	font-size:      .72rem;
	font-weight:    600;
	letter-spacing: .04em;
	text-transform: uppercase;
}
.badge--verified {
	background: #E3F5EC;
	color:      var(--color-badge-verified);
}
.badge--premium {
	background: var(--color-primary-pale);
	color:      var(--color-badge-premium);
	border:     1px solid var(--color-primary-borde);
}
.badge--gratuito {
	background: var(--color-warm-mid);
	color:      var(--color-text-soft);
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */

.dr-breadcrumbs {
	font-size:  .83rem;
	color:      var(--color-text-soft);
	padding:    20px 10px 10px;
}
.dr-breadcrumbs a { color: var(--color-text-soft); }
.dr-breadcrumbs a:hover { color: var(--color-primary); text-decoration: none; }
.dr-breadcrumbs span { margin: 0 6px; opacity: .8; color: var(--color-primary);}

/* ============================================================
   FICHA INDIVIDUAL — LAYOUT
   ============================================================ */

.dr-ficha {
	max-width: var(--container-max);
	margin:    0 auto;
	padding:   0 var(--space-lg) var(--space-3xl);
}

.dr-ficha__layout {
	display: grid;
	grid-template-columns: 1fr var(--sidebar-width);
	gap:     var(--space-xl);
	align-items: start;
}

@media (max-width: 860px) {
	.dr-ficha__layout { grid-template-columns: 1fr; }
	.dr-ficha__sidebar { order: -1; }
}

/* ── Header de ficha ── */
.dr-ficha__header {
	background:    #FFFFFF;
	border:        1px solid var(--color-warm-borde);
	border-radius: var(--radius-lg);
	overflow:      hidden;
	margin-bottom: var(--space-xl);
	box-shadow:    var(--shadow-sm);
}

/* ── Galería ── */
.dr-galeria {
	position:     relative;
	background:   var(--color-warm-mid);
	aspect-ratio: 16 / 7;
	overflow:     hidden;
}
.dr-galeria__img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform 400ms ease;
}
.dr-galeria__placeholder {
	width: 100%; height: 100%;
	display: flex; align-items: center; justify-content: center;
	color: var(--color-text-soft); font-size: .9rem;
}
.dr-galeria__nav {
	position:  absolute; top: 50%; transform: translateY(-50%);
	display:   flex; justify-content: space-between;
	width:     100%; padding: 0 var(--space-md);
	pointer-events: none;
}
.dr-galeria__btn {
	pointer-events: all;
	width: 40px; height: 40px;
	background: rgba(255,255,255,.92);
	border: none; border-radius: 50%;
	cursor: pointer;
	display: flex; align-items: center; justify-content: center;
	box-shadow: var(--shadow-md);
	transition: background var(--transition);
}
.dr-galeria__btn:hover { background: #fff; }
.dr-galeria__counter {
	position:   absolute; bottom: var(--space-md); right: var(--space-md);
	background: rgba(0,0,0,.5);
	color: #fff; font-size: .78rem;
	padding: 3px 10px; border-radius: var(--radius-sm);
}
.dr-galeria__dots {
	position:  absolute; bottom: var(--space-md); left: 50%;
	transform: translateX(-50%);
	display:   flex; gap: 6px;
}
.dr-galeria__dot {
	width: 8px; height: 8px; border-radius: 50%;
	background: rgba(255,255,255,.5);
	border: none; cursor: pointer;
	transition: background var(--transition);
}
.dr-galeria__dot.is-active { background: #fff; }

/* ── Identidad ── */
.dr-ficha__identidad { padding: var(--space-lg) var(--space-xl); }

.dr-ficha__badges {
	display: flex; gap: var(--space-sm);
	flex-wrap: wrap; margin-bottom: var(--space-sm);
}

.dr-ficha__nombre {
	font-family: var(--font-serif);
	font-size:   clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	line-height: 1.2;
	color:       var(--color-dark);
	margin:      0 0 var(--space-sm);
}

.dr-ficha__meta {
	display: flex; flex-wrap: wrap;
	gap: var(--space-md) var(--space-xl);
	color: var(--color-text-mid); font-size: .9rem;
}
.dr-ficha__meta-item { display: flex; align-items: center; gap: 6px; }
.dr-ficha__meta-item svg { flex-shrink: 0; color: var(--color-primary); }
.dr-ficha__meta-item a { color: var(--color-text-mid); text-decoration: underline; text-underline-offset: 3px; }
.dr-ficha__meta-item a:hover { color: var(--color-primary); }

/* ── Horario en sidebar ── */
.dr-horario-sidebar { display: flex; flex-direction: column; gap: .3rem; }
.dr-horario-sidebar__fila {
    display:         flex;
    justify-content: space-between;
    align-items:     baseline;
    font-size:       .83rem;
    padding:         .25rem 0;
    border-bottom:   1px solid var(--color-warm-borde);
}
.dr-horario-sidebar__fila:last-child { border-bottom: none; }
.dr-horario-sidebar__dias { color: var(--color-text-mid); font-weight: 500; }
.dr-horario-sidebar__horas { color: var(--color-text-soft); }
.dr-horario-sidebar__fila--cerrado .dr-horario-sidebar__horas { color: var(--color-warm-borde); }
.dr-horario-sidebar__fila--24h .dr-horario-sidebar__horas { color: var(--color-primary); font-weight: 600; }

/* ============================================================
   BLOQUE CENTRAL — SECCIONES
   ============================================================ */

.dr-ficha__content {
	display: flex; flex-direction: column; gap: var(--space-xl);
}

.dr-seccion {
	background:    #FFFFFF;
	border:        1px solid var(--color-warm-borde);
	border-radius: var(--radius-lg);
	padding:       var(--space-xl);
	box-shadow:    var(--shadow-sm);
}

.dr-seccion__titulo {
	font-family:    var(--font-serif);
	font-size:      1.05rem;
	font-weight:    700;
	color:          var(--color-dark);
	margin:         0 0 var(--space-lg);
	padding-bottom: var(--space-sm);
	border-bottom:  2px solid var(--color-primary-pale);
}

/* ── Descripción ── */
.dr-descripcion { font-size: .97rem; line-height: 1.8; color: var(--color-text-mid); }
.dr-descripcion b, .dr-descripcion strong { color: var(--color-text); }

/* ── Servicios ── */
.dr-servicios-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: var(--space-md);
}
.dr-servicio {
	display: flex; flex-direction: column; align-items: center;
	gap: 6px; padding: var(--space-md) var(--space-sm);
	border: 1px solid var(--color-warm-borde);
	border-radius: var(--radius-md);
	text-align: center; font-size: .8rem;
	color: var(--color-text-mid); background: var(--color-warm);
	transition: border-color var(--transition), box-shadow var(--transition);
}
.dr-servicio:hover { border-color: var(--color-primary); box-shadow: var(--shadow-sm); }
.dr-servicio svg { color: var(--color-primary); }

/* ── Precio ── */
.dr-precio-tabla { display: flex; align-items: baseline; gap: var(--space-sm); }
.dr-precio-tabla__valor {
	font-family: var(--font-serif); font-size: 2rem; font-weight: 700; color: var(--color-primary);
}
.dr-precio-tabla__desde { font-size: .9rem; color: var(--color-text-soft); }
.dr-precio-tabla__nota { font-size: .82rem; color: var(--color-text-soft); margin-top: var(--space-sm); }

/* ── Opiniones ── */
.dr-opiniones { display: flex; align-items: center; gap: var(--space-lg); flex-wrap: wrap; }
.dr-opiniones__nota {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	width: 80px; height: 80px; border-radius: 50%;
	background: var(--color-dark); color: #fff;
}
.dr-opiniones__nota-num {
	font-family: var(--font-serif); font-size: 1.6rem; font-weight: 700; line-height: 1;
}
.dr-opiniones__nota-label { font-size: .65rem; opacity: .7; text-transform: uppercase; letter-spacing: .05em; }
.dr-opiniones__estrellas { display: flex; gap: 2px; color: var(--color-primary); margin-bottom: 4px; }
.dr-opiniones__resumen { font-size: .9rem; color: var(--color-text-mid); font-style: italic; line-height: 1.6; }

/* ── Mapa ── */
.dr-mapa { border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--color-warm-borde); line-height: 0; }
.dr-mapa iframe { width: 100%; height: 300px; border: 0; }

/* ============================================================
   SIDEBAR — CONVERSIÓN
   ============================================================ */

.dr-ficha__sidebar {
	position: sticky; top: var(--space-xl);
	display: flex; flex-direction: column; gap: var(--space-md);
}

.dr-sidebar-card {
	background:    #FFFFFF;
	border:        1px solid var(--color-warm-borde);
	border-radius: var(--radius-lg);
	padding:       var(--space-lg);
	box-shadow:    var(--shadow-sm);
}

/* ── CTA Teléfono ── */
.dr-cta-telefono {
	display: flex; flex-direction: column; align-items: center;
	gap: var(--space-sm); text-align: center;
}
.dr-cta-telefono__label { font-size: .85rem; color: var(--color-text-soft); }
.dr-cta-telefono__btn {
	display: flex; align-items: center; justify-content: center;
	gap: var(--space-sm); width: 100%;
	padding: var(--space-md) var(--space-lg);
	background: var(--color-primary); color: #fff;
	border: none; border-radius: var(--radius-md);
	font-family: var(--font-sans); font-size: 1rem; font-weight: 600;
	cursor: pointer;
	transition: background var(--transition), transform var(--transition);
	text-decoration: none;
}
.dr-cta-telefono__btn:hover {
	background: var(--color-primary-light); transform: translateY(-1px);
	text-decoration: none; color: #fff;
}
.dr-cta-telefono__numero {
	font-family: var(--font-serif); font-size: 1.35rem; font-weight: 700;
	color: var(--color-dark); letter-spacing: .05em;
}
.dr-cta-telefono__nota { font-size: .78rem; color: var(--color-text-soft); }

.dr-tel-reveal__numero { display: none; }
.dr-tel-reveal.is-revealed .dr-tel-reveal__btn { display: none; }
.dr-tel-reveal.is-revealed .dr-tel-reveal__numero { display: block; }

/* ── Datos rápidos ── */
.dr-sidebar-datos { display: flex; flex-direction: column; gap: var(--space-sm); font-size: .88rem; }
.dr-sidebar-dato {
	display: flex; justify-content: space-between; align-items: baseline;
	padding: var(--space-sm) 0; border-bottom: 1px solid var(--color-warm-borde);
}
.dr-sidebar-dato:last-child { border-bottom: none; }
.dr-sidebar-dato__label { color: var(--color-text-soft); }
.dr-sidebar-dato__valor { font-weight: 600; color: var(--color-text); }

/* ── CTA reclamar ── */
.dr-cta-reclamar {
	background: var(--color-primary-pale);
	border: 1px solid var(--color-primary-borde);
	border-radius: var(--radius-lg);
	padding: var(--space-lg); text-align: center;
	font-size: .88rem; color: var(--color-dark);
}
.dr-cta-reclamar p { margin: 0 0 var(--space-sm); }
.dr-cta-reclamar a {
	display: inline-block; padding: 8px 20px;
	background: var(--color-primary); color: #fff;
	border-radius: var(--radius-sm); font-weight: 600; font-size: .85rem;
	transition: background var(--transition);
}
.dr-cta-reclamar a:hover { background: var(--color-primary-light); text-decoration: none; }

/* ============================================================
   GUTENBERG CONTENT (FAQs y contenido libre en listados)
   ============================================================ */

.dr-gutenberg-content {
	margin-top:  var(--space-2xl);
	font-size:   .95rem;
	line-height: 1.8;
	color:       var(--color-text-mid);
}
.dr-gutenberg-content h2 {
	font-family: var(--font-serif);
	font-size:   1.4rem; font-weight: 700;
	color:       var(--color-dark);
	margin:      var(--space-xl) 0 var(--space-md);
}
.dr-gutenberg-content h3 {
	font-family: var(--font-serif);
	font-size:   1.1rem; font-weight: 700;
	color:       var(--color-primary);
	margin:      var(--space-lg) 0 var(--space-sm);
}

/* ============================================================
   RESPONSIVE — FICHA
   ============================================================ */

@media (max-width: 600px) {
	.dr-ficha__identidad  { padding: var(--space-md); }
	.dr-seccion           { padding: var(--space-lg) var(--space-md); }
	.dr-servicios-grid    { grid-template-columns: repeat(2, 1fr); }
	.dr-ficha__meta       { flex-direction: column; gap: var(--space-sm); }
}

/* ============================================================
   ESTILOS GP
   ============================================================ */

.site-header {
    border-bottom: 1px solid #E2D9CC;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.site-footer {
    background: var(--color-dark);
    color: rgba(255,255,255,.6);
    border-top: none;
}
.site-footer a {
    color: rgba(255,255,255,.7);
}
.site-footer a:hover {
    color: var(--color-primary);
    text-decoration: none;
}

.wp-block-button__link,
button:not(.dr-card__cta):not(.dr-cta-telefono__btn):not(.dr-filtros__aplicar) {
    border-radius: var(--radius-md);
}