/* ============================================================
   FRANK F. PINTOR PROFESIONAL — CSS PRINCIPAL
   Fuentes: Inter (limpieza y claridad tech tipo Ranking Dental)
   Paleta: Naranja Vivo #ea580c · Azul Eléctrico #2563eb
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

/* --- Variables de marca --- */
:root {
  --naranja:        #ff7b00;
  --naranja-claro:  #ffedd5;
  --naranja-oscuro: #cc6200;
  --azul:           #2563eb;
  --azul-claro:     #eff6ff;
  --azul-oscuro:    #1e40af;
  --crema:          #f8fafc;
  --oscuro:         #0f172a;
  --oscuro-medio:   #1e293b;
  --gris-texto:     #475569;
  --gris-borde:     #e2e8f0;
  --gris-fondo:     #f1f5f9;
  --blanco:         #ffffff;
  --verde-ok:       #10b981;
  
  --font-titulo:    'Inter', system-ui, sans-serif;
  --font-cuerpo:    'Inter', system-ui, sans-serif;
  
  --radio:          8px;
  --radio-lg:       12px;
  --sombra-sm:      0 1px 2px 0 rgb(0 0 0 / 0.05);
  --sombra-md:      0 10px 15px -3px rgb(0 0 0 / 0.1);
  --transicion:     all 0.25s ease;
}

/* --- Reset y base --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-cuerpo);
  font-weight: 400;
  color: var(--oscuro);
  background: var(--blanco);
  line-height: 1.6;
  overflow-x: hidden;
}

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

a { color: inherit; text-decoration: none; transition: var(--transicion); }

ul { list-style: none; }

/* --- Tipografía --- */
h1, h2, h3, h4 {
  font-family: var(--font-titulo);
  line-height: 1.1;
  letter-spacing: -0.5px;
}
h1 { font-size: clamp(2.2rem, 5vw, 3.4rem); font-weight: 900; }
h2 { font-size: clamp(1.7rem, 3.5vw, 2.4rem); font-weight: 700; }
h3 { font-size: 1.25rem; font-weight: 700; }
h4 { font-size: 1rem; font-weight: 700; }

p { line-height: 1.75; color: var(--gris-texto); }

.texto-naranja  { color: var(--naranja); }
.texto-azul     { color: var(--azul-oscuro); }
.texto-crema    { color: var(--crema); }
.italic         { font-style: italic; }

/* --- Layout --- */
.contenedor {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 24px;
}

.seccion {
  padding: 72px 0;
}

.seccion-titulo {
  margin-bottom: 8px;
}

.seccion-subtitulo {
  font-size: 0.9rem;
  color: var(--gris-texto);
  margin-bottom: 40px;
}

/* --- Botones --- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: var(--radio);
  font-family: var(--font-cuerpo);
  font-size: 0.875rem;
  font-weight: 500;
  border: none;
  cursor: pointer;
  transition: var(--transicion);
  white-space: nowrap;
}

.btn-primario {
  background: var(--naranja);
  color: var(--blanco);
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.3), 0 4px 12px rgba(255, 123, 0, 0.4);
}

.btn-primario:hover {
  background: var(--naranja-oscuro);
  transform: translateY(-1px);
  box-shadow: var(--sombra-sm);
}

.btn-secundario {
  background: transparent;
  color: var(--azul-oscuro);
  border: 1.5px solid var(--azul);
}

.btn-secundario:hover {
  background: var(--azul-claro);
}

.btn-whatsapp {
  background: #25D366;
  color: var(--blanco);
}

.btn-whatsapp:hover {
  background: #1DA851;
  transform: translateY(-1px);
}

.btn-oscuro {
  background: var(--oscuro);
  color: var(--crema);
}

.btn-oscuro:hover {
  background: var(--oscuro-medio);
}

/* ============================================================
   NAVEGACIÓN
   ============================================================ */
.nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--blanco);
  border-bottom: 1px solid var(--gris-borde);
  box-shadow: var(--sombra-sm);
}

.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 105px;
  gap: 24px;
}

.nav__logo img {
  height: 82px;
  width: auto;
}

.nav__links {
  display: flex;
  gap: 28px;
  align-items: center;
}

.nav__links a {
  font-size: 0.8rem;
  font-weight: 400;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--gris-texto);
  position: relative;
  padding-bottom: 2px;
}

.nav__links a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--naranja);
  transition: width 0.25s ease;
}

.nav__links a:hover { color: var(--naranja); }
.nav__links a:hover::after { width: 100%; }

.nav__cta { flex-shrink: 0; }

.nav__hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}

.nav__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--oscuro);
  transition: var(--transicion);
  border-radius: 2px;
}

.nav__mobile {
  display: none;
  flex-direction: column;
  gap: 0;
  background: var(--blanco);
  border-top: 1px solid var(--gris-borde);
  padding: 8px 0 16px;
}

.nav__mobile.abierto { display: flex; }

.nav__mobile a {
  padding: 12px 24px;
  font-size: 0.9rem;
  color: var(--gris-texto);
  border-bottom: 1px solid var(--gris-fondo);
}

.nav__mobile a:hover { color: var(--naranja); background: var(--naranja-claro); }

/* ============================================================
   HERO CON SLIDER
   ============================================================ */
.hero {
  position: relative;
  min-height: 580px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--oscuro);
}

.hero__slides {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
  background-size: cover;
  background-position: center;
}

.hero__slide.activo { opacity: 1; }

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(28,28,28,0.78) 0%,
    rgba(28,28,28,0.55) 60%,
    rgba(28,28,28,0.40) 100%
  );
  z-index: 1;
}

.hero__contenido {
  position: relative;
  z-index: 2;
  padding: 64px 0;
  max-width: 620px;
  text-align: center;
  margin: 0 auto;
}

.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 24px;
  padding: 6px 14px;
  font-size: 0.75rem;
  color: #ddd;
  margin-bottom: 20px;
  backdrop-filter: blur(4px);
}

.hero__badge-punto {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--verde-ok);
  flex-shrink: 0;
}

.hero__titulo {
  color: var(--blanco);
  margin-bottom: 8px;
  text-shadow: 0 4px 20px rgba(0,0,0,0.8);
  -webkit-text-stroke: 1px rgba(255, 255, 255, 0.3);
}

.hero__titulo em {
  font-style: italic;
  color: var(--naranja);
}

.hero__titulo span { color: var(--azul); }

.hero__subtitulo {
  color: #bbb;
  font-weight: 300;
  font-size: 1rem;
  max-width: 440px;
  margin: 16px auto 28px;
}

.hero__botones {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}

.hero__dots {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 3;
}

.hero__dot {
  width: 8px;
  height: 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.3);
  border: none;
  cursor: pointer;
  transition: var(--transicion);
  padding: 0;
}

.hero__dot.activo {
  width: 22px;
  background: var(--naranja);
}

/* ============================================================
   STATS BAR
   ============================================================ */
.stats {
  background: var(--oscuro-medio);
  padding: 0;
}

.stats__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  divide: 1px solid #333;
}

.stats__item {
  padding: 24px 20px;
  text-align: center;
  border-right: 1px solid #333;
}

.stats__item:last-child { border-right: none; }

.stats__numero {
  font-family: var(--font-titulo);
  font-size: 2rem;
  font-weight: 700;
  color: var(--naranja);
  line-height: 1;
}

.stats__label {
  font-size: 0.75rem;
  color: #999;
  margin-top: 4px;
}

/* ============================================================
   CALCULADORA
   ============================================================ */
.calculadora {
  background: var(--gris-fondo);
  padding: 72px 0;
}

.calc__wrapper {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  overflow: hidden;
  box-shadow: var(--sombra-md);
}

.calc__cabecera {
  background: var(--oscuro);
  padding: 20px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.calc__cabecera-titulo {
  font-family: var(--font-titulo);
  font-size: 1.2rem;
  color: var(--crema);
}

.calc__cabecera-sub {
  font-size: 0.75rem;
  color: #888;
  margin-top: 2px;
}

.calc__progreso-texto {
  font-size: 0.75rem;
  color: var(--naranja);
  font-weight: 500;
}

.calc__pasos {
  display: flex;
  background: #141414;
  border-bottom: 1px solid #222;
}

.calc__paso {
  flex: 1;
  padding: 10px 8px;
  text-align: center;
  font-size: 0.7rem;
  color: #555;
  cursor: pointer;
  transition: var(--transicion);
  border-right: 1px solid #222;
}

.calc__paso:last-child { border-right: none; }

.calc__paso.activo {
  color: var(--naranja);
  background: rgba(240,122,56,0.08);
}

.calc__paso.completado { color: var(--verde-ok); }

.calc__cuerpo {
  padding: 28px;
}

.calc__panel { display: none; }
.calc__panel.visible { display: block; }

.calc__label-grupo {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--gris-texto);
  font-weight: 500;
  margin-bottom: 12px;
  margin-top: 20px;
}

.calc__label-grupo:first-child { margin-top: 0; }

/* Grid de tarjetas de selección */
.calc__tarjetas {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  margin-bottom: 4px;
}

.calc__tarjeta {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  padding: 14px 10px;
  text-align: center;
  cursor: pointer;
  transition: var(--transicion);
  background: var(--blanco);
  user-select: none;
}

.calc__tarjeta:hover {
  border-color: var(--naranja);
  background: var(--naranja-claro);
}

.calc__tarjeta.seleccionado {
  border-color: var(--naranja);
  background: var(--naranja-claro);
  box-shadow: 0 0 0 1px var(--naranja);
}

.calc__tarjeta-icono {
  font-size: 1.5rem;
  display: block;
  margin-bottom: 6px;
}

.calc__tarjeta-nombre {
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--gris-texto);
}

.calc__tarjeta.seleccionado .calc__tarjeta-nombre {
  color: var(--naranja-oscuro);
}

/* Estancias con contador */
.calc__estancias-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.calc__estancia {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--blanco);
}

.calc__estancia-nombre {
  font-size: 0.82rem;
  font-weight: 500;
}

.calc__counter {
  display: flex;
  align-items: center;
  gap: 8px;
}

.calc__counter-btn {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--gris-borde);
  background: var(--gris-fondo);
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  transition: var(--transicion);
  color: var(--oscuro);
}

.calc__counter-btn:hover {
  border-color: var(--naranja);
  background: var(--naranja-claro);
  color: var(--naranja-oscuro);
}

.calc__counter-val {
  font-size: 0.9rem;
  font-weight: 500;
  min-width: 16px;
  text-align: center;
}

/* Paleta de colores */
.calc__paleta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 10px;
}

.calc__color {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--transicion);
  flex-shrink: 0;
}

.calc__color:hover { transform: scale(1.15); }

.calc__color.seleccionado {
  border-color: var(--naranja);
  outline: 2px solid var(--naranja);
  outline-offset: 2px;
}

.calc__color-nombre {
  font-size: 0.75rem;
  color: var(--gris-texto);
  margin-top: 4px;
}

/* Resultado */
.calc__resultado {
  border-top: 1px solid var(--gris-borde);
  padding-top: 20px;
  margin-top: 20px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}

.calc__resultado-desde { font-size: 0.8rem; color: var(--gris-texto); }

.calc__precio {
  font-family: var(--font-titulo);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--naranja);
  line-height: 1;
}

.calc__precio-hasta {
  font-size: 0.9rem;
  color: var(--gris-texto);
}

.calc__resultado-cta { margin-left: auto; }

.calc__aviso {
  font-size: 0.72rem;
  color: #aaa;
  margin-top: 10px;
  line-height: 1.5;
}

/* Navegación entre pasos */
.calc__nav-pasos {
  display: flex;
  justify-content: space-between;
  margin-top: 24px;
  padding-top: 16px;
  border-top: 1px solid var(--gris-borde);
  gap: 10px;
}

/* ============================================================
   PÓNSELO FÁCIL AL PINTOR
   ============================================================ */
.ponselo {
  background: var(--blanco);
  padding: 72px 0;
}

.ponselo__intro {
  background: var(--naranja-claro);
  border: 1px solid #F5C4B3;
  border-radius: var(--radio-lg);
  padding: 16px 20px;
  font-size: 0.875rem;
  color: #7A3A10;
  line-height: 1.7;
  margin-bottom: 28px;
}

.ponselo__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.ponselo__item {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  padding: 20px;
  background: var(--blanco);
  cursor: pointer;
  transition: var(--transicion);
  user-select: none;
}

.ponselo__item:hover {
  border-color: var(--naranja);
  box-shadow: var(--sombra-sm);
}

.ponselo__item.marcado {
  border-color: var(--naranja);
  background: var(--naranja-claro);
}

.ponselo__item-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px;
  gap: 8px;
}

.ponselo__check {
  width: 22px;
  height: 22px;
  border-radius: 5px;
  border: 2px solid var(--naranja);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  font-weight: 700;
  color: transparent;
  flex-shrink: 0;
  transition: var(--transicion);
}

.ponselo__item.marcado .ponselo__check {
  background: var(--naranja);
  color: var(--blanco);
}

.ponselo__badge {
  font-size: 0.7rem;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 12px;
  white-space: nowrap;
}

.ponselo__badge--naranja {
  background: var(--naranja-claro);
  color: #7A3A10;
}

.ponselo__badge--verde {
  background: #EAF3DE;
  color: #3B6D11;
}

.ponselo__titulo {
  font-size: 0.9rem;
  font-weight: 500;
  margin-bottom: 6px;
}

.ponselo__desc {
  font-size: 0.8rem;
  color: var(--gris-texto);
  line-height: 1.55;
}

.ponselo__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  border-top: 1px solid var(--gris-borde);
  padding-top: 20px;
}

.ponselo__total-label { font-size: 0.85rem; color: var(--gris-texto); }
.ponselo__total-sub { font-size: 0.72rem; color: #aaa; margin-top: 2px; }

.ponselo__total-valor {
  font-family: var(--font-titulo);
  font-size: 1.6rem;
  font-weight: 700;
  color: #3B6D11;
}

/* ============================================================
   SERVICIOS
   ============================================================ */
.servicios { background: var(--gris-fondo); }

.servicios__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 16px;
}

.servicio-card {
  position: relative;
  background-size: cover;
  background-position: center;
  border-radius: var(--radio-lg);
  padding: 40px 24px;
  overflow: hidden;
  transition: var(--transicion);
  min-height: 280px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  border: 1px solid var(--gris-borde);
}

.servicio-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.9), rgba(0,0,0,0.3));
  z-index: 1;
  transition: var(--transicion);
}

.servicio-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sombra-md);
  border-color: var(--naranja);
}

.servicio-card:hover::before {
  background: linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0.1));
}

.servicio-card__titulo {
  position: relative;
  z-index: 2;
  margin-bottom: 8px;
  font-size: 1.1rem;
  color: #ffffff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.8);
}

.servicio-card__desc {
  position: relative;
  z-index: 2;
  font-size: 0.85rem;
  color: #eeeeee;
  line-height: 1.6;
  text-shadow: 0 1px 3px rgba(0,0,0,0.8);
}

/* ============================================================
   SOBRE MÍ
   ============================================================ */
.sobre-mi {
  background: var(--crema);
  padding: 72px 0;
}

.sobre-mi__inner {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 48px;
  align-items: center;
}

.sobre-mi__foto {
  border-radius: var(--radio-lg);
  overflow: hidden;
  aspect-ratio: 3/4;
  background: var(--gris-borde);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  color: #aaa;
}

.sobre-mi__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sobre-mi__label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--naranja);
  font-weight: 500;
  margin-bottom: 12px;
}

.sobre-mi__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}

.sobre-mi__chip {
  background: var(--naranja-claro);
  color: #7A3A10;
  border-radius: 20px;
  padding: 5px 14px;
  font-size: 0.78rem;
  font-weight: 500;
}

/* ============================================================
   ZONAS
   ============================================================ */
.zonas { background: var(--blanco); }

.zonas__selector {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.zonas__pill {
  border: 1px solid var(--gris-borde);
  border-radius: 24px;
  padding: 8px 18px;
  font-size: 0.85rem;
  cursor: pointer;
  transition: var(--transicion);
  background: var(--blanco);
}

.zonas__pill:hover {
  border-color: var(--azul);
  background: var(--azul-claro);
}

.zonas__pill.activo {
  background: var(--azul);
  color: var(--blanco);
  border-color: var(--azul);
  font-weight: 500;
}

.zonas__mapa {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  overflow: hidden;
  height: 380px;
}

.zonas__mapa iframe {
  width: 100%;
  height: 100%;
  border: none;
}

/* ============================================================
   GALERÍA DE TRABAJOS
   ============================================================ */
.galeria { background: var(--gris-fondo); }

.galeria__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}

.galeria__item {
  border-radius: var(--radio-lg);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--gris-borde);
  position: relative;
}

.galeria__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.galeria__item:hover img { transform: scale(1.04); }

/* ============================================================
   RESEÑAS
   ============================================================ */
.resenas { background: var(--blanco); }

.resenas__cabecera {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 28px;
}

.resenas__google-badge {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--gris-fondo);
  border: 1px solid var(--gris-borde);
  border-radius: 24px;
  padding: 6px 14px;
  font-size: 0.78rem;
  color: var(--gris-texto);
}

.resenas__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 16px;
}

.resena-card {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  padding: 20px;
  background: var(--blanco);
  transition: var(--transicion);
}

.resena-card:hover { box-shadow: var(--sombra-sm); }

.resena-card__estrellas {
  color: #F4B400;
  font-size: 1rem;
  letter-spacing: 2px;
  margin-bottom: 10px;
}

.resena-card__texto {
  font-size: 0.875rem;
  color: var(--gris-texto);
  line-height: 1.65;
  margin-bottom: 14px;
}

.resena-card__autor { font-size: 0.85rem; font-weight: 500; }

.resena-card__fuente {
  font-size: 0.72rem;
  color: #aaa;
  margin-top: 2px;
}

/* ============================================================
   BLOG
   ============================================================ */
.blog { background: var(--gris-fondo); }

.blog__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
}

.blog-card {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  overflow: hidden;
  transition: var(--transicion);
}

.blog-card:hover {
  box-shadow: var(--sombra-md);
  transform: translateY(-3px);
}

.blog-card__imagen {
  aspect-ratio: 16/9;
  background: var(--crema);
  overflow: hidden;
}

.blog-card__imagen img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.blog-card:hover .blog-card__imagen img { transform: scale(1.04); }

.blog-card__contenido { padding: 20px; }

.blog-card__tag {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.9px;
  color: var(--naranja);
  font-weight: 500;
  margin-bottom: 8px;
}

.blog-card__titulo {
  font-family: var(--font-titulo);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 8px;
}

.blog-card__extracto {
  font-size: 0.82rem;
  color: var(--gris-texto);
  line-height: 1.6;
}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto { background: var(--crema); }

.contacto__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}

.contacto__form-wrapper {
  background: var(--blanco);
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  padding: 28px;
  box-shadow: var(--sombra-sm);
}

.contacto__form-titulo {
  font-family: var(--font-titulo);
  font-size: 1.3rem;
  margin-bottom: 16px;
}

.contacto__presupuesto-tag {
  background: var(--naranja-claro);
  border: 1px solid #F5C4B3;
  border-radius: var(--radio);
  padding: 10px 14px;
  font-size: 0.8rem;
  color: #7A3A10;
  margin-bottom: 16px;
  display: none;
}

.contacto__presupuesto-tag.visible { display: block; }

.form-campo { margin-bottom: 14px; }

.form-campo label {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--gris-texto);
  margin-bottom: 5px;
  font-weight: 500;
}

.form-campo input,
.form-campo textarea,
.form-campo select {
  width: 100%;
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  padding: 10px 12px;
  font-size: 0.875rem;
  font-family: var(--font-cuerpo);
  background: var(--blanco);
  color: var(--oscuro);
  transition: var(--transicion);
  outline: none;
}

.form-campo input:focus,
.form-campo textarea:focus,
.form-campo select:focus {
  border-color: var(--naranja);
  box-shadow: 0 0 0 3px rgba(240,122,56,0.12);
}

.form-campo textarea { height: 90px; resize: vertical; }

.form-campo--obligatorio label::after {
  content: ' *';
  color: var(--naranja);
}

.form__mensaje-ok {
  background: #EAF3DE;
  border: 1px solid #C0DD97;
  border-radius: var(--radio);
  padding: 12px 16px;
  font-size: 0.875rem;
  color: #3B6D11;
  margin-top: 12px;
  display: none;
}

.form__mensaje-ok.visible { display: block; }

.contacto__mapa-wrapper {
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  overflow: hidden;
  height: 100%;
  min-height: 460px;
}

.contacto__mapa-wrapper iframe {
  width: 100%;
  height: 100%;
  border: none;
  min-height: 460px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--oscuro);
  padding: 48px 0 0;
}

.footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 36px;
  border-bottom: 1px solid #333;
}

.footer__logo img { height: 52px; width: auto; margin-bottom: 14px; }

.footer__descripcion {
  font-size: 0.82rem;
  color: #888;
  line-height: 1.7;
  max-width: 280px;
  margin-bottom: 16px;
}

.footer__redes {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.footer__red {
  background: #2C2C2C;
  border: 1px solid #444;
  border-radius: 20px;
  padding: 5px 14px;
  font-size: 0.72rem;
  color: #aaa;
  transition: var(--transicion);
}

.footer__red:hover {
  background: var(--naranja);
  border-color: var(--naranja);
  color: var(--blanco);
}

.footer__col-titulo {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #666;
  margin-bottom: 16px;
  font-weight: 500;
}

.footer__enlaces {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer__enlaces a {
  font-size: 0.85rem;
  color: #888;
  transition: var(--transicion);
}

.footer__enlaces a:hover { color: var(--naranja); }

.footer__zona-txt {
  font-size: 0.82rem;
  color: #888;
  line-height: 1.8;
}

.footer__bottom {
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

.footer__copy {
  font-size: 0.75rem;
  color: #555;
}

.footer__legal {
  display: flex;
  gap: 16px;
}

.footer__legal a {
  font-size: 0.72rem;
  color: #555;
  transition: var(--transicion);
}

.footer__legal a:hover { color: var(--naranja); }

/* ============================================================
   WHATSAPP FLOTANTE
   ============================================================ */
.whatsapp-float {
  position: fixed;
  bottom: 86px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
}

.whatsapp-float__btn {
  width: 56px;
  height: 56px;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 4px 16px rgba(37,211,102,0.4);
  transition: var(--transicion);
  cursor: pointer;
  text-decoration: none;
}

.whatsapp-float__btn:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 22px rgba(37,211,102,0.5);
}

.whatsapp-float__badge {
  position: absolute;
  top: -3px;
  right: -3px;
  width: 14px;
  height: 14px;
  background: #FF3B30;
  border-radius: 50%;
  border: 2px solid var(--blanco);
}

.whatsapp-float__tooltip {
  background: var(--oscuro);
  color: var(--blanco);
  font-size: 0.75rem;
  padding: 6px 12px;
  border-radius: 6px;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(8px);
  transition: var(--transicion);
  pointer-events: none;
}

.whatsapp-float:hover .whatsapp-float__tooltip {
  opacity: 1;
  transform: translateX(0);
}

/* ============================================================
   COOKIE BANNER
   ============================================================ */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9998;
  background: var(--oscuro-medio);
  border-top: 1px solid #333;
  padding: 16px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  transform: translateY(100%);
  transition: transform 0.4s ease;
}

.cookie-banner.visible { transform: translateY(0); }

.cookie-banner__texto {
  font-size: 0.8rem;
  color: #aaa;
  flex: 1;
  line-height: 1.6;
  min-width: 240px;
}

.cookie-banner__texto a { color: var(--azul); text-decoration: underline; }

.cookie-banner__botones {
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}

.cookie-banner__config {
  background: transparent;
  border: 1px solid #555;
  border-radius: var(--radio);
  padding: 8px 16px;
  font-size: 0.8rem;
  color: #aaa;
  cursor: pointer;
  font-family: var(--font-cuerpo);
  transition: var(--transicion);
}

.cookie-banner__config:hover { border-color: #888; color: var(--blanco); }

.cookie-banner__aceptar {
  background: var(--naranja);
  border: none;
  border-radius: var(--radio);
  padding: 8px 16px;
  font-size: 0.8rem;
  color: var(--blanco);
  cursor: pointer;
  font-family: var(--font-cuerpo);
  font-weight: 500;
  transition: var(--transicion);
}

.cookie-banner__aceptar:hover { background: var(--naranja-oscuro); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .nav__links { display: none; }
  .nav__cta { display: none; }
  .nav__hamburger { display: flex; }

  .hero { min-height: 480px; }
  .hero__contenido { padding: 48px 0; }

  .stats__grid { grid-template-columns: 1fr; }
  .stats__item { border-right: none; border-bottom: 1px solid #333; }
  .stats__item:last-child { border-bottom: none; }

  .sobre-mi__inner { grid-template-columns: 1fr; }
  .sobre-mi__foto { aspect-ratio: 4/3; max-width: 320px; margin: 0 auto; }

  .contacto__grid { grid-template-columns: 1fr; }
  .contacto__mapa-wrapper { min-height: 280px; }
  .contacto__mapa-wrapper iframe { min-height: 280px; }

  .footer__grid { grid-template-columns: 1fr; gap: 28px; }
  .footer__bottom { flex-direction: column; text-align: center; }

  .calc__tarjetas { grid-template-columns: repeat(2, 1fr); }
  .calc__estancias-grid { grid-template-columns: 1fr; }

  .ponselo__grid { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .seccion { padding: 48px 0; }
  .hero__botones { flex-direction: column; }
  .hero__botones .btn { width: 100%; justify-content: center; }
  .calc__tarjetas { grid-template-columns: 1fr 1fr; }
}

/* ============================================================
   BLOG — ESTILOS ADICIONALES
   ============================================================ */

.blog-card__placeholder {
  width: 100%;
  height: 100%;
  background: var(--crema);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  min-height: 180px;
}

.blog-card__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--gris-borde);
}

.blog-card__meta time {
  font-size: 0.75rem;
  color: var(--gris-texto);
}

.blog-card__leer {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--naranja);
  transition: var(--transicion);
}

.blog-card__leer:hover { color: var(--naranja-oscuro); }

.blog-hero {
  background: var(--oscuro);
  padding: 72px 0 56px;
  position: relative;
  overflow: hidden;
}

.blog-hero::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  background: rgba(240,122,56,0.06);
  pointer-events: none;
}

.blog-hero__inner { max-width: 640px; }

.blog-hero__label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--naranja);
  font-weight: 500;
  margin-bottom: 14px;
}

.blog-hero__titulo {
  font-family: var(--font-titulo);
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 900;
  line-height: 1.08;
  color: var(--crema);
  letter-spacing: -0.8px;
  margin-bottom: 0;
}

.blog-hero__titulo em {
  font-style: italic;
  color: var(--naranja);
}

.blog-hero__sub {
  font-size: 0.95rem;
  color: #bbb;
  font-weight: 300;
  line-height: 1.75;
  margin-top: 18px;
  max-width: 520px;
}

/* Paginación */
.paginacion {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 48px;
  padding-top: 32px;
  border-top: 1px solid var(--gris-borde);
}

.paginacion__btn {
  padding: 10px 20px;
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio);
  font-size: 0.875rem;
  color: var(--naranja);
  background: var(--blanco);
  transition: var(--transicion);
  font-weight: 500;
}

.paginacion__btn:hover {
  background: var(--naranja);
  color: var(--blanco);
  border-color: var(--naranja);
}

.paginacion__info {
  font-size: 0.82rem;
  color: var(--gris-texto);
}

/* Blog vacío */
.blog-vacio {
  text-align: center;
  padding: 64px 24px;
}

.blog-vacio__icono {
  font-size: 3rem;
  margin-bottom: 16px;
}

.blog-vacio__titulo {
  font-family: var(--font-titulo);
  font-size: 1.5rem;
  margin-bottom: 12px;
}

.blog-vacio__desc {
  color: var(--gris-texto);
  font-size: 0.9rem;
  margin-bottom: 24px;
}

/* ============================================================
   POST DETALLE
   ============================================================ */

.post-detalle__header {
  position: relative;
  background: var(--oscuro);
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.post-detalle__imagen-wrapper {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.post-detalle__imagen {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.45;
}

.post-detalle__imagen-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(28,28,28,0.3) 0%,
    rgba(28,28,28,0.85) 100%
  );
}

.post-detalle__header-contenido {
  position: relative;
  z-index: 2;
  padding: 48px 0 40px;
  max-width: 720px;
}

.post-detalle__header-contenido--sin-imagen {
  padding-top: 32px;
}

.post-detalle__breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.75rem;
  color: #aaa;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.post-detalle__breadcrumb a {
  color: #aaa;
  transition: var(--transicion);
}

.post-detalle__breadcrumb a:hover { color: var(--naranja); }

.post-detalle__tag {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--naranja);
  font-weight: 500;
  margin-bottom: 10px;
}

.post-detalle__titulo {
  font-family: var(--font-titulo);
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  font-weight: 900;
  color: var(--crema);
  line-height: 1.1;
  letter-spacing: -0.5px;
  margin-bottom: 14px;
}

.post-detalle__extracto {
  font-size: 1rem;
  color: #ccc;
  line-height: 1.7;
  font-weight: 300;
  max-width: 600px;
}

.post-detalle__meta {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.post-detalle__autor,
.post-detalle__fecha {
  font-size: 0.8rem;
  color: #aaa;
}

/* Cuerpo del artículo */
.post-detalle__body {
  padding: 56px 0 64px;
  background: var(--blanco);
}

.post-detalle__grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 48px;
  align-items: start;
}

/* Contenido tipográfico del post */
.post-detalle__contenido {
  font-size: 1rem;
  line-height: 1.85;
  color: var(--oscuro);
}

.post-detalle__contenido h2 {
  font-size: 1.6rem;
  margin: 40px 0 16px;
  color: var(--oscuro);
}

.post-detalle__contenido h3 {
  font-size: 1.2rem;
  margin: 28px 0 12px;
  color: var(--oscuro);
}

.post-detalle__contenido p {
  margin-bottom: 18px;
  color: var(--gris-texto);
}

.post-detalle__contenido ul,
.post-detalle__contenido ol {
  margin: 0 0 18px 20px;
  list-style: disc;
}

.post-detalle__contenido li {
  margin-bottom: 8px;
  color: var(--gris-texto);
  line-height: 1.7;
}

.post-detalle__contenido strong {
  color: var(--oscuro);
  font-weight: 500;
}

.post-detalle__contenido a {
  color: var(--naranja);
  text-decoration: underline;
}

.post-detalle__contenido a:hover {
  color: var(--naranja-oscuro);
}

.post-detalle__contenido img {
  width: 100%;
  border-radius: var(--radio-lg);
  margin: 24px 0;
}

.post-detalle__contenido blockquote {
  border-left: 4px solid var(--naranja);
  padding: 12px 20px;
  margin: 24px 0;
  background: var(--naranja-claro);
  border-radius: 0 var(--radio) var(--radio) 0;
}

.post-detalle__contenido blockquote p {
  margin: 0;
  font-style: italic;
  color: #7A3A10;
}

/* Sidebar */
.sidebar-card {
  background: var(--gris-fondo);
  border: 1px solid var(--gris-borde);
  border-radius: var(--radio-lg);
  padding: 20px;
  position: sticky;
  top: 84px;
}

.sidebar-card__titulo {
  font-size: 0.95rem;
  font-weight: 700;
  margin-bottom: 8px;
  font-family: var(--font-titulo);
}

.sidebar-card__desc {
  font-size: 0.82rem;
  color: var(--gris-texto);
  line-height: 1.6;
  margin-bottom: 14px;
}

/* Posts relacionados */
.posts-relacionados {
  padding: 56px 0;
  background: var(--gris-fondo);
}

/* ============================================================
   PÁGINAS LEGALES
   ============================================================ */

.legal-page {
  padding: 56px 0 80px;
  background: var(--blanco);
}

.legal-page__inner {
  max-width: 760px;
}

.legal-page__titulo {
  font-family: var(--font-titulo);
  font-size: clamp(1.8rem, 3.5vw, 2.4rem);
  font-weight: 900;
  margin: 20px 0 6px;
  letter-spacing: -0.5px;
}

.legal-page__fecha {
  font-size: 0.8rem;
  color: #aaa;
  margin-bottom: 36px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--gris-borde);
}

.legal-page__contenido h2 {
  font-family: var(--font-titulo);
  font-size: 1.25rem;
  font-weight: 700;
  margin: 32px 0 12px;
  color: var(--oscuro);
}

.legal-page__contenido h3 {
  font-size: 1rem;
  font-weight: 500;
  margin: 20px 0 8px;
  color: var(--oscuro);
}

.legal-page__contenido p {
  font-size: 0.9rem;
  color: var(--gris-texto);
  line-height: 1.8;
  margin-bottom: 14px;
}

.legal-page__contenido ul {
  margin: 0 0 16px 20px;
  list-style: disc;
}

.legal-page__contenido li {
  font-size: 0.9rem;
  color: var(--gris-texto);
  line-height: 1.7;
  margin-bottom: 6px;
}

.legal-page__contenido a {
  color: var(--naranja);
  text-decoration: underline;
}

/* ============================================================
   RESPONSIVE ADICIONAL — BLOG Y PÁGINAS LEGALES
   ============================================================ */

@media (max-width: 900px) {
  .post-detalle__grid {
    grid-template-columns: 1fr;
  }

  .sidebar-card {
    position: static;
  }

  .post-detalle__grid .post-detalle__contenido {
    order: 1;
  }

  .post-detalle__grid .post-detalle__sidebar {
    order: 2;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
  }

  .post-detalle__grid .post-detalle__sidebar .sidebar-card {
    margin-top: 0;
  }
}

@media (max-width: 768px) {
  .blog-hero { padding: 48px 0 40px; }

  .blog-hero__titulo {
    font-size: clamp(1.7rem, 6vw, 2.4rem);
  }

  .post-detalle__header {
    min-height: 280px;
  }

  .post-detalle__titulo {
    font-size: clamp(1.4rem, 5vw, 2rem);
  }

  .post-detalle__extracto {
    font-size: 0.9rem;
  }

  .post-detalle__body {
    padding: 36px 0 48px;
  }

  .post-detalle__contenido {
    font-size: 0.95rem;
  }

  .post-detalle__contenido h2 {
    font-size: 1.3rem;
    margin: 28px 0 12px;
  }

  .paginacion {
    flex-direction: column;
    gap: 10px;
  }

  .paginacion__btn {
    width: 100%;
    text-align: center;
    justify-content: center;
  }

  .legal-page { padding: 40px 0 60px; }

  .legal-page__titulo {
    font-size: clamp(1.5rem, 5vw, 2rem);
  }

  .posts-relacionados { padding: 40px 0; }

  .blog-card__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

@media (max-width: 480px) {
  .post-detalle__meta {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }

  .post-detalle__header-contenido {
    padding: 36px 0 28px;
  }
}
