/* ══════════════════════════════════════════════
   DIJORGE v5 — espaçamentos compactos
══════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400;1,600&display=swap');

:root {
  --am:       #FFC107;
  --am-h:     #e0a800;
  --preto:    #1F1F1F;
  --cinza:    #6D6D6D;
  --cinza-lt: #f2f2f2;
  --bco:      #ffffff;
  --max:      1024px;
  --r:        6px;
  --t:        all .24s ease;
  /* Espaçamento padrão de seção — compacto */
  --sec-py:   52px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family:'Poppins',sans-serif;
  font-size:14px;
  color:var(--preto);
  background:var(--bco);
  overflow-x:hidden;
}

/* ── utilitários ── */
.wrap      { max-width:var(--max); margin:0 auto; padding:0 40px; }
.center    { text-align:center; }
.am        { color:var(--am); }
.linha-am  { width:40px; height:3px; background:var(--am); border-radius:2px; margin-top:10px; }
.label-topo {
  display:block; font-size:10px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--am); margin-bottom:6px;
}
.sec-titulo {
  font-size:clamp(20px,2.8vw,30px);
  font-weight:700; line-height:1.25; color:var(--preto);
}
.sec-titulo em { font-style:normal; color:var(--am); }
.sec-head { margin-bottom:32px; }   /* era 48px */
.sec-branco { background:var(--bco); }
.sec-cinza  { background:var(--cinza-lt); }

/* ══ NAVBAR ══════════════════════════════════ */
#nav {
  position:fixed; top:0; left:0; right:0; z-index:900;
  transition:background .35s ease, box-shadow .35s ease, opacity .35s ease;
}
#nav.on {
  background:rgba(31,31,31,.97);
  backdrop-filter:blur(10px);
  box-shadow:0 1px 0 rgba(255,255,255,.06);
}

/* Landscape: esconde navbar até rolar */
@media (orientation:landscape) {
  #nav {
    opacity:0;
    pointer-events:none;
  }
  #nav.on {
    opacity:1;
    pointer-events:auto;
  }
}
.nav-inner {
  max-width:var(--max); margin:0 auto; padding:0 40px;
  height:60px;
  display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:10px;
  text-decoration:none; flex-shrink:0;
}

.nav-logo img {
  max-width: 100px;
  height: auto;
}

.nav-nome {
  font-size:20px; font-weight:600;
  color:var(--bco); letter-spacing:-.3px;
}
.nav-nome em { font-style:normal; color:var(--am); font-weight:600; }
.nav-menu {
  display:flex; align-items:center; gap:26px; list-style:none;
}
.nav-menu a {
  font-size:13px; font-weight:500;
  color:rgba(255,255,255,.75); text-decoration:none; transition:var(--t);
}
.nav-menu a:hover { color:var(--am); }
.nav-btn-wpp {
  display:inline-flex; align-items:center; gap:6px;
  font-size:12px; font-weight:600;
  color:var(--am) !important;
  border:1.5px solid var(--am);
  padding:6px 14px; border-radius:var(--r);
  transition:var(--t) !important;
}
.nav-btn-wpp:hover { background:var(--am) !important; color:var(--preto) !important; }
.nav-btn-wpp svg  { color:var(--am); transition:var(--t); }
.nav-btn-wpp:hover svg { color:var(--preto); }
.nav-ham {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.nav-ham span {
  display:block; width:22px; height:2px;
  background:var(--bco); border-radius:2px; transition:var(--t);
}

/* ══ HERO ══════════════════════════════════════
   Portrait (vertical): 100vh
   Landscape (horizontal): 50vh
═══════════════════════════════════════════════ */
#hero {
  position:relative;
  min-height:100svh;          /* desktop portrait = tela toda */
  background:var(--preto);
  display:flex; align-items:center;
  overflow:hidden;
}

/* Mobile portrait: hero ocupa ~75vh para clientes aparecerem na dobra */
@media (max-width:600px) and (orientation:portrait) {
  #hero {
    min-height:75svh;
    max-height:75svh;
    align-items:flex-start;
  }
  .hero-inner {
    min-height:75svh !important;
    padding:70px 20px 24px !important;
    align-items:flex-start !important;
  }
  .hero-brand   { padding:0 0 10px !important; }
  .hero-copy    { padding:0 !important; }
  .hero-logo-img { width:100px !important; }
  .hero-brand-sub { font-size:8px !important; }
  .hero-h1      { font-size:clamp(19px,5.5vw,26px) !important; margin-bottom:14px !important; }
  .hero-desc    { display:none; }
  .hero-btns    { gap:8px !important; }
  .btn-hero-primary  { padding:10px 18px !important; font-size:12px !important; }
  .btn-hero-secondary{ padding:9px 14px !important; font-size:12px !important; }
}

/* Landscape: metade da altura */
@media (orientation:landscape) {
  #hero { min-height:50svh; }
  .hero-inner { min-height:50svh !important; }
  .hero-brand { padding:24px 0 !important; }
  .hero-sep   { margin:24px 32px !important; }
  .hero-copy  { padding:24px 0 !important; }
  .hero-logo-wrap svg { width:44px !important; height:44px !important; }
  .hero-brand-nome    { font-size:24px !important; }
  .hero-h1            { font-size:clamp(16px,2.2vw,26px) !important; margin-bottom:14px !important; }
  .hero-acao-item     { padding:10px 12px !important; }
}

.hero-bg-foto {
  position:absolute; top:0; right:0;
  width:62%; height:100%;
  background:url('../img/hero-bg.png') center top / cover no-repeat;
}
.hero-bg-grad {
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, var(--preto) 34%, rgba(31,31,31,.82) 58%, rgba(31,31,31,.18) 100%),
    linear-gradient(180deg, rgba(31,31,31,.4) 0%, transparent 50%, rgba(31,31,31,.45) 100%);
}
.hero-inner {
  position:relative; z-index:2;
  max-width:var(--max); margin:0 auto; padding:0 40px;
  width:100%; padding-top:60px;
  display:grid;
  grid-template-columns:210px 2px 1fr;
  min-height:100svh;
  align-items:center; gap:0;
}
.hero-brand { padding:70px 0; }
.hero-logo-wrap { margin-bottom:8px; }
.hero-brand-nome {
  font-size:36px; font-weight:700;
  color:var(--bco); line-height:1; letter-spacing:-.5px;
}
.hero-brand-nome em { font-style:normal; color:var(--am); }
.hero-brand-sub {
  font-size:9px; letter-spacing:2.5px; text-transform:uppercase;
  color:rgba(255,255,255,.5); font-weight:400; margin-top:6px;
}
.hero-criador {
  display:flex; align-items:center; gap:8px;
  margin-top:18px; padding-top:16px;
  border-top:1px solid rgba(255,255,255,.1);
}
.hero-criador svg  { color:var(--am); flex-shrink:0; }
.hero-criador span {
  font-size:9px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,.5); font-weight:600;
}
.hero-sep {
  background:var(--am); align-self:stretch;
  margin:70px 36px; border-radius:1px;
}
.hero-copy { padding:70px 0; }
.hero-eyebrow {
  font-size:10px; font-weight:600;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--am); margin-bottom:12px;
}
.hero-h1 {
  font-size:clamp(22px,3vw,38px);
  font-weight:700; line-height:1.2;
  color:var(--bco); margin-bottom:24px;
}
.hero-destaque { color:var(--am); font-style:italic; }
.hero-acoes {
  display:flex; align-items:stretch;
  border-top:1px solid rgba(255,255,255,.12);
  border-bottom:1px solid rgba(255,255,255,.12);
  margin-bottom:18px;
}
.hero-acao-item {
  display:flex; align-items:center; gap:12px;
  flex:1; padding:16px 14px;
  text-decoration:none; transition:var(--t); cursor:pointer;
}
.hero-acao-item:hover { background:rgba(255,255,255,.04); }
.hero-acao-item svg  { color:var(--am); flex-shrink:0; }
.hero-acao-item span {
  font-size:12px; font-weight:600;
  color:var(--bco); line-height:1.4;
}
.hero-acao-div {
  width:1px; background:rgba(255,255,255,.12);
  align-self:stretch; flex-shrink:0;
}
.hero-desc {
  font-size:13px; line-height:1.7;
  color:rgba(255,255,255,.6); max-width:420px;
}

/* ══ SERVIÇOS ═════════════════════════════════ */
#servicos { padding:var(--sec-py) 0; }

.serv-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
}
.serv-card {
  border:1px solid #e5e5e5; border-radius:var(--r);
  padding:24px 20px; transition:var(--t);
  position:relative; overflow:hidden;
}
.serv-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0;
  height:2px; background:var(--am);
  transform:scaleX(0); transition:var(--t);
}
.serv-card:hover { transform:translateY(-4px); box-shadow:0 10px 28px rgba(0,0,0,.09); border-color:transparent; }
.serv-card:hover::after { transform:scaleX(1); }
.serv-ic {
  width:42px; height:42px; background:rgba(255,193,7,.1);
  border-radius:9px; display:flex; align-items:center; justify-content:center;
  margin-bottom:12px;
}
.serv-ic svg  { color:var(--am); }
.serv-card h3 { font-size:14px; font-weight:600; margin-bottom:7px; }
.serv-card p  { font-size:12px; color:var(--cinza); line-height:1.7; margin-bottom:16px; }
.link-saiba {
  font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--am); text-decoration:none;
  display:inline-flex; align-items:center; gap:4px; transition:var(--t);
}
.link-saiba:hover { gap:8px; }

/* ══ QUOTE BANNER ═════════════════════════════ */
#quote-banner {
  position:relative; overflow:hidden;
  background:var(--preto); padding:44px 0;  /* era 60px */
}
.qb-foto {
  position:absolute; inset:0;
  background:url('../img/hero-bg.png') center/cover no-repeat; opacity:.12;
}
.qb-grad {
  position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(31,31,31,.98) 40%, rgba(31,31,31,.7) 100%);
}
.qb-inner {
  position:relative; z-index:2;
  display:flex; align-items:center; gap:14px;
}
.qb-aspas {
  font-family:Georgia,serif; font-size:80px;
  line-height:.6; color:var(--am); opacity:.65; flex-shrink:0;
}
.qb-txt p {
  font-size:clamp(16px,2.3vw,26px); font-weight:600;
  color:var(--bco); line-height:1.35;
}

/* ══ CLIENTES ═════════════════════════════════ */
#clientes { padding:32px 0; border-bottom:1px solid #ebebeb; }  /* era 40px */
.clientes-row {
  display:flex; align-items:center;
  justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.cliente-item {
  flex:1; min-width:90px;
  display:flex; align-items:center; justify-content:center;
  padding:12px 10px; border:1px solid #e8e8e8;
  border-radius:var(--r); transition:var(--t);
}
.cliente-item:hover { border-color:var(--am); }
.cliente-item span {
  font-size:12px; font-weight:700;
  color:#bbb; letter-spacing:.5px; transition:var(--t); white-space:nowrap;
}
.cliente-item:hover span { color:var(--preto); }

/* ══ DEPOIMENTOS ══════════════════════════════ */
#depoimentos { padding:var(--sec-py) 0; }

.dep-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px;
  margin-bottom:22px;
}
.dep-card {
  background:var(--bco); border:1px solid #e8e8e8;
  border-radius:var(--r); padding:22px 20px; transition:var(--t);
}
.dep-card:hover { box-shadow:0 8px 24px rgba(0,0,0,.07); transform:translateY(-3px); border-color:rgba(255,193,7,.3); }
.dep-aspas {
  font-family:Georgia,serif; font-size:42px;
  line-height:.8; color:var(--am); margin-bottom:8px;
}
.dep-card blockquote {
  font-size:12px; line-height:1.75; font-style:italic;
  color:var(--cinza); margin-bottom:16px;
}
.dep-autor {
  display:flex; align-items:center; gap:10px;
  padding-top:12px; border-top:1px solid #f0f0f0;
}
.dep-av {
  width:34px; height:34px; border-radius:50%;
  background:var(--am); color:var(--preto);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:13px; flex-shrink:0;
}
.dep-nome  { font-size:12.5px; font-weight:600; color:var(--preto); }
.dep-cargo { font-size:11px; color:var(--cinza); margin-top:1px; }
.dep-dots  { display:flex; justify-content:center; gap:8px; }
.dot {
  width:9px; height:9px; border-radius:50%;
  background:#ddd; cursor:pointer; transition:var(--t); border:none;
}
.dot.ativo { background:var(--am); transform:scale(1.2); }

/* ══ PORTFÓLIO ════════════════════════════════ */
#portfolio { padding:var(--sec-py) 0; background:var(--cinza-lt); }

/* ── Portfolio grid home: layout assimétrico fixo ── */
.port-grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr 1fr;
  grid-template-rows:220px 220px;
  gap:7px;
  margin-bottom:0;
}
/* Verticais nas extremidades e centro */
.port-item:nth-child(1) { grid-row:1/3; }
.port-item:nth-child(3) { grid-row:1/3; }
.port-item:nth-child(5) { grid-row:1/3; }
/* Horizontais entre as verticais */
.port-item:nth-child(2) { grid-row:1/2; grid-column:2/3; }
.port-item:nth-child(4) { grid-row:2/3; grid-column:2/3; }
.port-item:nth-child(6) { grid-row:1/2; grid-column:4/5; }
.port-item:nth-child(7) { grid-row:2/3; grid-column:4/5; }
/* Extra slots se tiver mais fotos */
.port-item:nth-child(n+8) { display:none; }

.port-item {
  position:relative; overflow:hidden;
  border-radius:6px; cursor:pointer;
  min-height:100%;
}
.port-item img {
  width:100%; height:100%; object-fit:cover; object-position:top center;
  display:block; transition:transform .45s ease; filter:grayscale(10%);
}
.port-item:hover img { transform:scale(1.05); filter:grayscale(0%); }
.port-ov {
  position:absolute; inset:0;
  background:rgba(31,31,31,.55);
  opacity:0; transition:var(--t);
  display:flex; align-items:flex-end; padding:10px;
}
.port-item:hover .port-ov { opacity:1; }
.port-ov span { font-size:11px; font-weight:600; color:var(--bco); }
/* ════════════════════════════════════════════
   SISTEMA DE BOTÕES — Site Dijorge
   Base comum: mesma fonte, border-radius, gap,
   transição e tamanho. Só muda cor/fundo.
   ════════════════════════════════════════════ */
.btn-site,
.btn-outline,
.btn-preto,
.btn-form,
.btn-dep-depoimento,
.btn-hero-primary,
.btn-hero-secondary {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family:'Poppins',sans-serif;
  font-size:12px;
  font-weight:700;
  letter-spacing:.5px;
  text-transform:uppercase;
  text-decoration:none;
  border-radius:var(--r);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  cursor:pointer;
  white-space:nowrap;
}
.btn-site:hover,
.btn-outline:hover,
.btn-preto:hover,
.btn-form:hover,
.btn-dep-depoimento:hover,
.btn-hero-primary:hover,
.btn-hero-secondary:hover {
  transform:translateY(-2px);
}

/* Variante 1: Contorno (sem fundo) */
.btn-outline {
  padding:10px 22px;
  color:var(--preto);
  background:transparent;
  border:1.5px solid #c8c8c8;
}
.btn-outline:hover {
  border-color:var(--am);
  color:var(--am);
  box-shadow:0 4px 14px rgba(255,193,7,.18);
}

/* Variante 2: Sólido preto */
.btn-preto {
  padding:12px 26px;
  color:var(--am);
  background:var(--preto);
  border:1.5px solid var(--preto);
}
.btn-preto:hover {
  background:#111;
  box-shadow:0 5px 18px rgba(0,0,0,.28);
}

/* Variante 3: Sólido amarelo (CTA principal) */
.btn-form {
  width:100%;
  padding:14px 24px;
  color:var(--preto);
  background:var(--am);
  border:1.5px solid var(--am);
  font-size:13px;
  border-radius:var(--r);
}
.btn-form svg { color:var(--preto); flex-shrink:0; }
.btn-form:hover {
  background:var(--am-h);
  border-color:var(--am-h);
  box-shadow:0 5px 18px rgba(255,193,7,.35);
}

/* Variante 4: Depoimento — mesmo padrão do btn-outline */
.btn-dep-depoimento {
  padding:10px 22px;
  color:var(--preto);
  background:transparent;
  border:1.5px solid #c8c8c8;
  text-transform:none;
  font-weight:600;
  letter-spacing:0;
}
.btn-dep-depoimento svg { color:var(--am); flex-shrink:0; }
.btn-dep-depoimento:hover {
  border-color:var(--am);
  color:var(--am);
  box-shadow:0 4px 14px rgba(255,193,7,.18);
}

/* ══ CTA FAIXA AMARELA ════════════════════════ */
#cta-faixa { background:var(--am); padding:40px 0; }  /* era 46px */

.cta-inner {
  display:flex; align-items:center;
  justify-content:space-between; gap:24px;
}
.cta-esq { display:flex; align-items:center; gap:16px; }
.cta-ic-circ {
  width:50px; height:50px; border-radius:50%;
  background:var(--preto); flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.cta-ic-circ svg { color:var(--am); }
.cta-titulo { font-size:clamp(15px,1.9vw,22px); font-weight:700; color:var(--preto); }
.cta-sub    { font-size:12px; color:rgba(0,0,0,.6); margin-top:3px; }
/* btn-preto definido no sistema de botões acima */

/* ══ FORMULÁRIO ═══════════════════════════════ */
#contato { padding:var(--sec-py) 0; }

.form-layout {
  display:grid; grid-template-columns:1fr 1.6fr; gap:48px;
  align-items:stretch;
}
.form-titulo {
  font-size:clamp(18px,2.3vw,26px); font-weight:700;
  margin-bottom:7px; line-height:1.2;
}
.form-sub {
  font-size:12px; color:var(--cinza);
  line-height:1.7; margin-bottom:22px;
}
.ben-item {
  display:flex; align-items:center; gap:11px; margin-bottom:14px;
}
.ben-ic {
  width:34px; height:34px; flex-shrink:0;
  background:rgba(255,193,7,.1); border-radius:7px;
  display:flex; align-items:center; justify-content:center;
}
.ben-ic svg  { color:var(--am); }
.ben-item strong { display:block; font-size:12.5px; font-weight:600; }
.ben-item span   { font-size:11px; color:var(--cinza); }
.form-card {
  background:var(--bco); border:1px solid #e5e5e5;
  border-radius:8px; padding:28px;
}
/* ── Colunas do formulário mesma altura ── */
.form-info {
  display:flex;
  flex-direction:column;
}
.form-card {
  display:flex;
  flex-direction:column;
  height:100%;
}
/* Textarea cresce para preencher espaço restante */
.form-card .fg:has(textarea) {
  flex:1;
  display:flex;
  flex-direction:column;
}
.form-card .fg textarea {
  flex:1;
  min-height:86px;
}

.form-row {
  display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:12px;
}
.fg { display:flex; flex-direction:column; gap:4px; margin-bottom:12px; }
.fg label { font-size:11px; font-weight:600; color:var(--preto); }
.fg label em { font-style:normal; color:var(--am); }
.fg input, .fg select, .fg textarea {
  width:100%; padding:9px 12px;
  border:1px solid #ddd; border-radius:var(--r);
  font-family:'Poppins',sans-serif; font-size:13px;
  color:var(--preto); background:var(--bco);
  outline:none; transition:var(--t);
}
.fg input:focus, .fg select:focus, .fg textarea:focus {
  border-color:var(--am); box-shadow:0 0 0 3px rgba(255,193,7,.12);
}
.fg textarea { resize:vertical; min-height:86px; }
.form-row .fg { margin-bottom:0; }
.btn-form {
  width:100%; padding:13px;
  background:var(--am); color:var(--preto);
  border:none; border-radius:var(--r);
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:700;
  cursor:pointer; display:flex; align-items:center;
  justify-content:center; gap:8px; letter-spacing:.4px;
  transition:var(--t); margin-top:2px;
}
.btn-form svg  { color:var(--preto); }
.btn-form:hover { background:var(--am-h); transform:translateY(-2px); box-shadow:0 5px 18px rgba(255,193,7,.35); }

/* ══ ACESSOS RÁPIDOS — após formulário, fundo cinza ══ */
#acessos {
  background:var(--cinza-lt);   /* fundo cinza conforme pedido */
  padding:36px 0;
  border-top:1px solid #e4e4e4;
  border-bottom:1px solid #e4e4e4;
}
.aces-grid {
  display:grid; grid-template-columns:repeat(6,1fr); gap:8px;
}
.aces-item {
  display:flex; flex-direction:column; align-items:center; gap:5px;
  text-decoration:none; padding:16px 8px; border-radius:var(--r);
  border:1px solid #e0e0e0;
  background:var(--bco);          /* botão branco sobre fundo cinza */
  transition:var(--t);
}
.aces-item svg   { color:var(--am); }
.aces-item:hover { border-color:var(--am); box-shadow:0 4px 12px rgba(255,193,7,.15); }
.aces-l { font-size:12px; font-weight:600; color:var(--preto); }
.aces-d { font-size:10px; color:var(--cinza); }

/* ══ FOOTER ═══════════════════════════════════ */
footer { background:var(--preto); color:var(--bco); padding:16px 0; }
.foot-inner {
  display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.foot-inner p { font-size:11px; color:rgba(255,255,255,.4); }

/* ══ BOTÃO FLUTUANTE ══════════════════════════ */
.btn-float {
  position:fixed; bottom:22px; right:22px; z-index:990;
  width:48px; height:48px; border-radius:50%;
  background:var(--am);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 14px rgba(255,193,7,.5); transition:var(--t);
}
.btn-float svg  { color:var(--preto); }
.btn-float:hover { transform:scale(1.1); box-shadow:0 6px 20px rgba(255,193,7,.65); }

/* ══ ANIMAÇÕES ════════════════════════════════ */
.fade-in {
  opacity:0; transform:translateY(22px);
  transition:opacity .55s ease, transform .55s ease;
  transition-delay:var(--d,0s);
}
.fade-in.vis { opacity:1; transform:none; }

/* ══ TOAST ════════════════════════════════════ */
.toast {
  position:fixed; bottom:22px; left:50%;
  transform:translateX(-50%) translateY(70px);
  background:var(--preto); color:var(--bco);
  padding:10px 18px; border-radius:var(--r);
  font-size:12px; font-weight:500;
  border-left:3px solid var(--am);
  box-shadow:0 4px 16px rgba(0,0,0,.3);
  transition:transform .3s ease; z-index:1002;
}
.toast.vis { transform:translateX(-50%) translateY(0); }

/* ══ RESPONSIVO ════════════════════════════════ */
@media (max-width:900px) {
  .hero-inner   { grid-template-columns:1fr; min-height:auto; padding:80px 40px 50px; }
  .hero-sep     { display:none; }
  .hero-bg-foto { width:100%; opacity:.2; }
  .hero-bg-grad { background:linear-gradient(180deg,rgba(31,31,31,.88) 0%,rgba(31,31,31,.6) 100%); }
  .hero-brand, .hero-copy { padding:16px 0; }
  .hero-acoes   { flex-wrap:wrap; }
  .hero-acao-div{ display:none; }
  .hero-acao-item{ flex:0 0 48%; }
  .serv-grid    { grid-template-columns:1fr 1fr; }
  .dep-grid     { grid-template-columns:1fr 1fr; }
  .port-grid    { grid-template-columns:1fr 1fr 1fr; grid-template-rows:auto; }
  .port-item:nth-child(n+8) { display:block; }
  .port-item:nth-child(1),.port-item:nth-child(3),.port-item:nth-child(5) { grid-row:auto; }
  .port-item:nth-child(2),.port-item:nth-child(4),.port-item:nth-child(6),.port-item:nth-child(7) { grid-row:auto; grid-column:auto; }
  .aces-grid    { grid-template-columns:repeat(3,1fr); }
  .form-layout  { grid-template-columns:1fr; gap:28px; }
  .cta-inner    { flex-direction:column; text-align:center; }
  .cta-esq      { flex-direction:column; }
  .clientes-row { gap:8px; }
}

@media (max-width:600px) {
  .wrap        { padding:0 20px; }
  .nav-ham { display:flex; }

  /* Menu deslizante — sempre renderizado, escondido via transform+visibility */
  .nav-menu {
    position:fixed;
    top:0; right:0;
    width:75vw; max-width:300px;
    height:100dvh;
    background:rgba(20,20,20,.99);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:flex-start;
    gap:0;
    padding:80px 40px 40px;
    overflow-y:auto;
    transform:translateX(110%);   /* fora da tela à direita */
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    z-index:1001;
    visibility:hidden;
    pointer-events:none;
  }
  .nav-menu.open {
    transform:translateX(0);
    visibility:visible;
    pointer-events:auto;
  }
  .nav-menu li {
    width:100%;
    border-bottom:1px solid rgba(255,255,255,.07);
  }
  .nav-menu li:last-child { border-bottom:none; margin-top:20px; }
  .nav-menu a {
    display:block;
    font-size:18px !important;
    font-weight:600 !important;
    color:rgba(255,255,255,.85) !important;
    padding:16px 0 !important;
    width:100%;
  }
  .nav-menu a:hover { color:var(--am) !important; }
  .nav-btn-wpp {
    font-size:15px !important;
    padding:12px 22px !important;
    width:100%;
    justify-content:center;
  }
  .serv-grid   { grid-template-columns:1fr; }
  .dep-grid    { grid-template-columns:1fr; }
  .port-grid   { grid-template-columns:repeat(2,1fr); }
  .aces-grid   { grid-template-columns:repeat(3,1fr); }
  .form-row    { grid-template-columns:1fr; }
  .hero-acoes  { border:none; flex-direction:column; }
  .hero-acao-item { flex:1; border-bottom:1px solid rgba(255,255,255,.1); }
  .foot-inner  { flex-direction:column; text-align:center; }
}

/* ══ BOTÕES HERO — hierarquia 3 níveis ══════ */
.hero-btns {
  display:flex; align-items:center;
  gap:12px; flex-wrap:wrap;
  margin-top:28px;
}

/* Nível 1: amarelo sólido — ação principal */
.btn-hero-primary {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--am); color:var(--preto);
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:700;
  letter-spacing:.4px; text-decoration:none;
  padding:13px 24px; border-radius:var(--r);
  transition:var(--t);
}
.btn-hero-primary svg { color:var(--preto); flex-shrink:0; }
.btn-hero-primary:hover {
  background:var(--am-h);
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(255,193,7,.4);
}

/* Nível 2: outline branco — alternativa */
.btn-hero-secondary {
  display:inline-flex; align-items:center; gap:9px;
  background:transparent; color:var(--bco);
  font-family:'Poppins',sans-serif; font-size:13px; font-weight:600;
  text-decoration:none;
  padding:12px 20px; border-radius:var(--r);
  border:1.5px solid rgba(255,255,255,.32);
  transition:var(--t);
}
.btn-hero-secondary svg { color:var(--bco); flex-shrink:0; }
.btn-hero-secondary:hover {
  border-color:rgba(255,255,255,.7);
  background:rgba(255,255,255,.06);
}

/* Nível 3: ghost — link discreto */
.btn-hero-ghost {
  display:inline-flex; align-items:center; gap:6px;
  color:rgba(255,255,255,.5);
  font-family:'Poppins',sans-serif; font-size:12px; font-weight:500;
  text-decoration:none;
  padding:4px 0;
  transition:var(--t);
}
.btn-hero-ghost svg { color:rgba(255,255,255,.4); transition:var(--t); }
.btn-hero-ghost:hover { color:var(--am); }
.btn-hero-ghost:hover svg { color:var(--am); }

/* Remove estilos antigos da .hero-acoes (não usados mais) */
.hero-acoes { display:none; }

/* ══ FAIXA DE CONFIANÇA (substitui números) ══════
   Fundo preto · badge +20 anos · carrossel logos
═════════════════════════════════════════════════ */
#confianca {
  background:var(--preto);
}

/* Topo: badge + texto */
.conf-topo {
  padding:16px 0 12px;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.conf-topo-inner {
  display:flex;
  align-items:center;
  gap:0;
  min-height:60px;
}

/* Badge "+30 anos" */
.conf-badge {
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
  padding-right:32px;
}
.conf-anos {
  font-size:44px;
  font-weight:800;
  color:var(--am);
  line-height:1;
  letter-spacing:-1px;
  align-self:center;
}
.conf-anos-lbl {
  font-size:11px;
  font-weight:600;
  color:rgba(255,255,255,.5);
  letter-spacing:1px;
  text-transform:uppercase;
  line-height:1.4;
  align-self:center;
}

/* Divisor vertical */
.conf-divider {
  width:1px;
  height:36px;
  background:rgba(255,255,255,.15);
  flex-shrink:0;
  margin-right:32px;
  align-self:center;
}

/* Frase */
.conf-frase {
  font-size:13px;
  font-weight:500;
  color:rgba(255,255,255,.55);
  line-height:1.6;
  letter-spacing:.3px;
  align-self:center;
}

/* Carrossel dentro da faixa preta */
#confianca .carrossel-outer {
  padding:18px 0;
  border-top:none;
}
#confianca .carrossel-item {
  padding:14px 40px;
  border-right:1px solid rgba(255,255,255,.08);
}
#confianca .carrossel-item img {
  height:44px;
  max-width:150px;
  /* Logos sobre fundo preto: branco semi-transparente */
  filter:brightness(0) invert(1) opacity(.5);
}
#confianca .carrossel-item:hover img {
  /* Hover: amarelo #FFC107 da paleta */
  filter:
    brightness(0)
    saturate(100%)
    invert(82%)
    sepia(60%)
    saturate(700%)
    hue-rotate(5deg)
    brightness(1.05)
    opacity(1);
}

@media (max-width:600px) {
  .conf-badge    { flex-direction:column; align-items:flex-start; gap:2px; }
  .conf-anos     { font-size:34px; }
  .conf-divider  { display:none; }
  .conf-topo-inner { gap:16px; }
  .conf-frase    { font-size:12px; }
}

/* ══ LISTA DENTRO DO CARD SERVIÇO ══════════ */
.serv-lista {
  list-style:none; margin:0 0 18px; padding:0;
  display:flex; flex-direction:column; gap:6px;
}
.serv-lista li {
  display:flex; align-items:center; gap:7px;
  font-size:12px; color:var(--cinza);
}
.serv-lista li svg { color:var(--am); flex-shrink:0; }

/* ══ COMO FUNCIONA ══════════════════════════ */
#processo { padding:var(--sec-py) 0; }

.proc-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:16px; position:relative;
}

/* Linha conectora entre os passos */
.proc-grid::before {
  content:'';
  position:absolute;
  top:36px; left:calc(12.5% + 20px); right:calc(12.5% + 20px);
  height:1px;
  background:repeating-linear-gradient(90deg, var(--am) 0, var(--am) 6px, transparent 6px, transparent 14px);
  z-index:0;
}

.proc-item {
  position:relative; z-index:1;
  background:var(--bco); border:1px solid #e8e8e8;
  border-radius:var(--r); padding:24px 18px;
  text-align:center; transition:var(--t);
}
.proc-item:hover { box-shadow:0 8px 24px rgba(0,0,0,.08); transform:translateY(-3px); }

.proc-num {
  display:inline-block;
  font-size:11px; font-weight:700;
  color:var(--am); letter-spacing:1px;
  background:rgba(255,193,7,.1);
  padding:3px 8px; border-radius:3px;
  margin-bottom:12px;
}
.proc-ic {
  width:48px; height:48px;
  background:rgba(255,193,7,.08); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 12px;
}
.proc-ic svg { color:var(--am); }
.proc-item h3 { font-size:13px; font-weight:600; margin-bottom:7px; }
.proc-item p  { font-size:12px; color:var(--cinza); line-height:1.65; }

/* ══ DEPOIMENTOS — estrelas no topo ════════ */
.dep-estrelas {
  color:var(--am); font-size:14px;
  letter-spacing:2px; margin-bottom:10px;
}

/* ══ CONTATOS DIRETOS NO FORMULÁRIO ════════ */
.form-contatos {
  margin-top:24px; padding-top:20px;
  border-top:1px solid #eeeeee;
  display:flex; flex-direction:column; gap:10px;
}
.form-contatos a {
  display:inline-flex; align-items:center; gap:9px;
  font-size:12.5px; color:var(--preto);
  text-decoration:none; transition:var(--t);
}
.form-contatos a svg { color:var(--am); flex-shrink:0; }
.form-contatos a:hover { color:var(--am); }

/* ══ ACESSOS RÁPIDOS — label alinhado ══════ */
.aces-topo { margin-bottom:20px; text-align:center; }

/* ══ RESPONSIVO NOVOS ELEMENTOS ════════════ */
@media (max-width:900px) {
  .proc-grid   { grid-template-columns:1fr 1fr; }
  .proc-grid::before { display:none; }
}
@media (max-width:600px) {
  .proc-grid   { grid-template-columns:1fr 1fr; }
  .hero-btns   { flex-direction:column; align-items:flex-start; }
}

/* ══ LOGO REAL NO HERO ══════════════════════ */
.hero-logo-img {
  width:220px;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 2px 10px rgba(0,0,0,.5));
  display:block;
}
@media (orientation:landscape) {
  .hero-logo-img { width:120px !important; height:auto !important; }
}

/* ══ CARROSSEL DE CLIENTES ══════════════════
   Logos monocromáticas: neutro por padrão,
   colorize para amarelo #FFC107 no hover
   via sepia+saturate+hue-rotate trick
═══════════════════════════════════════════ */
.carrossel-outer {
  overflow:hidden;
  position:relative;
  padding:4px 0;
  mask-image:linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);
  -webkit-mask-image:linear-gradient(90deg, transparent 0%, black 10%, black 90%, transparent 100%);
}

.carrossel-track {
  display:flex;
  align-items:center;
  gap:0;
  width:max-content;
  animation:carrossel-scroll 32s linear infinite;
}

/* Pausar ao passar o mouse em qualquer item */
.carrossel-outer:hover .carrossel-track {
  animation-play-state:paused;
}

.carrossel-item {
  flex-shrink:0;
  padding:16px 40px;
  border-right:1px solid #eeeeee;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}

.carrossel-item:last-child { border-right:none; }

.carrossel-item img {
  height:38px;
  width:auto;
  max-width:130px;
  object-fit:contain;
  /* Padrão: grayscale discreto */
  filter:grayscale(100%) opacity(.5) brightness(0.85);
  transition:filter .35s ease, transform .35s ease;
  display:block;
}

/* Hover: cor original da logo, totalmente opaco */
.carrossel-item:hover img {
  filter:grayscale(0%) opacity(1) brightness(1);
  transform:scale(1.06);
}

/* Landscape: logos maiores */
@media (orientation:landscape) {
  .carrossel-item img {
    height:48px;
    max-width:160px;
  }
  .carrossel-item {
    padding:14px 44px;
  }
}

@keyframes carrossel-scroll {
  0%   { transform:translateX(0); }
  100% { transform:translateX(calc(-100% / 3)); }
}

/* btn-dep-depoimento definido no sistema de botões acima */

/* ── Símbolo PNG na navbar e footer ─────── */
.nav-logo img {
  object-fit:contain;
  display:block;
  flex-shrink:0;
  /* Leve drop-shadow para destacar sobre fundos escuros */
  filter:drop-shadow(0 1px 4px rgba(0,0,0,.3));
}

/* ── Overlay por trás do menu deslizante ──
   Só em landscape (portrait: sem overlay, menu desliza sobre tudo) */
.nav-overlay {
  display:none;
  position:fixed;
  top:0; left:0; right:0;
  height:100dvh;
  background:rgba(0,0,0,.6);
  z-index:1000;
  opacity:0;
  transition:opacity .35s ease;
  touch-action:none;
  pointer-events:none;
}
.nav-overlay.on {
  display:block;
  opacity:1;
  pointer-events:auto;
}
/* Portrait: overlay invisível e não bloqueia */
@media (orientation:portrait) {
  .nav-overlay,
  .nav-overlay.on {
    display:none !important;
    pointer-events:none !important;
  }
}

/* ── Pixels decorativos no footer ── */
.foot-pixels {
  display:grid !important;
  grid-template-columns:repeat(3,9px);
  grid-template-rows:repeat(3,9px);
  gap:2px;
  flex-shrink:0;
  align-self:center;
}
.fp { width:9px; height:9px; border-radius:1px; }
.fp.a { background:var(--am); }
.fp.e { background:rgba(255,255,255,.35); }
.fp.v { background:transparent; }

/* ══ FORMULÁRIO 2 ETAPAS ═══════════════════ */

/* Indicador de etapas */
.form-steps {
  display:flex; align-items:center; gap:0;
  margin-bottom:24px; padding-bottom:20px;
  border-bottom:1px solid #f0f0f0;
}
.form-step-item {
  display:flex; align-items:center; gap:8px;
  flex:1;
}
.form-step-item:last-child { justify-content:flex-end; }
.step-num {
  width:26px; height:26px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; font-weight:700;
  background:#e8e8e8; color:var(--cinza);
  transition:var(--t); flex-shrink:0;
}
.form-step-item.active .step-num {
  background:var(--am); color:var(--preto);
}
.form-step-item.done .step-num {
  background:var(--preto); color:var(--bco);
}
.form-step-item span {
  font-size:12px; font-weight:600;
  color:var(--cinza); transition:var(--t);
}
.form-step-item.active span { color:var(--preto); }
.step-line {
  flex:1; height:1px; background:#e8e8e8;
  margin:0 12px;
}

/* Anti-spam */
.antispam-box {
  background:#fafafa; border-radius:var(--r);
  padding:12px 14px;
  border:1px solid #eee;
}
.antispam-box label {
  display:flex; align-items:center; gap:6px;
  font-size:12px; color:var(--cinza);
  margin-bottom:8px;
}
.antispam-box label svg { color:var(--am); flex-shrink:0; }
.antispam-box label strong { color:var(--preto); }

/* Aviso LGPD */
.lgpd-notice {
  display:flex; align-items:flex-start; gap:10px;
  background:rgba(255,193,7,.06);
  border:1px solid rgba(255,193,7,.2);
  border-radius:var(--r);
  padding:12px 14px;
  margin:14px 0 10px;
}
.lgpd-notice svg { color:var(--am); flex-shrink:0; margin-top:1px; }
.lgpd-notice p {
  font-size:11.5px; line-height:1.6; color:var(--cinza);
}
.lgpd-notice a {
  color:var(--am); font-weight:600; text-decoration:none;
}
.lgpd-notice a:hover { text-decoration:underline; }
