/* ============================================
   SOLAR 4.0 — Folha de estilo OFICIAL
   Identidade da marca (manual Lais Sindorf, 2023)
   Principal: verde #00A335 · Apoio: azul #095174,
   verde escuro #046223, amarelo #F2CB36, preto, branco
   Fontes: Montserrat (display/marca) + DM Sans (corpo)
   ============================================ */

:root{
  --verde:        #00A335;  /* PRINCIPAL */
  --verde-esc:    #046223;  /* verde escuro */
  --azul:         #095174;  /* confiança */
  --amarelo:      #F2CB36;  /* sol */
  --preto:        #0A0A0A;
  --branco:       #FFFFFF;

  --fundo:        #FFFFFF;
  --fundo-alt:    #F4F6F4;  /* cinza-esverdeado muito claro */
  --tinta:        #16201A;  /* texto corpo */
  --tinta-suave:  #4C5A52;
  --linha:        #E2E7E2;

  --fonte-display:'Montserrat', system-ui, sans-serif;
  --fonte-corpo:  'DM Sans', system-ui, -apple-system, sans-serif;

  --max: 1180px;
  --raio: 14px;
  --sombra: 0 12px 40px rgba(10,10,10,.10);
  --sombra-verde: 0 10px 30px rgba(0,163,53,.28);
  --petroleo: #0a3d2e;
  --areia: #F7F3EC;
  --sol-claro: #FFE08A;
  --sol: #F2CB36;
  --areia-fundo: #FBF7EF;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--fonte-corpo);
  color:var(--tinta);
  background:var(--fundo);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:var(--verde-esc); text-decoration:none; }
a:hover{ color:var(--verde); }
.wrap{ max-width:var(--max); margin:0 auto; padding:0 24px; }

/* ---------- Tipografia ---------- */
h1,h2,h3,h4{ font-family:var(--fonte-display); color:var(--preto); line-height:1.14; font-weight:700; letter-spacing:.005em; }
h1{ font-size:clamp(2.1rem, 5vw, 3.3rem); }
h2{ font-size:clamp(1.55rem, 3.5vw, 2.25rem); margin-bottom:.6em; }
h3{ font-size:1.2rem; margin-bottom:.4em; font-weight:700; }
p{ margin-bottom:1rem; max-width:65ch; }
.eyebrow{
  font-family:var(--fonte-display); font-weight:700; font-size:.92rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--verde);
  display:inline-block; margin-bottom:.8rem;
}

/* ---------- Topo ---------- */
header.topo{
  position:sticky; top:0; z-index:50;
  background:rgba(255,255,255,.95);
  backdrop-filter:saturate(150%) blur(10px);
  border-bottom:1px solid var(--linha);
}
.topo .wrap{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.marca-img{ height:38px; width:auto; flex-shrink:0; }
.marca-grupo a{ display:inline-flex; flex-shrink:0; }
.marca-grupo{ display:flex; align-items:center; gap:14px; margin-right:24px; flex-shrink:0; }
.marca-sep{ width:1px; height:30px; background:var(--linha); display:inline-block; }
.marca-intelbras{ height:20px; width:auto; }
@media (max-width:340px){ .marca-sep, .marca-intelbras{ display:none; } }
.nav{ display:flex; gap:1.7rem; align-items:center; }
.nav a{ font-family:var(--fonte-display); font-weight:600; font-size:.95rem; color:var(--tinta); white-space:nowrap; }
.nav a:hover{ color:var(--verde); }
.btn-topo{
  background:var(--verde); color:var(--branco)!important;
  padding:.6rem 1.3rem; border-radius:999px; font-weight:700; font-size:.92rem;
  text-align:center; display:inline-block; white-space:nowrap;
}
.btn-topo:hover{ background:var(--verde-esc); color:var(--branco)!important; }
.menu-toggle{ display:none; background:none; border:0; font-size:1.6rem; color:var(--preto); cursor:pointer; }

/* ---------- Botões ---------- */
.btn{
  display:inline-block; background:var(--verde); color:var(--branco);
  padding:.95rem 1.9rem; border-radius:999px; font-family:var(--fonte-display);
  font-weight:700; font-size:1rem; border:2px solid var(--verde); transition:.2s; cursor:pointer;
  box-shadow:var(--sombra-verde);
}
.btn:hover{ background:var(--verde-esc); border-color:var(--verde-esc); color:var(--branco); transform:translateY(-2px); }
.btn-linha{ background:transparent; color:var(--preto); border:2px solid var(--preto); box-shadow:none; }
.btn-linha:hover{ background:var(--preto); color:var(--branco); }
.btn-claro{ background:var(--branco); color:var(--verde-esc); border-color:var(--branco); }
.btn-claro:hover{ background:var(--amarelo); border-color:var(--amarelo); color:var(--preto); }

/* ---------- Hero ---------- */
.hero{
  position:relative; overflow:hidden; color:var(--branco);
  background:
    radial-gradient(900px 420px at 78% 8%, rgba(0,163,53,.30), transparent 62%),
    radial-gradient(700px 380px at 12% 100%, rgba(9,81,116,.35), transparent 60%),
    var(--preto);
  padding:clamp(3rem,7vw,5.5rem) 0 clamp(3rem,6vw,4.5rem);
}
.hero h1{ color:var(--branco); margin-bottom:1.2rem; text-shadow:0 0 1px rgba(0,0,0,.18); }
.hero .grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:3rem; align-items:center; }
.hero .lead{ font-size:1.18rem; color:rgba(255,255,255,.82); margin-bottom:1.8rem; }
.hero-cta{ display:flex; gap:1rem; flex-wrap:wrap; align-items:center; }
.hero-prova{ margin-top:1.8rem; display:flex; align-items:center; gap:.7rem; color:rgba(255,255,255,.82); font-size:.95rem; }
.estrelas{ color:var(--amarelo); letter-spacing:.1em; }
.hero .breadcrumb a{ color:rgba(255,255,255,.6); }
.hero .breadcrumb{ color:rgba(255,255,255,.6); }

/* arte do sol/esfera no hero */
.sol-arte{
  position:relative; aspect-ratio:1; max-width:400px; margin-left:auto;
  border-radius:50%;
  background:radial-gradient(circle at 50% 45%, #36c45f, var(--verde) 58%, var(--verde-esc) 100%);
  box-shadow:0 30px 80px rgba(0,163,53,.40), inset 0 -12px 50px rgba(0,0,0,.18);
  display:flex; align-items:center; justify-content:center;
}
.sol-arte .nucleo{ text-align:center; color:var(--branco); }
.sol-arte .nucleo .num{ font-family:var(--fonte-display); font-size:3.6rem; font-weight:800; line-height:1; }
.sol-arte .nucleo .lbl{ font-weight:600; font-size:1rem; margin-top:.3rem; }

/* faixa de cidades */
.faixa-cidades{ background:var(--verde-esc); color:var(--branco); padding:1.1rem 0; }
.faixa-cidades .wrap{ display:flex; gap:.55rem; flex-wrap:wrap; justify-content:center; font-size:.92rem; align-items:center; }
.faixa-cidades span{ opacity:.8; }
.faixa-cidades b{ color:var(--amarelo); font-weight:700; }

/* ---------- Seções ---------- */
section{ padding:clamp(3rem,6vw,5rem) 0; }
.sec-alt{ background:var(--fundo-alt); }
.sec-escura{ background:var(--preto); color:#E9EDE9; }
.sec-escura h2,.sec-escura h3{ color:var(--branco); text-shadow:0 0 1px rgba(0,0,0,.18); }
.sec-escura p{ color:rgba(255,255,255,.8); }
.centro{ text-align:center; }
.centro p{ margin-left:auto; margin-right:auto; }

/* ---------- Cards ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.card{ background:var(--branco); border:1px solid var(--linha); border-radius:var(--raio); padding:1.8rem; transition:.2s; }
a.card{ display:block; text-decoration:none; color:inherit; }
a.card h3{ color:var(--tinta); }
.card:hover{ transform:translateY(-4px); box-shadow:var(--sombra); border-color:var(--verde); }
.card .ico{ width:54px; height:54px; border-radius:14px; background:rgba(0,163,53,.12); display:flex; align-items:center; justify-content:center; font-size:1.7rem; margin-bottom:1rem; }

/* passos */
.passos{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.passo .n{ font-family:var(--fonte-display); font-size:2.6rem; font-weight:800; color:var(--verde); line-height:1; }
.passo h3{ margin-top:.5rem; }

/* stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; margin-top:2.5rem; }
.stat{ text-align:center; }
.stat .num{ font-family:var(--fonte-display); font-size:2.8rem; font-weight:800; color:var(--amarelo); }
.stat .lbl{ font-size:.95rem; opacity:.82; }

/* FAQ */
.faq{ max-width:800px; margin:2.5rem auto 0; }
.faq details{ background:var(--branco); border:1px solid var(--linha); border-radius:12px; margin-bottom:.9rem; padding:0 1.4rem; transition:.2s; }
.faq details[open]{ border-color:var(--verde); box-shadow:var(--sombra); }
.faq summary{ cursor:pointer; padding:1.1rem 0; font-family:var(--fonte-display); font-weight:700; font-size:1.08rem; color:var(--preto); list-style:none; display:flex; justify-content:space-between; gap:1rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:'+'; color:var(--verde); font-size:1.5rem; font-weight:400; }
.faq details[open] summary::after{ content:'–'; }
.faq details p{ padding-bottom:1.2rem; margin-bottom:0; }

/* CTA final */
.cta-final{ background:linear-gradient(135deg, var(--verde), var(--verde-esc)); border-radius:var(--raio); padding:clamp(2.5rem,5vw,4rem); text-align:center; color:var(--branco); }
.cta-final h2{ color:var(--branco); }
.cta-final p{ color:rgba(255,255,255,.9); }
.cta-final .eyebrow{ color:var(--amarelo); }
.cta-final .btn{ background:var(--branco); color:var(--verde-esc); border-color:var(--branco); margin-top:1rem; box-shadow:0 10px 30px rgba(0,0,0,.15); }
.cta-final .btn:hover{ background:var(--amarelo); border-color:var(--amarelo); color:var(--preto); }

/* depoimentos */
.depo{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.depo .item{ background:var(--branco); border:1px solid var(--linha); border-radius:var(--raio); padding:1.6rem; }
.depo .estrelas{ margin-bottom:.6rem; }
.depo .nome{ font-family:var(--fonte-display); font-weight:700; color:var(--preto); margin-top:.8rem; }
.depo .cidade{ font-size:.88rem; color:var(--tinta-suave); }

/* conteudo (cidade/blog) */
.conteudo{ max-width:760px; }
.conteudo h2{ margin-top:2.2rem; }
.conteudo h3{ margin-top:1.6rem; }
.conteudo ul{ margin:0 0 1rem 1.4rem; }
.conteudo li{ margin-bottom:.4rem; }
.breadcrumb{ font-size:.85rem; color:var(--tinta-suave); padding:1.2rem 0 0; }
.breadcrumb a{ color:var(--tinta-suave); }

/* lista de cidades */
.cidades-lista{ display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.5rem; }
.cidades-lista a{ background:var(--branco); border:1px solid var(--linha); border-radius:999px; padding:.45rem 1rem; font-family:var(--fonte-display); font-size:.9rem; font-weight:600; color:var(--preto); }
.cidades-lista a:hover{ background:var(--verde); border-color:var(--verde); color:var(--branco); }

/* placeholders de imagem (para o usuario inserir fotos) */
.foto-ph{ background:linear-gradient(135deg,#e9ede9,#dfe6df); border:2px dashed #b9c4ba; border-radius:var(--raio); display:flex; align-items:center; justify-content:center; color:#7d8a80; font-size:.9rem; text-align:center; padding:2rem; min-height:240px; font-family:var(--fonte-display); font-weight:600; }

/* blog cards */
.posts{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.5rem; }
.post-card{ background:var(--branco); border:1px solid var(--linha); border-radius:var(--raio); overflow:hidden; transition:.2s; }
.post-card:hover{ transform:translateY(-4px); box-shadow:var(--sombra); }
.post-card .corpo{ padding:1.4rem; }
.post-card .tag{ font-family:var(--fonte-display); font-size:.72rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--verde); }
.post-card h3{ margin:.4rem 0; font-size:1.12rem; }

/* rodapé */
footer.rodape{ background:var(--preto); color:rgba(255,255,255,.78); padding:3.5rem 0 2rem; }
footer.rodape h4, footer.rodape .rodape-titulo{ color:var(--branco); font-family:var(--fonte-display); font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1rem; font-weight:700; display:block; margin-top:0; }
.rodape-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:2rem; }
.rodape a{ color:rgba(255,255,255,.78); display:block; margin-bottom:.5rem; font-size:.95rem; }
.rodape a:hover{ color:var(--amarelo); }
.rodape-logo{ height:38px; width:auto; }
.rodape-marcas{ display:flex; align-items:center; gap:14px; margin-bottom:1rem; }
.rodape-sep{ width:1px; height:30px; background:rgba(255,255,255,.25); display:inline-block; }
.rodape-intelbras{ height:20px; width:auto; opacity:.95; }
.rodape-parceria{ margin-top:1.4rem; }
.rodape-parceria-lbl{ display:block; font-family:var(--fonte-display); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:.5rem; }
.rodape-base{ border-top:1px solid rgba(255,255,255,.12); margin-top:2.5rem; padding-top:1.5rem; font-size:.85rem; opacity:.65; display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; }

/* WhatsApp flutuante */
.zap{ position:fixed; bottom:24px; right:24px; z-index:60; background:#25D366; color:#fff; width:60px; height:60px; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 8px 30px rgba(37,211,102,.45); transition:.2s; }
.zap svg{ width:34px; height:34px; }
.zap:hover{ transform:scale(1.08); color:#fff; }

/* responsivo */
@media (max-width:900px){
  .hero .grid{ grid-template-columns:1fr; }
  .sol-arte{ margin:0 auto; max-width:280px; }
  .cards,.passos,.depo,.posts{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .rodape-grid{ grid-template-columns:1fr 1fr; }
  .rodape-marcas{ flex-direction:column; align-items:flex-start; gap:12px; }
  .rodape-sep{ display:none; }
  .nav{ display:none; }
  .nav.aberto{ display:flex; flex-direction:column; position:absolute; top:74px; left:0; right:0; background:var(--branco); padding:1.5rem 24px; border-bottom:1px solid var(--linha); gap:1rem; }
  .menu-toggle{ display:block; }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; scroll-behavior:auto!important; } }
a:focus-visible, button:focus-visible, summary:focus-visible{ outline:3px solid var(--verde); outline-offset:2px; border-radius:4px; }

/* ---------- Simulador de economia ---------- */
.simulador{ background:linear-gradient(135deg,var(--preto),#15241b); color:var(--branco); border-radius:var(--raio); padding:clamp(2rem,4vw,3rem); display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; }
.simulador h2{ color:var(--branco); }
.simulador .eyebrow{ color:var(--amarelo); }
.simulador p{ color:rgba(255,255,255,.8); }
.sim-campo{ margin-bottom:1.2rem; }
.sim-campo label{ display:block; font-family:var(--fonte-display); font-weight:600; font-size:.9rem; margin-bottom:.5rem; color:rgba(255,255,255,.9); }
.sim-campo select, .sim-campo input{ width:100%; padding:.85rem 1rem; border-radius:10px; border:2px solid rgba(255,255,255,.15); background:rgba(255,255,255,.06); color:var(--branco); font-family:var(--fonte-corpo); font-size:1rem; }
.sim-campo select option{ background:var(--preto); color:var(--branco); }
.sim-campo select:focus, .sim-campo input:focus{ outline:none; border-color:var(--verde); }
.sim-resultado{ background:rgba(0,163,53,.12); border:1px solid var(--verde); border-radius:14px; padding:1.6rem; text-align:center; }
.sim-resultado .valor{ font-family:var(--fonte-display); font-size:2.6rem; font-weight:800; color:var(--amarelo); line-height:1; }
.sim-resultado .sub{ font-size:.92rem; color:rgba(255,255,255,.85); margin-top:.4rem; }
.sim-resultado .extra{ font-size:.85rem; color:rgba(255,255,255,.7); margin-top:.8rem; }
.sim-painel{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:14px; padding:1.8rem; }
@media (max-width:900px){ .simulador{ grid-template-columns:1fr; } }

/* ---------- Hero com foto + selo ---------- */
.hero-foto{ position:relative; border-radius:var(--raio); overflow:hidden; box-shadow:0 30px 70px rgba(0,0,0,.4); aspect-ratio:16/11; }
.hero-foto img{ width:100%; height:100%; object-fit:cover; }
.hero-foto.sem-foto{ background:radial-gradient(circle at 50% 45%, #36c45f, var(--verde) 58%, var(--verde-esc) 100%); aspect-ratio:16/11; }
.selo-90{ position:absolute; bottom:18px; right:18px; background:var(--verde); color:#fff; border-radius:16px; padding:1rem 1.3rem; text-align:center; box-shadow:0 12px 30px rgba(0,0,0,.35); }
.selo-90 .num{ display:block; font-family:var(--fonte-display); font-size:2.4rem; font-weight:800; line-height:1; }
.selo-90 .lbl{ display:block; font-size:.8rem; margin-top:.2rem; line-height:1.25; }
.hero-foto.sem-foto .selo-90{ background:rgba(0,0,0,.35); backdrop-filter:blur(4px); }
@media (max-width:900px){ .hero-foto{ max-width:420px; margin:0 auto; } }

/* ---------- Formulário de orçamento ---------- */
.form-orc{ background:var(--branco); border:1px solid var(--linha); border-radius:var(--raio); padding:clamp(1.8rem,4vw,2.6rem); box-shadow:var(--sombra); }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.form-campo{ display:flex; flex-direction:column; }
.form-campo.full{ grid-column:1 / -1; }
.form-campo label{ font-family:var(--fonte-display); font-weight:600; font-size:.82rem; color:var(--tinta); margin-bottom:.35rem; }
.form-campo input, .form-campo select, .form-campo textarea{ padding:.8rem .9rem; border:2px solid var(--linha); border-radius:10px; font-family:var(--fonte-corpo); font-size:.98rem; color:var(--tinta); background:var(--branco); transition:.15s; }
.form-campo input:focus, .form-campo select:focus, .form-campo textarea:focus{ outline:none; border-color:var(--verde); }
.form-campo textarea{ resize:vertical; min-height:70px; }
.form-orc .btn{ width:100%; margin-top:.4rem; }
.form-nota{ font-size:.8rem; color:var(--tinta-suave); margin-top:.8rem; text-align:center; }
@media (max-width:600px){ .form-grid{ grid-template-columns:1fr; } }

/* ---------- Seção Nossa Empresa / Sede ---------- */
.empresa-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; }
.empresa-foto{ width:100%; height:auto; aspect-ratio:16/9; object-fit:cover; border-radius:var(--raio); box-shadow:0 25px 60px rgba(0,0,0,.25); display:block; }
@media (max-width:900px){ .empresa-grid{ grid-template-columns:1fr; } }

/* FAQ por cidade (long-tail SEO) */
.faq-cidade{margin-top:1rem}
.faq-cidade h3{font-size:1.08rem;margin:1.4rem 0 .4rem;color:var(--petroleo,#0b4f4a)}
.faq-cidade p{margin:0 0 .6rem;color:#444}

/* ===== Carrossel de avaliações reais (Google) ===== */
.aval-carrossel-wrap{ position:relative; margin-top:1.5rem; }
.aval-carrossel{ display:flex; gap:1.2rem; overflow-x:auto; scroll-behavior:smooth; scroll-snap-type:x mandatory; padding:.5rem .2rem 1.5rem; -webkit-overflow-scrolling:touch; }
.aval-carrossel::-webkit-scrollbar{ height:8px; }
.aval-carrossel::-webkit-scrollbar-thumb{ background:var(--linha); border-radius:4px; }
.aval-card{ scroll-snap-align:start; flex:0 0 330px; background:var(--branco); border:1px solid var(--linha); border-radius:16px; padding:1.6rem; box-shadow:0 8px 30px rgba(0,0,0,.06); display:flex; flex-direction:column; text-align:left; }
.aval-topo{ display:flex; align-items:center; gap:.8rem; margin-bottom:.5rem; }
.aval-avatar{ width:46px; height:46px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:var(--fonte-display); font-weight:700; color:#fff; font-size:1.2rem; flex-shrink:0; }
.aval-nome{ font-weight:700; font-size:.96rem; line-height:1.2; color:var(--tinta); }
.aval-meta{ font-size:.78rem; color:var(--tinta-suave); }
.aval-estrelas{ color:#FBBC04; font-size:1rem; margin:.3rem 0 .6rem; letter-spacing:1px; }
.aval-texto{ font-size:.9rem; line-height:1.55; color:#2a342d; flex:1; }
.aval-google{ display:flex; align-items:center; gap:.4rem; margin-top:1rem; font-size:.76rem; color:var(--tinta-suave); }
.aval-gicon{ width:15px; height:15px; }
.aval-nav{ display:flex; gap:.6rem; justify-content:center; margin-top:.3rem; }
.aval-nav button{ width:44px; height:44px; border-radius:50%; border:1px solid var(--linha); background:#fff; cursor:pointer; font-size:1.4rem; color:var(--verde); transition:.2s; display:flex; align-items:center; justify-content:center; line-height:1; }
.aval-nav button:hover{ background:var(--verde); color:#fff; border-color:var(--verde); }
@media (max-width:560px){ .aval-card{ flex:0 0 82%; } }
