/* Resetzinho amigável */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%;display:block}
ul,ol{margin:0;padding:0;list-style:none}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font:inherit}

/* Tokens */
:root{
  --bg: #f6f7fb;
  --paper: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --primary: #6c63ff;
  --primary-2: #8b86ff;
  --ring: rgba(108,99,255,.25);
  --shadow: 0 20px 50px rgba(17,24,39,.08);
  --radius: 16px;
}

body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color: var(--text);
  background: radial-gradient(1200px 600px at 70% 0%, #eef1ff 0%, transparent 55%) , var(--bg);
  line-height: 1.6;
}

/* Containers */
.container{width:min(1120px, 92%); margin-inline:auto}

/* Header */
.site-header{
  position: sticky; top:0; z-index:50;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid #e5e7eb;
}
.header-inner{
  height:72px; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{ font-weight:800; letter-spacing:.2px; font-size:22px; }

/* Nav */
.site-nav ul{display:flex; gap:28px; align-items:center}
.site-nav a{color:#111827; opacity:.9}
.site-nav a:hover{opacity:1}
.btn-nav{
  padding:.55rem .9rem; border:1px solid #e5e7eb; border-radius:999px;
  transition:.2s background, .2s box-shadow;
}
.btn-nav:hover{ background:#fff; box-shadow:0 8px 24px rgba(0,0,0,.06); }

/* Hambúrguer */
.nav-toggle{display:none; background:transparent; border:0; width:40px; height:40px;}
.nav-toggle span{display:block; height:2px; background:#111827; margin:8px 6px; border-radius:2px}

/* Hero */
.hero{ padding:54px 0 24px }
.hero-grid{ display:grid; align-items:center; gap:40px; grid-template-columns: 1.15fr 1fr; }
.hero h1{
  font-size: clamp(36px, 3.8vw + 16px, 64px);
  line-height: 1.05;
  letter-spacing:-.8px;
  margin:0 0 12px;
  font-weight:900;
  
    
  
}
.dot{ color: var(--primary); }
.lead{ color:var(--muted); font-size:18px; max-width:58ch }

.hero-actions{ display:flex; gap:16px; margin-top:40px; justify-content: flex-start; }
.hero-actions.center{ justify-content: center; }

/* ==== BOTÕES UNIFICADOS ==== */
.hero-actions .btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:56px;               /* mesma altura pros dois */
  padding:0 24px;            /* mesma largura interna */
  border-radius:14px;
  font-weight:600;
  font-size:18px;
  line-height:1;             /* evita “esticar” o ghost */
  border:1px solid transparent;
  gap:8px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}

/* Primário: roxo em degradê */
.hero-actions .btn-primary{
  color:#fff;
  background: linear-gradient(135deg, var(--primary), var(--primary-2));
  border-color: transparent;
  box-shadow: 0 18px 48px var(--ring);
}
.hero-actions .btn-primary:hover{
  transform: translateY(-1px);
}

/* Ghost: branco com borda */
.hero-actions .btn-ghost{
  color:#111827;
  background:#fff;
  border-color:#e5e7eb;                        /* mesma borda sempre */
  box-shadow: 0 8px 40px rgba(0,0,0,.06);       /* sombra leve p/ igualar “peso” visual */
}
.hero-actions .btn-ghost:hover{
  background:#fafafa;
  border-color:#e0e0e0;
  transform: translateY(-1px);
}

/* Centralização do grupo (se quiser centralizado) */
.hero-actions{
  display:flex;
  justify-content:center;   /* use flex-start para alinhar à esquerda */
  gap:16px;
  margin-top:24px;
}


.hero-media img{
  border-radius: 28px;
  box-shadow: var(--shadow);
  
  
}

/* Sections */
.section{ padding:72px 0 }
.section.alt{ background: #fafafe }
.narrow{ width:min(840px, 100%); }
.section-header h2{ margin:0 0 8px; font-size:28px }
.muted{ color:var(--muted) }

/* Cards / Features */
.features{ display:grid; grid-template-columns: repeat(3,1fr); gap:16px; margin-top:20px }
.card{
  background:var(--paper); border-radius:16px; padding:20px; box-shadow: var(--shadow);
  border:1px solid #eef0f5;
}
.card h3{ margin:0 0 6px; font-size:18px }

/* Serviços */
.services{ display:grid; grid-template-columns: repeat(3,1fr); gap:16px; margin-top:20px }
.service_icon{ font-size:28px; }

/* Contato */
.contact-grid{ display:grid; grid-template-columns: 1.1fr .9fr; gap:20px }
.contact-form label{ font-weight:600; display:block; margin:12px 0 6px }
.contact-form input, .contact-form textarea{
  width:100%; background:#fff; border:1px solid #e6e9f2; border-radius:12px;
  padding:.85rem 1rem; outline:0;
}
.contact-form input:focus, .contact-form textarea:focus{
  border-color: var(--primary); box-shadow: 0 0 0 4px var(--ring);
}
.contact-list{ display:grid; gap:8px }

/* Footer */
.site-footer{ padding:32px 0; border-top:1px solid #e5e7eb; background:#fff }
.footer-inner{ display:flex; align-items:center; justify-content:space-between }
.to-top{ width:36px; height:36px; display:grid; place-items:center; border:1px solid #e5e7eb; border-radius:50% }

/* WhatsApp FAB + Bubble (ANIMADO) */
.wa-wrap{
  position:fixed; right:22px; bottom:22px; display:flex; align-items:center; gap:8px; z-index:60
}
#wa-fab{
  position:relative;
  width:64px; height:64px; border-radius:50%;
  display:grid; place-items:center; color:#fff;
  background:#25d366;
  box-shadow:0 18px 40px rgba(37,211,102,.32);
  /* Animação de "flutuar" contínua */
  animation: wa-bob 4s ease-in-out infinite;
  will-change: transform;
}
#wa-fab:hover{ filter:brightness(1.04) }

/* Anel pulsante */
#wa-fab::before{
  content:"";
  position:absolute; inset:0;
  border-radius:50%;
  box-shadow:0 0 0 0 rgba(37,211,102,.45);
  animation: wa-pulse 2.2s ease-out infinite;
  z-index:-1; pointer-events:none;
}

/* Glow respirando */
#wa-fab::after{
  content:"";
  position:absolute; inset:-6px;
  border-radius:50%;
  background: radial-gradient(rgba(37,211,102,.35) 0, rgba(37,211,102,0) 60%);
  filter: blur(2px);
  opacity:.65;
  animation: wa-glow 3s ease-in-out infinite;
  z-index:-2; pointer-events:none;
}

/* Balão “Fale conosco” (já tinha) */
.wa-bubble{
  opacity:0; transform:translateY(8px); pointer-events:none;
  transition:.25s; background:#fff; border:1px solid #e5e7eb; border-radius:999px; padding:.55rem .9rem;
  box-shadow:0 20px 50px rgba(17,24,39,.08); color:#111827; font-size:14px;
}
.wa-bubble.show{ opacity:1; transform:translateY(0) }

/* Keyframes */
@keyframes wa-pulse{
  0%   { box-shadow:0 0 0 0 rgba(37,211,102,.45) }
  70%  { box-shadow:0 0 0 18px rgba(37,211,102,0) }
  100% { box-shadow:0 0 0 0 rgba(37,211,102,0) }
}
@keyframes wa-bob{
  0%,100% { transform: translateY(0) }
  50%     { transform: translateY(-3px) }
}
@keyframes wa-glow{
  0%,100% { transform: scale(1);   opacity:.55 }
  50%     { transform: scale(1.06); opacity:.85 }
}

/* Respeita acessibilidade */
@media (prefers-reduced-motion: reduce){
  #wa-fab, #wa-fab::before, #wa-fab::after{
    animation: none !important;
  }
}

@media (max-width: 768px) {
  .hero-actions {
    flex-direction: column;  /* botões em coluna */
    gap: 12px;               /* espaço entre eles */
  }
}

/* Responsivo */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .features, .services{ grid-template-columns: 1fr; }
  .contact-grid{ grid-template-columns: 1fr }
  .nav-toggle{ display:block }
  .site-nav{ position:absolute; top:72px; left:0; right:0; background:#fff; border-bottom:1px solid #e5e7eb; display:none }
  .site-nav.open{ display:block }
  .site-nav ul{ flex-direction:column; padding:12px 20px }
  .site-nav a{ padding:10px 0; width:100% }
}
/* ---- Reveal on scroll ---- */

.reveal-up {
  opacity: 0;
  transform: translateY(24px);
  transition: transform .8s cubic-bezier(.22,1,.36,1), opacity .8s ease;
  
}
.reveal-up.in {
  opacity: 1;
  transform: translateY(0);
}
.reveal-up.delay-1 { transition-delay: .08s; }
.reveal-up.delay-2 { transition-delay: .16s; }
.reveal-up.delay-3 { transition-delay: .24s; }

/* ---- Hero “animated” (mantém sua base) ---- */
.hero-animated {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

/* brilho/gradiente de fundo bem sutil (opcional) */
.hero-animated::before {
  content: "";
  position: absolute;
  inset: -30% -10% auto -10%;
  height: 60%;
  z-index: -1;
  background: radial-gradient(60% 60% at 70% 40%, rgba(124,58,237,.20), rgba(59,130,246,.12), transparent 70%);
  filter: blur(40px);
  animation: breathe 8s ease-in-out infinite alternate;
}
@keyframes breathe {
  from { transform: translateY(0); opacity: .7; }
  to   { transform: translateY(-12px); opacity: .9; }
}

/* ---- Mockups ---- */
.mockups {
  position: relative;
  display: grid;
  place-items: center;
  min-height: clamp(280px, 40vw, 520px);
}

.mockup {
  position: absolute;
  width: clamp(160px, 22vw, 200px);
  aspect-ratio: 10/20;
  object-fit: cover;
  border-radius: 20px;
  box-shadow:
    0 20px 60px rgba(2,6,23,.18),
    0 6px 18px rgba(2,6,23,.12),
    0 0 0 1px rgba(2,6,23,.06) inset;
  transform-style: preserve-3d;
  will-change: transform, filter;
  animation: float 6s ease-in-out infinite;
  margin-top: 10px;
  
}

/* posições iniciais */
.mockup.m1 { z-index: 3; transform: rotate(-4deg) translate(8px, 0); }
.mockup.m2 { z-index: 2; transform: rotate( 20deg) translate(-150px, 24px); }
.mockup.m3 { z-index: 1; transform: rotate(-15deg) translate(150px, 36px); }

/* vibezinhas */
@keyframes float {
  0%   { translate: 0 0; }
  50%  { translate: 0 -5px; }
  100% { translate: 0 0; }
}

/* efeito de “glow” ao passar o mouse */
.mockup:hover {
  filter: saturate(1.06) brightness(1.03);
  box-shadow:
    0 28px 80px rgba(2,6,23,.24),
    0 10px 24px rgba(2,6,23,.14),
    0 0 0 1px rgba(2,6,23,.08) inset;
}

/* Responsivo: em telas pequenas, empilha */
@media (max-width: 900px) {
  .mockup { width: clamp(130px, 32vw, 100px); }
  .mockup.m1 { transform: rotate(-4deg) translate(0, 0); }
  .mockup.m2 { transform: rotate( 20deg) translate(-100px, 50px); }
  .mockup.m3 { transform: rotate(-15deg) translate(100px, 40px); }
}



