/*
 * Imobilem Theme — Shared Primitives
 *
 * Atoms from Figma: buttons, tags, badges, form inputs.
 * Components scope their own CSS but rely on these global classes.
 */

/* ══════════════════════════════════════
   Buttons
   ══════════════════════════════════════ */
.imb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-8);
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-paragraph-2);
  text-decoration: none;
  border: 2px solid transparent;
  border-radius: var(--radius-btn);
  cursor: pointer;
  transition: opacity var(--ease), transform var(--ease), background-color var(--ease);
  text-align: center;
  line-height: 1;
}

.imb-btn:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.imb-btn:active {
  transform: translateY(0);
}

/* Primary — dark bg, verde text (btn_Habilitado) */
.imb-btn--primary {
  background-color: var(--c-charcoal);
  color: var(--c-brand);
}

/* Brand — verde bg, dark text */
.imb-btn--brand {
  background-color: var(--c-brand);
  color: var(--c-charcoal);
}

/* Outline — transparent bg, white border */
.imb-btn--outline {
  background-color: transparent;
  color: var(--c-white);
  border-color: var(--c-white);
}

/* Outline dark — transparent bg, dark border */
.imb-btn--outline-dark {
  background-color: transparent;
  color: var(--c-charcoal);
  border-color: var(--c-charcoal);
}

/* Ghost — no border, no bg */
.imb-btn--ghost {
  background-color: transparent;
  color: var(--c-charcoal);
  padding: var(--sp-2) var(--sp-4);
}

/* Disabled (btn_desabilitado) */
.imb-btn--disabled,
.imb-btn:disabled {
  background-color: var(--c-gris-2);
  color: var(--c-gris-4);
  cursor: not-allowed;
  pointer-events: none;
  opacity: 0.7;
}

/* Size: small */
.imb-btn--sm {
  font-size: var(--text-base);
  padding: var(--sp-2) var(--sp-5);
}

/* Size: large */
.imb-btn--lg {
  font-size: var(--text-xl);
  padding: var(--sp-4) var(--sp-10);
}

/* Pill shape */
.imb-btn--pill {
  border-radius: var(--radius-pill);
}

/* Pill link with chevron (btn_ok Variant2) */
.imb-btn--pill-link {
  background-color: var(--c-gris-2);
  border: 1px solid var(--c-gris-2);
  border-radius: var(--radius-pill);
  height: 38px;
  padding: 0 16px 0 22px;
  gap: var(--sp-1-5);
  font-size: var(--text-base);
  font-weight: var(--weight-normal);
  letter-spacing: var(--tracking-paragraph-3);
  color: var(--c-black);
}

.imb-btn--pill-link img,
.imb-btn--pill-link svg {
  width: 24px;
  height: 24px;
}

/* Icon-only (circular, like btn_Desarrollo_avance) */
.imb-btn--icon {
  width: 38px;
  height: 38px;
  padding: 0;
  border-radius: 50%;
}

.imb-btn--icon svg {
  width: 20px;
  height: 20px;
}

/* ══════════════════════════════════════
   Tags / Etiquetas de Estatus
   ══════════════════════════════════════ */
/* Figma: Párrafo 3 (14px Regular), padding 10px, height 26px, opacity 0.8, radius 6px */
.imb-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  height: 26px;
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--weight-normal);
  line-height: 1;
  letter-spacing: var(--tracking-paragraph-3);
  color: var(--c-black);
  border-radius: var(--radius-xs);
  opacity: 0.8;
  white-space: nowrap;
}

.imb-tag--entrega-inmediata { background-color: var(--c-tag-entrega); }
.imb-tag--vendido           { background-color: var(--c-tag-vendido); }
.imb-tag--proximo           { background-color: var(--c-tag-proximo); }
.imb-tag--preventa          { background-color: var(--c-tag-preventa); }
.imb-tag--en-desarrollo     { background-color: var(--c-tag-desarrollo); }
.imb-tag--renta-venta       { background-color: var(--c-tag-renta); }
.imb-tag--venta             { background-color: var(--c-tag-venta); }
.imb-tag--en-proceso        { background-color: var(--c-brand); }

/* ══════════════════════════════════════
   Badges (generic)
   ══════════════════════════════════════ */
.imb-badge {
  display: inline-block;
  padding: var(--sp-1) var(--sp-3);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--c-charcoal);
  border-radius: var(--radius-pill);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* ══════════════════════════════════════
   Zone Menu (SubHeader dropdown)
   Figma: D_Listado_MenuZonas
   ══════════════════════════════════════ */
/* Desktop: vertical list, left-aligned, gray text */
.imb-zone-menu {
  background-color: var(--c-white);
}

.imb-zone-menu__indicator {
  width: 93px;
  height: 1px;
  background-color: var(--c-black);
}

.imb-zone-menu__item {
  display: flex;
  align-items: center;
  padding: 10px 8px;
  height: 48px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  color: var(--c-gris-4);
  cursor: pointer;
  transition: color var(--ease);
  text-decoration: none;
}

.imb-zone-menu__item:hover,
.imb-zone-menu__item--active {
  color: var(--c-black);
}

/* Mobile: overlay dropdown, centered text, rounded, close btn */
.imb-zone-menu--mobile {
  width: 311px;
  border-radius: 34px;
  padding-top: 30px;
  position: relative;
}

.imb-zone-menu--mobile .imb-zone-menu__item {
  justify-content: center;
  text-align: center;
  padding: 19px 20px;
  height: auto;
  color: var(--c-black);
}

.imb-zone-menu__close {
  position: absolute;
  top: 10px;
  right: 0;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  cursor: pointer;
}

.imb-zone-menu__close img {
  width: 24px;
  height: 24px;
}

/* ══════════════════════════════════════
   Form Inputs
   ══════════════════════════════════════ */
.imb-input {
  display: block;
  width: 100%;
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--weight-normal);
  color: var(--c-black);
  background-color: var(--c-white);
  border: 1px solid var(--c-gris-2);
  border-radius: var(--radius-sm);
  transition: border-color var(--ease);
  letter-spacing: var(--tracking-paragraph-2);
}

.imb-input::placeholder {
  color: var(--c-gris-4);
}

.imb-input:focus {
  outline: none;
  border-color: var(--c-charcoal);
}

/* Rounded variant (mobile forms) — Gris 1 bg, radius 14px, 48px height */
.imb-input--rounded {
  background-color: var(--c-gris-1);
  border: none;
  border-radius: var(--radius-md);
  height: 48px;
  padding: 0 var(--sp-4);
}

.imb-input--dark {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.3);
  color: var(--c-white);
}

.imb-input--dark::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.imb-textarea {
  resize: vertical;
  min-height: 120px;
}

/* ══════════════════════════════════════
   Section wrapper (used by assemblePage)
   ══════════════════════════════════════ */
.imb-section {
  width: 100%;
}

/* ══════════════════════════════════════
   Utilities
   ══════════════════════════════════════ */

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

/* Max-width container */
.imb-container {
  width: 100%;
  max-width: var(--max-width);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--sp-5);
  padding-right: var(--sp-5);
}

@media (min-width: 768px) {
  .imb-container {
    padding-left: var(--sp-15);
    padding-right: var(--sp-15);
  }
}
