/* ==========================================================================
   7Conecta Plugin — Archive & Single Styles
   Uses theme design tokens (--c-*, --r-*, --sh-*, --ff, --max)
   ========================================================================== */

/* ---- Archive Hero ---- */
.archive-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--c-dark) 0%, #02327A 50%, var(--c-primary) 100%);
  color: #fff;
  padding: clamp(3rem, 6vw, 4.5rem) 0;
  text-align: center;
}
.archive-hero-bg { position: absolute; inset: 0; pointer-events: none; }
.archive-hero-bg .blob { position: absolute; border-radius: 50%; filter: blur(60px); opacity: .3; }
.archive-hero-bg .blob-a { width: 320px; height: 320px; background: #1A6BFF; top: -100px; right: -80px; }
.archive-hero-bg .blob-b { width: 220px; height: 220px; background: var(--c-orange); bottom: -60px; left: 10%; opacity: .2; }
.archive-hero-inner { position: relative; }
.archive-hero-title {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  color: #fff;
  letter-spacing: -.02em;
  margin: 0 0 .5rem;
}

/* ---- Archive Filters ---- */
.archive-filters {
  position: relative;
  margin-top: -2rem;
  margin-bottom: 2.5rem;
  background: var(--c-white, #fff);
  border-radius: var(--r-lg, 14px);
  padding: 1.25rem 1.5rem;
  box-shadow: var(--sh-3);
  z-index: 2;
}
.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  align-items: center;
}
.filter-field--search {
  flex: 1;
  min-width: 200px;
  position: relative;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.filter-ico {
  width: 20px;
  height: 20px;
  color: var(--c-text-3, #76859a);
  flex-shrink: 0;
}
.filter-input {
  flex: 1;
  border: 1px solid var(--c-line, #e6eaf0);
  border-radius: var(--r-sm, 6px);
  padding: .7rem 1rem;
  font-size: .95rem;
  font-family: var(--ff);
  color: var(--c-text);
  transition: border-color .15s;
}
.filter-input:focus { outline: none; border-color: var(--c-primary); }
.filter-select {
  padding: .7rem 1rem;
  border: 1px solid var(--c-line, #e6eaf0);
  border-radius: var(--r-sm, 6px);
  font-size: .95rem;
  font-family: var(--ff);
  color: var(--c-text);
  min-width: 140px;
  background: #fff;
  transition: border-color .15s;
}
.filter-select:focus { outline: none; border-color: var(--c-primary); }

/* ---- Archive Main ---- */
.archive-main {
  padding: 0 0 clamp(3rem, 6vw, 5rem);
}

/* ---- Biz Grid (shared with home) ---- */
.biz-grid.loading { opacity: 0.5; pointer-events: none; }

/* ---- Pagination ---- */
.archive-pagination {
  margin-top: 3rem;
  text-align: center;
}
.archive-pagination .nav-links {
  display: inline-flex;
  gap: .4rem;
  align-items: center;
}
.archive-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 .75rem;
  border-radius: var(--r-sm, 6px);
  font-size: .9rem;
  font-weight: 600;
  color: var(--c-text-2, #4a5a73);
  background: var(--c-bg, #f8f9fa);
  border: 1px solid var(--c-line, #e6eaf0);
  transition: background .15s, color .15s, border-color .15s;
  text-decoration: none;
}
.archive-pagination .page-numbers:hover {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
}
.archive-pagination .page-numbers.current {
  background: var(--c-primary);
  color: #fff;
  border-color: var(--c-primary);
}

/* ---- Empty state ---- */
.archive-empty {
  text-align: center;
  padding: 4rem 1rem;
  color: var(--c-text-2);
  font-size: 1.1rem;
}
.archive-empty .btn { margin-top: 1rem; }

/* ==========================================================================
   Single Empresa
   ========================================================================== */
.empresa-detail__header { display: flex; align-items: center; gap: 1.5rem; margin-bottom: 2rem; }
.empresa-detail__logo img { max-width: 120px; border-radius: 8px; }
.empresa-detail__content { display: grid; grid-template-columns: 1fr 320px; gap: 2rem; }
.empresa-info-box { background: var(--c-bg, #f8f9fa); padding: 1.25rem; border-radius: var(--r-md, 10px); margin-bottom: 1rem; }
.empresa-info-box h3 { margin: 0 0 0.75rem; font-size: 1rem; color: var(--c-dark); }
.btn-whatsapp {
  display: inline-block;
  padding: 0.5rem 1rem;
  background: #25d366;
  color: #fff;
  border-radius: 6px;
  text-decoration: none;
  font-weight: 600;
}
#empresa-map { height: 300px; border-radius: var(--r-md, 10px); margin-top: 1rem; }
.empresa-detail__footer { margin-top: 2rem; padding-top: 1rem; border-top: 1px solid var(--c-line, #e5e7eb); }
.badge { background: var(--c-primary); color: #fff; padding: 0.25rem 0.75rem; border-radius: 4px; font-size: 0.85rem; }

@media (max-width: 768px) {
  .empresa-detail__content { grid-template-columns: 1fr; }
  .empresa-detail__header { flex-direction: column; text-align: center; }
  .filter-row { flex-direction: column; }
  .filter-field--search { min-width: 100%; }
  .filter-select { width: 100%; }
  .archive-filters { margin-top: -1.5rem; padding: 1rem; }
}
