/**
 * Landing Page Theme — assets/css/main.css
 * Estilos complementares. Edite aqui sem tocar no style.css.
 *
 * @package Landing Page v2
 */

/* ==========================================================================
   LAYOUT RESPONSIVO DAS SEÇÕES
   ========================================================================== */

/* Grid 2 cols no mobile para stats */
@media (min-width: 768px) {
  .grid-2 {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Stats grid — 4 cols no desktop */
  #stats-grid {
    grid-template-columns: repeat(4, 1fr);
    background: var(--c-border);
  }

  /* Sobre — 2 cols no desktop */
  #sobre .container > div {
    grid-template-columns: 1fr 1fr;
  }

  /* Contato — 2 cols no desktop */
  #contato .container > div {
    grid-template-columns: 1fr 1fr;
  }

  /* CTA block — 2 cols no desktop */
  .cta-block-inner {
    grid-template-columns: 1fr auto !important;
  }
}

@media (min-width: 1024px) {
  .grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Pilares sobre — 2 cols */
  .pilares-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ==========================================================================
   HEADER OFFSET — SEÇÕES COM ÂNCORA
   ========================================================================== */
[id] {
  scroll-margin-top: calc(var(--header-h) + 1rem);
}

/* ==========================================================================
   SELECT ESTILIZADO
   ========================================================================== */
select.form-control {
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7A9A' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.875rem center;
  padding-right: 2.5rem;
}
select.form-control option {
  background: var(--c-navy-2);
  color: var(--c-white);
}

/* ==========================================================================
   TECH TAGS nos cards de serviço
   ========================================================================== */
.card:hover .card__icon {
  background: rgba(29,95,240,0.2);
  border-color: rgba(29,95,240,0.35);
}

/* ==========================================================================
   FORMULÁRIO — grid responsivo 1 col no mobile
   ========================================================================== */
#form-contato > div[style*="grid-template-columns: 1fr 1fr"] {
  grid-template-columns: 1fr;
}

@media (min-width: 640px) {
  #form-contato > div[style*="grid-template-columns: 1fr 1fr"] {
    grid-template-columns: 1fr 1fr;
  }
}

/* ==========================================================================
   SEARCH FORM (404)
   ========================================================================== */
.search-form {
  display: flex;
  gap: 0.5rem;
  max-width: 420px;
  margin: 0 auto;
}
.search-field {
  flex: 1;
  padding: 0.75rem 1rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--c-border-mid);
  border-radius: var(--r-md);
  color: var(--c-white);
  font-size: var(--fs-base);
  font-family: var(--font-body);
  transition: border-color var(--t-fast);
}
.search-field::placeholder { color: var(--c-muted); }
.search-field:focus {
  outline: none;
  border-color: var(--c-blue);
}
.search-submit {
  padding: 0.75rem 1.25rem;
  background: var(--c-blue);
  color: #fff;
  border: none;
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  transition: background var(--t-fast);
}
.search-submit:hover { background: var(--c-blue-hover); }

/* ==========================================================================
   PROCESSO — borda no último item
   ========================================================================== */
#processo .container > div > div:last-child {
  border-bottom: none;
}

/* ==========================================================================
   ELEMENTOR — PRO HEADER/FOOTER
   ========================================================================== */
body.elementor-template-full-width .site-header,
body.elementor-template-full-width .site-footer {
  /* Descomente se Elementor Pro gerenciar header/footer:
  display: none;
  */
}

/* ==========================================================================
   PAGINAÇÃO
   ========================================================================== */
.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--r-md);
  font-size: var(--fs-sm);
  font-weight: 500;
  border: 1px solid var(--c-border-mid);
  color: var(--c-muted-light);
  text-decoration: none;
  transition: all var(--t-fast);
  font-family: var(--font-mono);
}
.page-numbers:hover, .page-numbers.current {
  background: var(--c-blue);
  border-color: var(--c-blue);
  color: #fff;
}
nav.pagination { display: flex; gap: 0.375rem; justify-content: center; margin-top: 3rem; flex-wrap: wrap; }

/* ==========================================================================
   SCROLLBAR
   ========================================================================== */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--c-navy); }
::-webkit-scrollbar-thumb { background: #1d3460; border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--c-blue); }

/* ==========================================================================
   SELEÇÃO DE TEXTO
   ========================================================================== */
::selection {
  background: rgba(29,95,240,0.25);
  color: var(--c-white);
}

/* ==========================================================================
   FOCUS VISIBLE
   ========================================================================== */
:focus-visible {
  outline: 2px solid var(--c-blue);
  outline-offset: 3px;
  border-radius: 3px;
}

/* ==========================================================================
   WIDGET AREA
   ========================================================================== */
.widget { margin-bottom: 2rem; }
.widget-title {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--c-muted);
  margin-bottom: 1rem;
  font-weight: 400;
}
