/* ===== Base ===== */
.ihp-widget{ width:100%; position:relative; }
.ihp-stage{ position:relative; display:inline-block; max-width:100%; overflow:visible; }
.ihp-image{
  display:block;
  max-width:100%;
  height:auto;
  border-radius:14px;
  position:relative;
  z-index:1;

  /* Zoom suave */
  transition: transform .28s ease, filter .28s ease;
  transform-origin: var(--ihp-zoom-x, 50%) var(--ihp-zoom-y, 50%);
}
.ihp-markers{ position:absolute; inset:0; z-index:5; }

/* ===== Zoom al hotspot (suave, premium) ===== */
.ihp-widget.ihp-zooming .ihp-image{
  transform: scale(1.06);
  filter: saturate(1.02) contrast(1.02);
}

/* ===== Pin premium numerado: SIEMPRE círculo ===== */
.ihp-pin{
  position:absolute;
  z-index:10;

  /* Tamaño premium default (se puede sobreescribir por Elementor) */
  width:12px;
  height:12px;
  min-width:12px;
  min-height:12px;

  border-radius:50% !important;
  overflow:hidden;
  box-sizing:border-box;
  padding:0 !important;
  line-height:1 !important;

  border:2px solid #fff;
  background:#222;
  box-shadow: 0 0 0 4px rgba(0,0,0,.12), 0 6px 16px rgba(0,0,0,.22);

  transform:translate(-50%, -50%);
  cursor:pointer;

  display:flex;
  align-items:center;
  justify-content:center;

  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.ihp-pin:hover{
  transform:translate(-50%, -50%) scale(1.18);
  box-shadow: 0 0 0 6px rgba(0,0,0,.12), 0 10px 22px rgba(0,0,0,.28);
}
.ihp-pin:focus{ outline:3px solid rgba(0,0,0,.22); outline-offset:2px; }

/* Número dentro del pin */
.ihp-pin__num{
  font-size:10px;
  font-weight:800;
  color:#fff;
  letter-spacing:-0.2px;
  user-select:none;
  transform: translateY(0.2px);
}

/* Pulso premium */
.ihp-pin.ihp-pin--pulse::after{
  content:"";
  position:absolute;
  left:50%; top:50%;
  width:22px; height:22px;
  transform:translate(-50%, -50%);
  border-radius:50%;
  border:1px solid rgba(0,0,0,.25);
  opacity:.35;
  animation: ihpPulse 2.4s infinite ease-out;
  pointer-events:none;
}
@keyframes ihpPulse{
  0%{ transform:translate(-50%, -50%) scale(.6); opacity:.35; }
  100%{ transform:translate(-50%, -50%) scale(1.7); opacity:0; }
}

/* ===== Tooltip Apple/Airbnb ===== */
.ihp-tooltip{
  position:absolute;
  left:0; top:0;
  z-index:60;
  pointer-events:auto;

  width: 280px;
  max-width: min(86vw, 320px);

  padding: 10px 12px;
  border-radius: 14px;

  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 55px rgba(0,0,0,.18);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  transform: translate(-50%, calc(-100% - 12px));
  transform-origin: center bottom;

  animation: ihpTipIn .14s ease-out;
}
@keyframes ihpTipIn{
  from{ opacity:0; transform: translate(-50%, calc(-100% - 8px)) scale(.98); }
  to{ opacity:1; transform: translate(-50%, calc(-100% - 12px)) scale(1); }
}
.ihp-tooltip[aria-hidden="true"]{ display:none; }

.ihp-tooltip::after{
  content:"";
  position:absolute;
  left: var(--ihp-arrow-x, 50%);
  bottom: -7px;
  width:14px; height:14px;
  background: rgba(255,255,255,.92);
  border-left: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
  transform: translateX(-50%) rotate(45deg);
}

.ihp-modal__title{
  margin: 0 28px 4px 0;
  font-weight: 600;
  font-size: 11.5px;
}


.ihp-tooltip__img img{
  width:100%;
  height:auto;
  border-radius: 12px;
  display:block;
  margin: 6px 0 8px;
}
.ihp-tooltip__text{
  font-size: 12.8px;
  line-height: 1.35;
}
.ihp-tooltip__cta{ margin-top: 8px; }

/* ===== Modal: tarjeta inmobiliaria, compacta ===== */
.ihp-modal[aria-hidden="true"]{ display:none; }
.ihp-modal{ position:fixed; inset:0; z-index:9999; }
.ihp-modal__backdrop{ position:absolute; inset:0; background: rgba(0,0,0,.32); }

/* Panel anclado al PIN (posicionado por JS) */
.ihp-modal__panel{
  position: fixed;
  left: 50%;
  top: 50%;
  width: min(86vw, 340px);
  max-width: 340px;

  background:#fff;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 22px 70px rgba(0,0,0,.22);

  padding: 12px;
  transform: translate(-50%, calc(-100% - 18px));
  transform-origin: center bottom;

  animation: ihpModalIn .16s ease-out;
}
@keyframes ihpModalIn{
  from{ opacity:0; transform: translate(-50%, calc(-100% - 10px)) scale(.985); }
  to{ opacity:1; transform: translate(-50%, calc(-100% - 18px)) scale(1); }
}

/* Flecha */
.ihp-modal__panel::after{
  content:"";
  position:absolute;
  left: var(--ihp-arrow-x, 50%);
  bottom: -8px;
  width:16px; height:16px;
  background:#fff;
  border-right: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
  transform: translateX(-50%) rotate(45deg);
}

/* Si va debajo del pin */
.ihp-modal__panel.ihp-below{
  transform: translate(-50%, 18px);
  transform-origin: center top;
}
.ihp-modal__panel.ihp-below::after{
  top:-8px;
  bottom:auto;
  border-right: 0;
  border-bottom: 0;
  border-left: 1px solid rgba(0,0,0,.08);
  border-top: 1px solid rgba(0,0,0,.08);
  transform: translateX(-50%) rotate(45deg);
}

/* Botón cerrar compacto */
.ihp-modal__close{
  position:absolute;
  right: 10px;
  top: 10px;
  width: 26px;
  height: 26px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  cursor:pointer;
  font-size: 14px;
  line-height: 1;
}

/* Layout tarjeta */
.ihp-modal__body{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin-top: 4px;
}
.ihp-modal__media{
  flex: 0 0 120px;
}
.ihp-modal__img img{
  width: 100%;
  max-width: 120px;
  height: auto;
  border-radius: 12px;
  display:block;
}
.ihp-modal__content{
  flex: 1 1 auto;
  min-width: 0;
}
.ihp-modal__title{
  margin: 0 34px 6px 0;
  font-weight: 900;
  font-size: 14px;
}
.ihp-modal__text{
  font-size: 12.8px;
  line-height: 1.35;
}
.ihp-modal__cta{ margin-top: 8px; }

/* CTA premium */
.ihp-cta{
  display:inline-flex;
  padding: 8px 10px;
  border-radius: 12px;
  text-decoration:none;
  border: 1px solid rgba(0,0,0,.14);
  font-size: 12.8px;
}

/* Mobile: apila la tarjeta */
@media (max-width: 520px){
  .ihp-modal__panel{ width: min(92vw, 330px); }
  .ihp-modal__body{ flex-direction: column; }
  .ihp-modal__media{ flex: 0 0 auto; }
  .ihp-modal__img img{ max-width: 160px; margin: 0 auto; }
}