/* =========================== TOKENS / BASE =========================== */
:root{
  /* Marca */
  --brand-orange: #ff6434;  /* primária */
  --brand-blue:   #085cb4;  /* destaque/terciária */
  --bg:           #ffffff;  /* fundo branco */
  --bg-2:         #f6f7fb;  /* cinza clarinho (uso pontual) */
  --card:         #ffffff;  /* cartões brancos */
  --ink:          #0f1222;  /* texto escuro geral */
  --muted:        #5a5e6d;
  --line:         #eaedf3;
  --whatsapp:     #25D366;

  /* Padrão único de padding vertical para seções */
  --section-pad-y: clamp(40px, 9vw, 80px);

  /* Escala 8pt */
  --s-2:12px; --s-3:16px; --s-4:20px; --s-5:24px; --s-6:28px;
  --s-8:40px; --s-9:64px; --s-10:96px; --s-11:120px;

  /* Raios/Sombras */
  --r-lg:18px; --r-xl:22px;
  --shadow-0:0 1px 2px rgba(13,17,28,.08);
  --shadow-1:0 8px 24px rgba(13,17,28,.10);
  --shadow-2:0 24px 60px rgba(13,17,28,.12);

  /* Tipografia fluida */
  --h1: clamp(36px,5.6vw,64px);
  --h2: clamp(26px,3.8vw,44px);
  --body: clamp(15px,1.45vw,18px);

  /* Gradientes */
  --grad-orange: linear-gradient(90deg,#ff7a55 0%, #ff6434 50%, #ff4e18 100%);
  --grad-hero:
    radial-gradient(900px 480px at 15% 10%, rgba(255,255,255,.18), transparent 60%),
    radial-gradient(720px 420px at 85% 20%, rgba(255,255,255,.12), transparent 60%),
    linear-gradient(180deg,#ff6d41 0%, #ff6434 100%); /* hero laranja */
}

/* Reset/estrutura */
*{ box-sizing:border-box }
body{
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg); color:var(--ink);
  margin:0; font-size:var(--body); line-height:1.6;
}
.container{ max-width:1140px }

/* =============================== HERO =============================== */
.hero-edge{ width:100vw; margin-left:calc(-50vw + 50%) }
.hero{ position:relative; overflow:hidden; isolation:isolate }

/* Hero ocupa a tela toda no início */
.hero--institutional{
  background: var(--grad-hero);
  color:#fff;
  min-height: 80svh;                   /* ocupa 100% da viewport */
  display:flex; align-items:center;
  text-align:center;
  padding: var(--section-pad-y) 0;      /* mantém padrão de padding */
}
@media (max-width:768px){
  .hero--institutional{ min-height:100svh }
}

/* Grid leve e glow do hero */
.hero--institutional::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    linear-gradient(transparent 95%, rgba(255,255,255,.15) 100%) 0 0/100% 28px,
    linear-gradient(90deg, transparent 95%, rgba(255,255,255,.12) 100%) 0 0/28px 100%;
  mask-image: radial-gradient(1000px 600px at 50% -10%, #000 50%, transparent 60%);
  opacity:.25; pointer-events:none;
}
.hero--institutional::after{
  content:"";
  position:absolute; width:60vmax; height:60vmax; left:50%; top:15%;
  transform:translate(-50%,-50%);
  background: radial-gradient(closest-side, rgba(255,255,255,.24), transparent 75%);
  filter: blur(40px);
  animation: heroGlow 8s ease-in-out infinite alternate;
  pointer-events:none; opacity:.45;
}
@keyframes heroGlow{
  0%{ transform:translate(-52%,-48%) scale(1); opacity:.4 }
  100%{ transform:translate(-48%,-52%) scale(1.08); opacity:.55 }
}

/* Shapes decorativos do hero */
.hero-shape{ position:absolute; left:0; width:100%; fill:rgba(255,255,255,.20); pointer-events:none }
.hero-shape--top{ top:0; transform:translateY(-55%) }
.hero-shape--bottom{ bottom:0; transform:translateY(55%) }

/* Conteúdo do hero */
.hero-inner{ max-width:1000px; margin:0 auto }
.hero-logo{ max-width:160px; height:auto; margin-bottom:18px; filter:drop-shadow(0 1px 2px rgba(0,0,0,.15)) }
.eyebrow{ font-weight:700; opacity:.95; margin:0 0 10px; letter-spacing:.02em; color:#fff }
.hero-title{ font-weight:800; font-size:var(--h1); line-height:1.05; letter-spacing:-.012em; margin:0 0 16px; color:#fff }
.hero-title .hero-highlight{ color: var(--brand-blue) !important }
.hero-sub{ color:#fff; opacity:.95; max-width:780px; margin:0 auto 26px }
.hero-ctas{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin-bottom:16px }

/* Remover badges do hero */
.hero-badges{ display:none !important }

/* Botões globais */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  min-height:52px; border-radius:999px; font-weight:800; border:0; text-decoration:none; letter-spacing:.01em
}
/* Primário (laranja) */
.btn-urban-blue, .btn-primary{
  background: var(--grad-orange); color:#fff;
  transition:transform .18s ease, box-shadow .25s ease, filter .25s;
  box-shadow:0 0 0 rgba(0,0,0,0);                 /* sem sombras globais por padrão */
}
.btn-urban-blue:hover, .btn-primary:hover{ transform:translateY(-2px) }
/* Secundário (ghost claro) */
.btn-ghost-light, .btn-outline-light{
  background:rgba(255, 255, 255, 0.96); color:#085cb4; border:1.5px solid rgba(255,255,255,.66);
  backdrop-filter:blur(3px);
  transition:background .2s, color .2s, transform .18s, box-shadow .25s;
}
.btn-ghost-light:hover, .btn-outline-light:hover{
  background:#fff; color:var(--brand-blue); transform:translateY(-2px)
}

/* WhatsApp (verde) — sem sombra */
.hero-ctas a[href*="wa.me/"],
a.btn-whatsapp{
  background: linear-gradient(90deg,#35e07a, #25D366);
  color:#fff !important;
  border:0;
  box-shadow:none !important;             /* ✂ sombra removida */
}
.hero-ctas a[href*="wa.me/"]:hover,
a.btn-whatsapp:hover{
  transform:translateY(-2px);
  box-shadow:none !important;
}


/* ============================== SERVIÇOS =============================== */
/* Sem background colorido, menos afastado e alinhado ao padrão */
.bg-services{
  background:#f7f7f7;                         /* remove gradiente laranja */
  color:var(--ink);
  padding-top: 20px;   
  padding-bottom: 60px; 
}
.section-title{ font-weight:800; font-size:var(--h2); color:var(--ink);padding-bottom: 30px ;}
/* .solutions-subtitle{ color:var(--muted); margin: 0 auto var(--s-6); max-width:760px } */

/* Cards */
.services-grid > [class*="col-"]{ display:flex }
.service-card{
  display:flex; flex-direction:column; width:100%;
  background:var(--card); border:1px solid var(--line); border-radius:var(--r-xl); overflow:hidden;
  box-shadow:var(--shadow-0);
  transition:transform .22s, box-shadow .22s, border-color .22s;
}

.service-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-2); border-color:#e1e6f0 }
.service-media img{ width:100%; height:180px; object-fit:cover; display:block }
.service-body{ padding:var(--s-4); display:flex; flex-direction:column; gap:8px; flex:1 }
.service-title{ font-size:1.08rem; font-weight:700; margin:0px; color:var(--ink) }
.service-desc{ font-size:.92rem; color:var(--muted); margin:0 }
.service-points{ font-size:.86rem; margin:4px 0 var(--s-2); padding-left:16px }
.service-points li{ margin:4px 0; list-style:"✓  "; color:#3B3F50 }

/* CTA dos cards — menos ambíguo: outline AZUL e fill no hover */
.service-cta{
  margin-top:auto;
  font-size:.92rem;
  display:flex;                 /* mantém flex */
  justify-content:center;       /* centraliza o conteúdo */
  align-items:center;
  gap:8px; 
  padding:10px 16px;
  border-radius:999px; 
  font-weight:700; 
  text-decoration:none;
  border:2px solid var(--brand-blue); 
  color:var(--brand-blue);
  transition:background .18s, color .18s, transform .18s, box-shadow .2s;
  width: 100%;                  /* agora ocupa o card todo */
  box-sizing: border-box;
}

.service-cta:hover{ 
  background:var(--brand-blue); 
  color:#fff; 
  transform:translateY(-1px) 
}
.service-cta:hover{ background:var(--brand-blue); color:#fff; transform:translateY(-1px) }


@media (min-width:992px){ .services-grid .col-lg-3{ flex:0 0 25%; max-width:25% } }
@media (max-width:991px){ .services-grid .col-md-6{ flex:0 0 50%; max-width:50% } .service-media img{ height:160px } }
@media (max-width:575px){ .services-grid > [class*="col-"]{ flex:0 0 100%; max-width:100% } .service-media img{ height:150px } }

/* ============================= DEPOIMENTOS ============================= */

.testimonials .section-title{
  font-weight:800; font-size:var(--h2); text-align:center; margin:0 0 40px; color:var(--ink)
}

/* Seção Depoimentos (prints) */
.testimonials{
  background:#fff;
  padding-top: clamp(40px, 2vw, 70px);
  padding-bottom: var(--section-pad-y);
}

.t-card--image{
  padding: 0; 
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-0);
  background: #fff;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.t-card--image:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-1);
  border-color: #e1e6f0;
}

/* Wrapper com proporção consistente (evita layout shift)*/
.t-img-wrap{
  aspect-ratio: 16/9;              /* mantém todos os prints na mesma altura */
  width: 100%;
  background: #fff;
} 

/*Imagem do print: preenche o card sem cortar textos */
.t-img{
  width: 100%;
  height: 100%;
  object-fit: contain;              /* NÃO corta — mostra o print inteiro */
  display: block;
  background: #f8f4fc;
}

/* =========================== FECHAMENTO =========================== */


.closing--light{
  padding-block: clamp(40px, 5vw, 70px) !important; /* top e bottom */
  text-align: center;
  background: #f7f7F7;
}
.closing-title{margin:0 0 18px !important;}
.closing-sub{margin:0 0 28px !important;}

.closing-title{ font-weight:800; font-size:var(--h2); margin:0px 0 12px }
.closing-title u{ text-decoration:none; color:var(--brand-blue) }  /* sem underline, azul */
.closing-sub{ margin:0 0 26px; color:var(--muted) }
.closing-ctas{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center }

/* Caixa opcional */
.closing-box{
  margin-inline:auto; max-width:920px;
  background:#FFF; border:1px solid var(--line);
  border-radius:24px; padding:38px 28px; box-shadow:var(--shadow-1);
}

/* Botão outline azul para "Ligar agora" (combina com a paleta) */
.btn-call{
  border: 2px solid var(--brand-blue);
  background: #085CB4;
  color: #FFF;
  transition: background .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.btn-call:hover{
  background: var(--brand-blue);
  color: #fff;
  transform: translateY(-2px);
}

/* garante layout lado a lado e bom espaçamento (você já tem, mas reforçando) */
.closing-ctas{
  display:flex; flex-wrap:wrap; gap:12px; justify-content:center;
}


/* =========================== WHATSAPP FLOAT =========================== */
.whatsapp-float{
  position:fixed; 
  right:20px; 
  bottom:calc(20px + env(safe-area-inset-bottom));
  z-index:1000; 
  width:60px; 
  height:60px; 
  border-radius:999px;
  display:flex; 
  align-items:center; 
  justify-content:center;
  opacity:0; 
  transform:translateY(14px) scale(.9);
  animation: whatsappPop .55s cubic-bezier(.2,.8,.2,1) .2s forwards, 
             whatsappBounce 2s ease-in-out 1s infinite; /* animação contínua */
  box-shadow:var(--shadow-2);
}

.whatsapp-float::before{ 
  content:""; 
  position:absolute; 
  inset:0; 
  border-radius:999px; 
  background:var(--whatsapp);
}

.whatsapp-float img{ 
  position:relative; 
  z-index:1; 
  width:28px; 
  height:28px; 
  filter:brightness(0) invert(1) drop-shadow(0 1px 0 rgba(0,0,0,.15));
}

.whatsapp-float:hover{ 
  transform:translateY(0) scale(1.06); 
}

/* Animação de entrada */
@keyframes whatsappPop{ 
  0%{opacity:0;transform:translateY(14px) scale(.9)} 
  60%{opacity:1;transform:translateY(0) scale(1.06)} 
  100%{opacity:1;transform:translateY(0) scale(1)} 
}

/* Animação de pulinhos */
@keyframes whatsappBounce{
  0%, 20%, 50%, 80%, 100% { transform: translateY(0) scale(1); }
  40% { transform: translateY(-8px) scale(1.02); }
  60% { transform: translateY(-4px) scale(1.01); }
}

/* ================================= FOOTER ================================ */
footer{
  background:#fff;
  padding: var(--s-5) 0;
  font-size:14px;
  /* border-top:1px solid var(--line); */
}
.text-center{
    margin-top:20px;
}

footer p{ color:#5a6a86 }
footer .social-icons a{ color:#0f1222; font-size:22px; margin:0 8px; transition:transform .2s, color .2s }
footer .social-icons a:hover{ color:var(--brand-orange); transform:scale(1.08) }
/* Oculta qualquer link “tel:” no footer (botão só com número) */
footer a[href^="tel:"]{ display:none !important }

/* ========================== ANIMAÇÕES ON-SCROLL ========================== */
[data-animate]{
  opacity:0; transform:translateY(10px) scale(.995); filter:blur(2px);
  transition:opacity .7s, transform .7s cubic-bezier(.2,.8,.2,1), filter .7s; will-change: transform, filter;
}
[data-animate].in{ opacity:1; transform:none; filter:none }
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important }
  [data-animate]{ opacity:1 !important; transform:none !important; filter:none !important }
}

