/* ============================================================
   HouseMatch — Sistema de diseño estilo Apple
   Cargar DESPUÉS de tailwind.min.css para poder refinarlo.
   Clases con prefijo .ap- para no chocar con Tailwind.
   ============================================================ */

:root {
  /* Acento (azul HouseMatch, con refinamiento Apple alrededor) */
  --ap-accent: #136dec;
  --ap-accent-hover: #2563eb;
  --ap-accent-soft: rgba(19, 109, 236, 0.10);

  /* Superficies */
  --ap-bg: #f5f5f7;
  --ap-surface: #ffffff;
  --ap-surface-2: #fbfbfd;

  /* Texto */
  --ap-text: #1d1d1f;
  --ap-text-secondary: #6e6e73;
  --ap-text-tertiary: #86868b;

  /* Bordes (hairlines) */
  --ap-border: rgba(0, 0, 0, 0.08);

  /* Radios */
  --ap-radius-sm: 10px;
  --ap-radius: 14px;
  --ap-radius-lg: 20px;
  --ap-radius-xl: 28px;

  /* Sombras */
  --ap-shadow-sm: 0 1px 2px rgba(0,0,0,.04), 0 1px 6px rgba(0,0,0,.04);
  --ap-shadow: 0 4px 24px rgba(0,0,0,.06);
  --ap-shadow-lg: 0 12px 40px rgba(0,0,0,.10);

  /* Estados */
  --ap-green: #1d9e4b;
  --ap-red: #e0301e;

  /* Tipografía del sistema (SF Pro en dispositivos Apple, Inter de respaldo) */
  --ap-font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text",
             "Inter", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

/* ---------- Base ---------- */
.ap-body {
  background: var(--ap-bg);
  color: var(--ap-text);
  font-family: var(--ap-font);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.01em;
}
html { scroll-behavior: smooth; }

/* Scrollbar discreto estilo macOS */
.ap-body ::-webkit-scrollbar { width: 10px; height: 10px; }
.ap-body ::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,.18); border-radius: 8px;
  border: 2px solid transparent; background-clip: content-box;
}
.ap-body ::-webkit-scrollbar-thumb:hover { background: rgba(0,0,0,.30); background-clip: content-box; }
.ap-body ::-webkit-scrollbar-track { background: transparent; }

/* ---------- Navbar / vidrio esmerilado ---------- */
.ap-navbar, .ap-glass {
  background: rgba(255,255,255,0.72);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
  border-bottom: 1px solid var(--ap-border);
}
.ap-glass { border: 1px solid var(--ap-border); }

/* ---------- Tarjeta ---------- */
.ap-card {
  background: var(--ap-surface);
  border: 1px solid var(--ap-border);
  border-radius: var(--ap-radius-xl);
  box-shadow: var(--ap-shadow);
}
.ap-card-header {
  display: flex; align-items: center; gap: .75rem;
  padding: 1.15rem 1.75rem;
  border-bottom: 1px solid var(--ap-border);
}
.ap-card-title {
  font-size: 1.0625rem; font-weight: 600;
  letter-spacing: -0.02em; color: var(--ap-text);
}

/* ---------- Tipografía utilitaria ---------- */
.ap-title { font-weight: 700; letter-spacing: -0.03em; color: var(--ap-text); }
.ap-subtitle { color: var(--ap-text-secondary); }
.ap-label {
  font-size: .8125rem; font-weight: 500;
  color: var(--ap-text-secondary); letter-spacing: 0;
}
.ap-hint { font-size: .75rem; color: var(--ap-text-tertiary); }

/* ---------- Inputs ---------- */
.ap-input {
  width: 100%;
  background: var(--ap-surface-2);
  border: 1px solid var(--ap-border);
  border-radius: var(--ap-radius);
  padding: .7rem .95rem;
  font-size: .9375rem;
  color: var(--ap-text);
  font-family: var(--ap-font);
  transition: border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance: none; appearance: none;
}
.ap-input::placeholder { color: var(--ap-text-tertiary); }
.ap-input:focus {
  outline: none;
  background: var(--ap-surface);
  border-color: var(--ap-accent);
  box-shadow: 0 0 0 4px var(--ap-accent-soft);
}
.ap-input:disabled { background: #f0f0f2; color: var(--ap-text-tertiary); cursor: not-allowed; }

/* ---------- Botones ---------- */
.ap-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  font-size: .9375rem; font-weight: 500;
  font-family: var(--ap-font);
  padding: .65rem 1.4rem;
  border-radius: 980px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background .2s, transform .12s, box-shadow .2s, color .2s, border-color .2s;
}
.ap-btn:active { transform: scale(.97); }
.ap-btn-primary { background: var(--ap-accent); color: #fff; }
.ap-btn-primary:hover { background: var(--ap-accent-hover); }
.ap-btn-primary:disabled { opacity: .55; cursor: default; }
.ap-btn-secondary { background: rgba(0,0,0,.05); color: var(--ap-text); }
.ap-btn-secondary:hover { background: rgba(0,0,0,.08); }
.ap-btn-ghost { background: transparent; color: var(--ap-text-secondary); border-color: var(--ap-border); }
.ap-btn-ghost:hover { color: var(--ap-accent); border-color: var(--ap-accent); }

/* ---------- Badges / pills ---------- */
.ap-badge {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .75rem; font-weight: 600;
  padding: .2rem .7rem; border-radius: 980px;
}
.ap-badge-accent { background: var(--ap-accent-soft); color: var(--ap-accent); }
.ap-badge-success { background: rgba(29,158,75,.12); color: var(--ap-green); }

/* ---------- Item de navegación / sidebar ---------- */
.ap-nav-item {
  display: flex; align-items: center; gap: .75rem;
  padding: .6rem .9rem; border-radius: var(--ap-radius);
  font-size: .9rem; font-weight: 500; color: var(--ap-text-secondary);
  transition: background .15s, color .15s;
}
.ap-nav-item:hover { background: rgba(0,0,0,.04); color: var(--ap-text); }
.ap-nav-item.active { background: var(--ap-accent-soft); color: var(--ap-accent); }

/* ---------- Helpers de acento ---------- */
.ap-accent { color: var(--ap-accent); }
.ap-bg-accent { background: var(--ap-accent); }
.ap-text-secondary { color: var(--ap-text-secondary); }
.ap-text-tertiary { color: var(--ap-text-tertiary); }
.ap-divider { border-color: var(--ap-border); }
