/* ==================================
   FORNECEDORES.CSS
   Archive + Single
   Mobile First
   Scoped for APP
================================== */


/* =========================
   BASE GERAL
========================= */

.app-content.archive-fornecedores,
.app-content.single-fornecedor {
  background: #f6f8f7;
  font-family: system-ui, -apple-system, sans-serif;
  color: #1e2a3a;
  line-height: 1.5;
  padding: 1rem;
}


/* =========================
   TIPOGRAFIA
========================= */

.app-content.archive-fornecedores h1,
.app-content.single-fornecedor h1 {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.app-content.archive-fornecedores h2,
.app-content.single-fornecedor h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: .5rem;
}

.app-content.archive-fornecedores h3,
.app-content.single-fornecedor h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin-top: 1rem;
  margin-bottom: .4rem;
}

.app-content.archive-fornecedores p,
.app-content.single-fornecedor p {
  font-size: .95rem;
  margin-bottom: .6rem;
  color: #555555;
}

.app-content small {
  font-size: .8rem;
  color: #555555;
}


/* =========================
   GRID
========================= */

.app-content .fornecedor-card,
.fornecedores-grid .fornecedor-card {
  background: #fff;
  border-radius: .8rem;
  padding: .8rem;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  margin-bottom: 1rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  position: relative;
  transition: transform .15s ease;
}

/* Tablet */
@media (min-width: 768px) {
  .app-content .fornecedores-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Desktop */
@media (min-width: 1024px) {
  .app-content .fornecedores-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* =========================
   CARD FORNECEDOR
========================= */


.app-content .fornecedor-card:hover {
  transform: translateY(-2px);
  transition: .2s ease;
}


/* =========================
   HEADER DO CARD
========================= */

.app-content .fornecedor-card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.app-content .fornecedor-nome {
  font-size: 1.05rem;
  font-weight: 600;
  color: #2f5d8c;
}


/* =========================
   LISTAS
========================= */

.app-content .fornecedor-card ul,
.app-content.single-fornecedor ul {
  padding-left: 1.2rem;
  margin: .5rem 0;
}

.app-content .fornecedor-card li,
.app-content.single-fornecedor li {
  margin-bottom: .3rem;
  line-height: 1.4;
}


/* listas internas */

.app-content .lista-servicos li,
.app-content .lista-etapas li {
  background: #f6f8fb;
  border-radius: .6rem;
  padding: .6rem .8rem;
  box-shadow: inset 0 0 0 1px #e2e6ec;
  list-style: none;
}

/* remover bullets estranhos */

.app-content .lista-servicos,
.app-content .lista-etapas {
  padding-left: 0;
}


/* =========================
   BOTÕES
========================= */

.app-content .btn {
  padding: .75rem 1.4rem;
  border-radius: 999px;
  background: #2f5d8c;
  color: #ffffff;
  font-weight: 600;
  border: none;
  display: inline-block;
  text-align: center;
  cursor: pointer;
  text-decoration: none;
}

.app-content .btn:hover {
  background: #1f466b;
}


/* =========================
   LINKS
========================= */

.app-content .fornecedor-card a,
.app-content.single-fornecedor a {
  color: #2f5d8c;
  text-decoration: none;
  font-weight: 500;
}

.app-content .fornecedor-card a:hover,
.app-content.single-fornecedor a:hover {
  color: #1f466b;
}


/* =========================
   SINGLE FORNECEDOR
========================= */

.app-content.single-fornecedor .fornecedor-info {
  background: #ffffff;
  border-radius: 1rem;
  padding: 1rem;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  margin-bottom: 1rem;
}

.app-content .fornecedor-bloco {
  margin-bottom: 1.5rem;
}


/* =========================
   CTA
========================= */

.app-content .cta {
  background: linear-gradient(135deg,#fff2c2,#ffe08a);
  padding: 1.6rem;
  border-radius: 1rem;
  text-align: center;
  margin-top: 1.5rem;
}

.app-content .cta h3 {
  margin-bottom: .5rem;
}


/* =========================
   FILTROS / MODAL
========================= */

.app-content .modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  display: none;
  z-index: 1000;
}

.app-content .modal.active {
  display: block;
}

.app-content .modal-content {
  background: #ffffff;
  border-radius: 20px 20px 0 0;
  padding: 1.2rem;
  position: absolute;
  bottom: 0;
  width: 100%;
}


/* =========================
   ÍCONES
========================= */

.app-content .icon {
  color: #2f5d8c;
  width: 20px;
  height: 20px;
}


/* =========================
   TEXTO LONGO
========================= */

.app-content .texto-longo {
  text-align: justify;
}


/* =========================
   HEADER LOCAL
========================= */

.app-content .fornecedores-header {
  text-align: center;
  margin-bottom: 1rem;
}


/* =========================
   FOOTER LOCAL
========================= */

.app-content .fornecedores-footer {
  margin-top: 2rem;
  text-align: center;
  font-size: .8rem;
  color: #555555;
}


/* =========================
   ESPAÇAMENTOS
========================= */

.app-content .mb-1 { margin-bottom: .5rem; }
.app-content .mb-2 { margin-bottom: 1rem; }
.app-content .mb-3 { margin-bottom: 1.5rem; }



/* ==========================
   FORNECEDORES - ESTILO POR PLANO
========================== */
.fornecedor-card.fornecedor-premium {
  background: #fff3cc;
  border-left: 5px solid #d4a017;
}

.fornecedor-card.fornecedor-basic {
  background: #e8f2fb;
  border-left: 5px solid #1f6fb2;
}

.fornecedor-card.fornecedor-free {
  background: #f2f2f2;
  border-left: 5px solid #777;
}


/* texto sempre legível */
.fornecedor-card p,
.fornecedor-card strong {
  color: #1e2a3a;
}