/* ============================================
   Sections — hero, verticais, servicos, etc.
   Design: institucional branco + azul + amarelo (acento)
   ============================================ */

/* ---------- HERO ---------- */
.hero {
  position: relative;
  padding-top: clamp(3rem, 6vw, 5.5rem);
  padding-bottom: clamp(5rem, 10vw, 9rem);
  background: var(--white);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 96px 96px;
  opacity: .8;
  pointer-events: none;
}

.hero__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2.5rem;
  position: relative;
  z-index: 1;
}
.hero__meta-l, .hero__meta-r {
  display: flex;
  gap: 1.5rem;
  font-family: var(--font-mono);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .04em;
  color: var(--ink-mute);
  text-transform: uppercase;
}
.hero__meta-r { text-align: right; }
.hero__meta b { color: var(--navy); font-weight: 500; }
@media (max-width: 720px) { .hero__meta-r { display: none; } }

.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: 4rem;
  align-items: end;
  z-index: 1;
}
.hero__content { max-width: 760px; }

.hero h1 {
  margin: 0 0 1.75rem;
  text-wrap: balance;
}
.hero h1 .hl { color: var(--yellow-deep); font-style: italic; }
.hero h1 .underline-y {
  background: linear-gradient(to top, var(--yellow) 18%, transparent 18%, transparent 22%, transparent);
  padding: 0 .1em;
}

.hero__lead {
  font-size: clamp(1.05rem, 1.35vw, 1.18rem);
  color: var(--ink-soft);
  margin: 0 0 2.5rem;
  line-height: 1.65;
  max-width: 58ch;
}
.hero__lead strong { color: var(--navy); font-weight: 600; }

.hero__cta { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 3rem; }

.hero__badges {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(2, max-content);
  gap: .65rem 2rem;
}
.hero__badges li {
  display: flex;
  flex-direction: column;
  font-family: var(--font-mono);
  font-size: .72rem;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.hero__badges strong {
  color: var(--navy);
  font-family: var(--font-body);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  text-transform: none;
}

/* ---------- HERO STAMP (selo "ART REGISTRADA") ---------- */
.hero__visual {
  position: relative;
  align-self: end;
  min-height: 360px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.hero__stamp {
  position: relative;
  width: 320px;
  aspect-ratio: 1;
  border: 2px solid var(--navy);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  background:
    repeating-conic-gradient(from 0deg, transparent 0deg 8deg, rgba(13,27,61,0.035) 8deg 9deg),
    var(--white);
  transform: rotate(-6deg);
  transition: transform 600ms cubic-bezier(.2,.7,.2,1);
  box-shadow: var(--shadow-md);
}
.hero__stamp:hover { transform: rotate(0deg) scale(1.02); }
.hero__stamp::before,
.hero__stamp::after {
  content: "";
  position: absolute;
  inset: 14px;
  border: 1px solid var(--navy);
  border-radius: 50%;
  pointer-events: none;
}
.hero__stamp::after {
  inset: 26px;
  border-style: dashed;
  border-color: var(--yellow-deep);
}
.hero__stamp-arc {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.hero__stamp-arc text {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .22em;
  fill: var(--navy);
  text-transform: uppercase;
}
.hero__stamp-mark {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 2.6rem;
  line-height: .95;
  color: var(--navy);
  letter-spacing: -0.025em;
  margin-bottom: .35rem;
}
.hero__stamp-mark span {
  display: block;
  font-family: var(--font-mono);
  font-size: .68rem;
  letter-spacing: .25em;
  color: var(--yellow-deep);
  margin-top: .55rem;
  font-weight: 500;
}
.hero__stamp-sub {
  font-family: var(--font-mono);
  font-size: .64rem;
  letter-spacing: .18em;
  color: var(--ink-soft);
  text-transform: uppercase;
  font-weight: 500;
  max-width: 62%;
  line-height: 1.6;
}

@media (max-width: 960px) {
  .hero__inner { grid-template-columns: 1fr; gap: 3rem; align-items: start; }
  .hero__visual { min-height: 280px; }
  .hero__stamp { width: 260px; }
  .hero__stamp-mark { font-size: 2.2rem; }
}
@media (max-width: 560px) {
  .hero { padding-top: 2rem; padding-bottom: 4rem; }
  .hero__meta { margin-bottom: 1.5rem; flex-wrap: wrap; gap: .5rem; }
  .hero__meta-l { flex-wrap: wrap; gap: .75rem 1rem; font-size: .68rem; }
  .hero__inner { gap: 2.5rem; }
  .hero h1 { font-size: clamp(1.75rem, 9vw, 2.4rem); line-height: 1.08; }
  .hero__lead { font-size: 1rem; margin-bottom: 1.75rem; }
  .hero__cta { flex-direction: column; gap: .75rem; margin-bottom: 2rem; }
  .hero__cta .btn { width: 100%; }
  .hero__visual { display: none; }
  .hero__badges { grid-template-columns: 1fr 1fr; gap: .65rem 1rem; }
  .hero__badges strong { font-size: .95rem; }
}

/* ---------- VERTICAIS ---------- */
.verticais { background: var(--bg-soft); }
.verticais__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1px solid var(--rule);
  background: var(--white);
}
.verticais__grid .vert-card { border: none; border-right: 1px solid var(--rule); }
.verticais__grid .vert-card:last-child { border-right: none; }
@media (max-width: 900px) {
  .verticais__grid { grid-template-columns: 1fr; }
  .verticais__grid .vert-card { border-right: none; border-bottom: 1px solid var(--rule); }
  .verticais__grid .vert-card:last-child { border-bottom: none; }
}

/* ---------- SERVIÇOS ---------- */
.servicos { background: var(--white); }
.servicos__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
}
.servicos__grid .serv-card {
  border-top: none;
  border-left: none;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}

/* ---------- DIFERENCIAIS (Compromissos) ---------- */
.diferenciais { background: var(--bg-soft); }
.dif__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  background: var(--white);
  border-left: 1px solid var(--rule);
  border-top: 1px solid var(--rule);
}
.dif__item {
  padding: 2.25rem 1.75rem;
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  transition: background var(--transition);
  display: flex;
  flex-direction: column;
}
.dif__item {
  position: relative;
}
.dif__item::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--yellow);
  opacity: 0;
  transition: opacity var(--transition);
}
.dif__item:hover {
  background: var(--white);
}
.dif__item:hover::before { opacity: 1; }
.dif__num {
  font-family: var(--font-mono);
  font-size: .8rem;
  font-weight: 500;
  color: var(--yellow-deep);
  letter-spacing: .04em;
  line-height: 1;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.dif__num::after {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--yellow-deep);
}
.dif__item .dif__title { font-size: 1.08rem; color: var(--navy); margin: 0 0 .65rem; font-family: var(--font-display); font-weight: 600; }
.dif__item p { color: var(--ink-soft); font-size: .94rem; margin: 0; line-height: 1.6; }

@media (max-width: 820px) { .dif__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px) { .dif__grid { grid-template-columns: 1fr; } }

/* ---------- NORMAS (Index) ---------- */
.normas { background: var(--navy); color: var(--white); }
.normas .eyebrow { color: var(--yellow); }
.normas .eyebrow::before { background: var(--yellow); }
.normas .section__head h2, .normas .section__head h3 { color: var(--white); }
.normas .section__lead { color: rgba(255, 255, 255, 0.72); }
.normas__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0;
  border-left: 1px solid rgba(255, 255, 255, 0.12);
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.norma-chip {
  background: transparent;
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 0;
  padding: 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
  transition: background var(--transition);
}
.norma-chip {
  cursor: default;
  transition: background var(--transition), transform var(--transition);
}
.norma-chip:hover {
  background: var(--navy-soft);
  transform: scale(1.02);
}
.norma-chip strong {
  color: var(--yellow);
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 600;
  letter-spacing: -0.015em;
}
.norma-chip span {
  color: rgba(255, 255, 255, 0.7);
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* ---------- CONTATO ---------- */
.contato { background: var(--white); }
.contato__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.contato__info h2 { margin-bottom: 1.25rem; max-width: 18ch; }
.contato__lead {
  color: var(--ink-soft);
  font-size: 1.05rem;
  margin-bottom: 2.25rem;
  max-width: 46ch;
}

.contato__cards { display: flex; flex-direction: column; gap: 0; }
.contato__card {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  padding: 1.15rem 1.25rem;
  background: var(--white);
  border: 1px solid var(--rule);
  border-bottom: none;
  transition: background var(--transition), transform var(--transition);
}
.contato__card:last-child { border-bottom: 1px solid var(--rule); }
.contato__card:hover { background: var(--bg-soft); transform: translateX(2px); }
.contato__card-ico {
  width: 40px;
  height: 40px;
  background: var(--navy);
  color: var(--yellow);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.contato__card-ico svg { width: 22px; height: 22px; }
.contato__card small {
  display: block;
  font-family: var(--font-mono);
  font-size: .68rem;
  color: var(--ink-mute);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 3px;
  font-weight: 500;
}
.contato__card strong {
  color: var(--navy);
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: -0.005em;
}

@media (max-width: 900px) {
  .contato__inner { grid-template-columns: 1fr; gap: 2.5rem; }
}

/* ---------- CLIENTES BAR ---------- */
.clientes-bar {
  background: var(--bg-soft);
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid var(--rule);
}
.clientes-bar__label {
  font-family: var(--font-mono);
  font-size: .7rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--ink-mute);
  text-align: center;
  margin: 0 0 1.75rem;
}
.clientes-bar__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  flex-wrap: wrap;
}
/* Logo real — uso: <img class="cliente-logo" src="..." alt="Nome Empresa"> */
.cliente-logo {
  height: 48px;
  width: auto;
  max-width: 140px;
  object-fit: contain;
  filter: grayscale(100%) opacity(0.55);
  transition: filter var(--transition);
}
.cliente-logo:hover { filter: grayscale(0%) opacity(1); }
/* Placeholder enquanto logos não chegam — remover quando trocar por <img> */
.logo-ph {
  width: 136px;
  height: 48px;
  border: 1px dashed rgba(13,27,61,.18);
  border-radius: var(--r-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: .62rem;
  font-weight: 500;
  color: var(--ink-mute);
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--white);
  user-select: none;
}

/* ---------- CAMPO (fotos) ---------- */
.campo__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.campo__foto { margin: 0; }

/* Foto real — uso: <img class="campo__img" src="..." alt="Descrição"> */
.campo__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  display: block;
  border: 1px solid var(--rule);
}
/* Placeholder enquanto fotos não chegam */
.foto-ph {
  width: 100%;
  aspect-ratio: 4/3;
  background: var(--bg-soft);
  border: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .85rem;
  color: rgba(13,27,61,.25);
  position: relative;
  overflow: hidden;
}
.foto-ph::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 48px 48px;
}
.foto-ph svg {
  width: 36px;
  height: 36px;
  position: relative;
  z-index: 1;
}
.foto-ph__label {
  font-family: var(--font-mono);
  font-size: .66rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--ink-mute);
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 1rem;
}
.campo__foto figcaption {
  font-family: var(--font-mono);
  font-size: .7rem;
  color: var(--ink-mute);
  margin-top: .65rem;
  letter-spacing: .04em;
  display: flex;
  align-items: center;
  gap: .5rem;
}
.campo__foto figcaption::before {
  content: "↑";
  color: var(--yellow-deep);
  font-size: .8rem;
}

@media (max-width: 820px) {
  .campo__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .campo__grid { grid-template-columns: 1fr; }
  .clientes-bar__logos { gap: 1rem; }
  .logo-ph { width: 110px; font-size: .58rem; }
}
