/* INNOVARE CODE — Premium CSS Redesign */

/* Layout */
.container { max-width: 1280px; margin: 0 auto; padding: 0 2rem; }

/* ── ACESSIBILIDADE: skip link + foco visível ── */
.skip-link { position:absolute; left:1rem; top:-60px; z-index:2000; background:#0030B8; color:#fff; padding:.7rem 1.2rem; border-radius:0 0 10px 10px; font-size:.875rem; font-weight:600; transition:top .2s; }
.skip-link:focus { top:0; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, summary:focus-visible {
  outline:2px solid #1A47D6; outline-offset:3px; border-radius:4px;
}

/* ── BARRA DE PROGRESSO DE ROLAGEM ── */
.scroll-progress { position:fixed; top:0; left:0; height:3px; width:0; z-index:1100; background:linear-gradient(90deg,#0030B8,#1A47D6,#C0C0C0); transition:width .1s linear; }

/* ── NAVBAR (white, clean) ── */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  height: 72px; display: flex; align-items: center;
  background: rgba(255,255,255,0.96);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(13,27,75,0.08);
  box-shadow: 0 2px 24px rgba(13,27,75,0.06);
  transition: box-shadow .3s ease;
  animation: navReveal .5s ease forwards;
}
#navbar.scrolled { box-shadow: 0 4px 40px rgba(13,27,75,0.12); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; gap:2.5rem; width:100%; }
.nav-logo { flex-shrink:0; }
.nav-logo img { height: 46px; width: auto; transition: transform .25s; }
.nav-logo:hover img { transform: scale(1.04); }

/* ── HERO BRAND MARK ── */
.hero-brand-mark {
  display: inline-flex; align-items: center; gap: 1rem;
  margin-bottom: 2rem;
  animation: fadeInUp .7s ease forwards;
}
.hero-brand-logo { height: 52px; width: auto; filter: drop-shadow(0 4px 24px rgba(0,48,184,.35)); }
.nav-menu { display:flex; align-items:center; gap:2rem; }
.nav-link { font-size:.875rem; font-weight:500; color:#4A5568; transition:color .2s; position:relative; padding:.25rem 0; }
.nav-link::after { content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px; background:#0030B8; transition:width .25s; }
.nav-link:hover, .nav-link.active { color:#0030B8; }
.nav-link:hover::after, .nav-link.active::after { width:100%; }
.nav-dropdown { position:relative; }
/* Ponte invisivel que cobre o vao entre "Produtos" e o submenu,
   evitando que o hover se perca ao mover o mouse ate as opcoes */
.nav-dropdown::after { content:''; position:absolute; left:0; right:0; top:100%; height:18px; }
.dropdown-menu {
  position:absolute; top:calc(100% + 14px); left:50%; transform:translateX(-50%);
  background:#fff; border:1px solid rgba(13,27,75,0.1); border-radius:14px;
  padding:.5rem; min-width:210px; box-shadow:0 16px 48px rgba(13,27,75,0.14);
  opacity:0; visibility:hidden; transition:all .22s ease; pointer-events:none;
}
.nav-dropdown:hover .dropdown-menu,
.nav-dropdown.open .dropdown-menu { opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.nav-dropdown > .nav-link { cursor:pointer; }
.nav-dropdown > .nav-link .caret { display:inline-block; transition:transform .25s; font-size:.7em; }
.nav-dropdown.open > .nav-link .caret { transform:rotate(180deg); }
.dropdown-item { display:flex; align-items:center; gap:.75rem; padding:.65rem 1rem; border-radius:10px; font-size:.875rem; color:#2D3748; transition:background .18s; }
.dropdown-item:hover { background:rgba(13,27,75,0.05); color:#0030B8; font-weight:500; }
.btn-cta {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.6rem 1.4rem; background:#0030B8; color:#fff;
  font-size:.875rem; font-weight:600; border-radius:50px;
  transition:all .25s; box-shadow:0 4px 16px rgba(13,27,75,0.3);
}
.btn-cta:hover { background:#1A47D6; transform:translateY(-2px); box-shadow:0 8px 28px rgba(13,27,75,0.4); }
.nav-toggle { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.nav-toggle span { display:block; width:24px; height:2px; background:#0030B8; border-radius:2px; transition:all .25s; }
.nav-toggle.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ── HERO (dark navy, editorial) ── */
#hero {
  min-height: 100vh; display:flex; align-items:center;
  background: linear-gradient(160deg, #04081C 0%, #0D1B4B 52%, #0030B8 120%);
  background-size:300% 300%; animation:gradientShift 14s ease infinite;
  padding-top:72px; position:relative; overflow:hidden;
}
.hero-grid-bg {
  position:absolute; inset:0; opacity:.04;
  background-image:linear-gradient(rgba(176,184,201,.8) 1px,transparent 1px),linear-gradient(90deg,rgba(176,184,201,.8) 1px,transparent 1px);
  background-size:80px 80px;
}
.hero-orb { position:absolute; border-radius:50%; filter:blur(80px); pointer-events:none; }
.hero-orb-1 { width:500px; height:500px; background:rgba(0,48,184,0.45); top:-150px; right:-100px; }
.hero-orb-2 { width:300px; height:300px; background:rgba(176,184,201,0.07); bottom:0; left:-60px; }
.hero-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; position:relative; z-index:2; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:.6rem; padding:.4rem 1rem; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12); border-radius:50px; font-size:.8rem; font-weight:500; color:#B0B8C9; letter-spacing:.05em; text-transform:uppercase; margin-bottom:1.5rem; }
.hero-eyebrow-dot { width:7px; height:7px; border-radius:50%; background:#4ADE80; animation:pulseGlow 2s infinite; }
.hero-h1 { font-family:'Outfit',sans-serif; font-size:clamp(2.8rem,5vw,4.2rem); font-weight:800; line-height:1.08; color:#fff; margin-bottom:1.5rem; letter-spacing:-0.02em; }
.hero-h1 em { font-style:normal; background:linear-gradient(135deg,#94A3B8,#E2E8F0); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.hero-sub { font-size:1.1rem; color:#94A3B8; line-height:1.7; margin-bottom:2.5rem; max-width:480px; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }
.btn-hero-primary { display:inline-flex; align-items:center; gap:.6rem; padding:1rem 2rem; background:#fff; color:#0030B8; font-weight:700; font-size:1rem; border-radius:50px; transition:all .3s; box-shadow:0 4px 24px rgba(255,255,255,.15); }
.btn-hero-primary:hover { transform:translateY(-3px); box-shadow:0 12px 36px rgba(255,255,255,.25); }
.btn-hero-secondary { display:inline-flex; align-items:center; gap:.6rem; padding:1rem 2rem; background:transparent; color:#fff; font-weight:600; font-size:1rem; border-radius:50px; border:1.5px solid rgba(255,255,255,.25); transition:all .3s; }
.btn-hero-secondary:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.5); transform:translateY(-2px); }
.hero-trust { display:flex; align-items:center; gap:1rem; }
.hero-trust-text { font-size:.8rem; color:#64748B; }
.hero-trust-badges { display:flex; gap:.5rem; }
.trust-badge { padding:.3rem .7rem; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:50px; font-size:.75rem; color:#94A3B8; }

/* Browser mockup */
.browser-mockup { background:#1E2A4A; border-radius:16px; overflow:hidden; box-shadow:0 32px 80px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.05); transform:perspective(1000px) rotateY(-8deg) rotateX(4deg); transition:transform .4s ease; }
.browser-mockup:hover { transform:perspective(1000px) rotateY(-4deg) rotateX(2deg); }
.browser-bar { display:flex; align-items:center; gap:.6rem; padding:.75rem 1rem; background:#0D1427; border-bottom:1px solid rgba(255,255,255,.06); }
.b-dot { width:11px; height:11px; border-radius:50%; }
.b-dot.r { background:#FF5F56; } .b-dot.y { background:#FFBD2E; } .b-dot.g { background:#27C93F; }
.b-url { margin-left:.75rem; flex:1; background:rgba(255,255,255,.06); border-radius:6px; padding:.25rem .75rem; font-size:.7rem; color:#64748B; font-family:monospace; }
.browser-screen { overflow:hidden; height:420px; }
.browser-screen img { width:100%; height:100%; display:block; object-fit:cover; object-position:top center; }

/* ── STATS (light section) ── */
#stats { background:#F8F9FC; padding:5rem 0; border-top:1px solid rgba(13,27,75,.06); border-bottom:1px solid rgba(13,27,75,.06); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(13,27,75,.08); border-radius:20px; overflow:hidden; }
.stat-item { background:#fff; padding:2.5rem 2rem; text-align:center; transition:background .2s; }
.stat-item:hover { background:#F8F9FC; }
.stat-number { font-family:'Outfit',sans-serif; font-size:3.5rem; font-weight:800; color:#0030B8; line-height:1; margin-bottom:.5rem; }
.stat-label { font-size:.8rem; color:#94A3B8; font-weight:500; text-transform:uppercase; letter-spacing:.1em; }

/* ── SECTION LABEL ── */
.s-eyebrow { display:inline-flex; align-items:center; gap:.5rem; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.12em; color:#0030B8; opacity:.7; margin-bottom:1rem; }
.s-eyebrow::before { content:''; width:24px; height:2px; background:#0030B8; opacity:.4; border-radius:2px; }
.s-h2 { font-family:'Outfit',sans-serif; font-size:clamp(2rem,4vw,3rem); font-weight:800; line-height:1.1; letter-spacing:-0.02em; color:#0030B8; margin-bottom:1rem; }
.s-h2 span { background:linear-gradient(135deg,#0030B8,#4A6BDB); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.s-sub { font-size:1.05rem; color:#64748B; line-height:1.7; max-width:560px; }
.s-header { margin-bottom:4rem; }
.s-header.center { text-align:center; }
.s-header.center .s-sub { margin:0 auto; }

/* ── PRODUCTS (alternating editorial rows) ── */
#products { background:#fff; padding:7rem 0; }
.product-row { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-bottom:7rem; }
.product-row:last-child { margin-bottom:0; }
.product-row.reverse { direction:rtl; }
.product-row.reverse > * { direction:ltr; }
.product-text { }
.product-kicker { display:inline-flex; align-items:center; gap:.5rem; padding:.35rem .9rem; border-radius:50px; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1.5rem; }
.kicker-menu { background:#FFF3EE; color:#E05E2B; border:1px solid #FFD5C2; }
.kicker-mens { background:#1A1A1A; color:#F59E0B; border:1px solid #374151; }
.kicker-frotas { background:#EEF2FF; color:#3B5BDB; border:1px solid #C7D7FF; }
.product-name { font-family:'Outfit',sans-serif; font-size:2.6rem; font-weight:800; color:#0030B8; line-height:1.1; letter-spacing:-0.02em; margin-bottom:1rem; }
.product-desc { font-size:1.05rem; color:#64748B; line-height:1.75; margin-bottom:2rem; }
.product-feats { display:flex; flex-direction:column; gap:.75rem; margin-bottom:2.5rem; }
.product-feat { display:flex; align-items:center; gap:.75rem; font-size:.9rem; color:#374151; }
.feat-check { width:20px; height:20px; border-radius:6px; background:#0030B8; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.65rem; color:#fff; font-weight:700; }
.product-cta { display:inline-flex; align-items:center; gap:.6rem; padding:.9rem 1.8rem; background:#0030B8; color:#fff; font-weight:600; border-radius:50px; transition:all .3s; font-size:.95rem; box-shadow:0 4px 20px rgba(13,27,75,.25); }
.product-cta:hover { background:#1A47D6; transform:translateY(-3px); box-shadow:0 10px 32px rgba(13,27,75,.35); }
.product-cta-ghost { display:inline-flex; align-items:center; gap:.5rem; padding:.9rem 1.5rem; color:#0030B8; font-weight:500; font-size:.9rem; border:1.5px solid rgba(13,27,75,.15); border-radius:50px; transition:all .25s; margin-left:.75rem; }
.product-cta-ghost:hover { border-color:#0030B8; background:rgba(13,27,75,.04); }
.product-visual { position:relative; }
.product-visual-glow { position:absolute; inset:-20px; border-radius:24px; filter:blur(40px); opacity:.15; z-index:0; }
.glow-menu { background:linear-gradient(135deg,#E05E2B,#F59E0B); }
.glow-mens { background:linear-gradient(135deg,#F59E0B,#FBBF24); }
.glow-frotas { background:linear-gradient(135deg,#3B5BDB,#60A5FA); }
.product-visual > .browser-mockup { position:relative; z-index:1; }

/* ── SERVICES (light bg) ── */
#services { background:#F8F9FC; padding:7rem 0; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.svc-card { background:#fff; border:1px solid rgba(13,27,75,.07); border-radius:20px; padding:2.5rem 2rem; transition:all .3s cubic-bezier(.34,1.56,.64,1); cursor:default; }
.svc-card:hover { transform:translateY(-8px); box-shadow:0 24px 64px rgba(13,27,75,.1); border-color:rgba(13,27,75,.15); }
.svc-icon { width:56px; height:56px; background:linear-gradient(135deg,#0030B8,#1A3068); border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin-bottom:1.5rem; box-shadow:0 8px 24px rgba(13,27,75,.2); }
.svc-name { font-family:'Outfit',sans-serif; font-size:1.1rem; font-weight:700; color:#0030B8; margin-bottom:.75rem; }
.svc-desc { font-size:.875rem; color:#64748B; line-height:1.7; }

/* ── WHY US (dark navy) ── */
#why-us { background:#0D1B4B; padding:7rem 0; position:relative; overflow:hidden; }
.why-bg-pattern { position:absolute; inset:0; opacity:.03; background-image:radial-gradient(circle, #fff 1px, transparent 1px); background-size:40px 40px; }
.why-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; position:relative; z-index:2; }
.why-text .s-h2 { color:#fff; }
.why-text .s-h2 span { background:linear-gradient(135deg,#94A3B8,#E2E8F0); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.why-text .s-sub { color:#94A3B8; }
.why-text .s-eyebrow { color:rgba(176,184,201,.8); }
.pillars { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin-top:2.5rem; }
.pillar { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:1.75rem; transition:all .3s; }
.pillar:hover { background:rgba(255,255,255,.08); border-color:rgba(255,255,255,.15); transform:translateY(-4px); }
.pillar-icon { font-size:1.8rem; margin-bottom:.75rem; }
.pillar-title { font-family:'Outfit',sans-serif; font-size:1rem; font-weight:700; color:#fff; margin-bottom:.5rem; }
.pillar-desc { font-size:.85rem; color:#94A3B8; line-height:1.65; }
.why-numbers { display:flex; flex-direction:column; gap:1.5rem; }
.why-num-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:20px; padding:2rem 2.5rem; display:flex; align-items:center; gap:1.5rem; transition:all .3s; }
.why-num-card:hover { background:rgba(255,255,255,.08); transform:translateX(8px); }
.why-big-num { font-family:'Outfit',sans-serif; font-size:3.5rem; font-weight:800; color:#fff; line-height:1; width:130px; flex-shrink:0; }
.why-big-num span { background:linear-gradient(135deg,#94A3B8,#E2E8F0); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.why-num-label { font-size:.95rem; color:#94A3B8; line-height:1.6; }
.why-num-label strong { display:block; font-size:1.05rem; color:#fff; margin-bottom:.25rem; }

/* ── CTA ── */
#cta-section { background:#fff; padding:7rem 0; }
.cta-inner { background:linear-gradient(135deg,#040B1E 0%,#0030B8 60%,#1A47D6 100%); border-radius:32px; padding:5rem 4rem; text-align:center; position:relative; overflow:hidden; }
.cta-orb { position:absolute; border-radius:50%; filter:blur(60px); pointer-events:none; }
.cta-orb-1 { width:350px; height:350px; background:rgba(0,48,184,0.7); top:-100px; right:-80px; }
.cta-orb-2 { width:250px; height:250px; background:rgba(176,184,201,0.06); bottom:-60px; left:-60px; }
.cta-inner > *:not(.cta-orb) { position:relative; z-index:2; }
.cta-h2 { font-family:'Outfit',sans-serif; font-size:clamp(2rem,4vw,3.2rem); font-weight:800; color:#fff; letter-spacing:-0.02em; margin-bottom:1.25rem; }
.cta-sub { font-size:1.1rem; color:#94A3B8; max-width:520px; margin:0 auto 2.5rem; line-height:1.7; }
.cta-btns { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; margin-bottom:3rem; }
.btn-wpp { display:inline-flex; align-items:center; gap:.75rem; padding:1.1rem 2.2rem; background:linear-gradient(135deg,#25D366,#128C7E); color:#fff; font-weight:700; font-size:1.05rem; border-radius:50px; transition:all .3s; box-shadow:0 4px 30px rgba(37,211,102,.4); }
.btn-wpp:hover { transform:translateY(-4px); box-shadow:0 12px 44px rgba(37,211,102,.55); }
.btn-email { display:inline-flex; align-items:center; gap:.6rem; padding:1.1rem 2rem; background:rgba(255,255,255,.08); color:#fff; font-weight:600; font-size:1rem; border-radius:50px; border:1.5px solid rgba(255,255,255,.2); transition:all .3s; }
.btn-email:hover { background:rgba(255,255,255,.15); border-color:rgba(255,255,255,.4); transform:translateY(-2px); }
.cta-contact-row { display:flex; justify-content:center; gap:3rem; flex-wrap:wrap; }
.cta-info { text-align:center; }
.cta-info-icon { font-size:1.5rem; margin-bottom:.4rem; }
.cta-info-text { font-size:.875rem; color:#94A3B8; }

/* ── FOOTER ── */
#footer { background:#040B1E; border-top:1px solid rgba(176,184,201,.08); padding:5rem 0 2.5rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:4rem; margin-bottom:4rem; }
.footer-logo img { height:38px; margin-bottom:1.25rem; }
.footer-about { font-size:.875rem; color:#64748B; line-height:1.75; margin-bottom:1.5rem; max-width:280px; }
.footer-contact-item { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:#64748B; margin-bottom:.5rem; }
.footer-col-title { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:#B0B8C9; margin-bottom:1.25rem; }
.footer-links { display:flex; flex-direction:column; gap:.75rem; }
.footer-link { font-size:.875rem; color:#64748B; transition:color .18s; }
.footer-link:hover { color:#fff; }
.footer-bottom { border-top:1px solid rgba(176,184,201,.08); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-copy { font-size:.8rem; color:#475569; }
.footer-socials { display:flex; gap:.75rem; }
.social-btn { width:38px; height:38px; background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.07); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:.9rem; color:#64748B; transition:all .2s; }
.social-btn:hover { background:rgba(255,255,255,.1); color:#fff; transform:translateY(-3px); }
.footer-copy-link { color:#94A3B8; transition:color .18s; }
.footer-copy-link:hover { color:#fff; }

/* ============================================================
   FASE 3 — PROCESSO
   ============================================================ */
#processo { background:#fff; padding:7rem 0; }
.process-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.process-step { position:relative; background:#F8F9FC; border:1px solid rgba(13,27,75,.07); border-radius:20px; padding:2.5rem 1.75rem 2rem; transition:all .3s cubic-bezier(.34,1.56,.64,1); overflow:hidden; }
.process-step:hover { transform:translateY(-6px); box-shadow:0 24px 56px rgba(13,27,75,.1); border-color:rgba(0,48,184,.15); }
.process-num { position:absolute; top:.75rem; right:1.25rem; font-family:'Outfit',sans-serif; font-size:3rem; font-weight:800; color:rgba(0,48,184,.08); line-height:1; }
.process-icon { font-size:2rem; margin-bottom:1rem; }
.process-title { font-family:'Outfit',sans-serif; font-size:1.15rem; font-weight:700; color:#0030B8; margin-bottom:.6rem; }
.process-desc { font-size:.9rem; color:#64748B; line-height:1.7; }

/* ============================================================
   FASE 3 — FAQ
   ============================================================ */
#faq { background:#F8F9FC; padding:7rem 0; border-top:1px solid rgba(13,27,75,.06); }
.faq-list { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:1rem; }
.faq-item { background:#fff; border:1px solid rgba(13,27,75,.08); border-radius:14px; overflow:hidden; transition:border-color .2s, box-shadow .2s; }
.faq-item[open] { border-color:rgba(0,48,184,.2); box-shadow:0 10px 30px rgba(13,27,75,.06); }
.faq-item summary { list-style:none; cursor:pointer; padding:1.25rem 1.5rem; font-family:'Outfit',sans-serif; font-weight:600; font-size:1rem; color:#0D1B4B; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after { content:'+'; font-size:1.5rem; font-weight:400; color:#0030B8; transition:transform .25s; flex-shrink:0; }
.faq-item[open] summary::after { transform:rotate(45deg); }
.faq-answer { padding:0 1.5rem 1.35rem; }
.faq-answer p { font-size:.92rem; color:#64748B; line-height:1.75; }

/* ============================================================
   FASE 2 — DEPOIMENTOS
   ============================================================ */
#depoimentos { background:#F8F9FC; padding:7rem 0; border-top:1px solid rgba(13,27,75,.06); }
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.testi-card { background:#fff; border:1px solid rgba(13,27,75,.07); border-radius:20px; padding:2rem; display:flex; flex-direction:column; gap:1rem; transition:all .3s cubic-bezier(.34,1.56,.64,1); }
.testi-card:hover { transform:translateY(-6px); box-shadow:0 24px 56px rgba(13,27,75,.1); border-color:rgba(0,48,184,.15); }
.testi-stars { color:#F5A623; font-size:1rem; letter-spacing:.15em; }
.testi-text { font-size:.95rem; color:#374151; line-height:1.7; margin:0; }
.testi-author { display:flex; align-items:center; gap:.85rem; margin-top:auto; }
.testi-avatar { width:46px; height:46px; border-radius:50%; background:linear-gradient(135deg,#0030B8,#1A47D6); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:.9rem; flex-shrink:0; }
.testi-author strong { display:block; font-size:.9rem; color:#0030B8; }
.testi-author span { font-size:.8rem; color:#94A3B8; }
.logo-strip { margin-top:4rem; text-align:center; }
.logo-strip-label { display:block; font-size:.75rem; text-transform:uppercase; letter-spacing:.12em; color:#94A3B8; margin-bottom:1.5rem; font-weight:600; }
.logo-strip-items { display:flex; flex-wrap:wrap; justify-content:center; gap:1rem 2.5rem; align-items:center; }
.client-logo { font-family:'Outfit',sans-serif; font-weight:700; font-size:1.1rem; color:#B0B8C9; padding:.5rem 1rem; border:1px dashed rgba(13,27,75,.12); border-radius:10px; letter-spacing:.02em; }

/* ============================================================
   FASE 2 — CONTATO (formulário)
   ============================================================ */
.cta-inner { text-align:left; }
.contact-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:3.5rem; align-items:start; }
.cta-eyebrow { font-size:.8rem; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:#B0B8C9; margin-bottom:1rem; }
.contact-grid .cta-h2 { text-align:left; }
.contact-grid .cta-sub { margin:0 0 2rem; text-align:left; }
.contact-channels { display:flex; flex-direction:column; gap:1.5rem; align-items:flex-start; }
.contact-direct { display:flex; flex-direction:column; gap:.6rem; }
.contact-line { font-size:.9rem; color:#94A3B8; transition:color .18s; }
a.contact-line:hover { color:#fff; }
.contact-form { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:20px; padding:2rem; backdrop-filter:blur(12px); }
.form-title { font-family:'Outfit',sans-serif; font-size:1.3rem; font-weight:700; color:#fff; margin-bottom:1.5rem; }
.form-field { margin-bottom:1rem; }
.form-field label { display:block; font-size:.78rem; font-weight:600; color:#B0B8C9; margin-bottom:.4rem; }
.form-field input, .form-field select, .form-field textarea {
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  border-radius:10px; padding:.8rem 1rem; color:#fff; font-size:.9rem; transition:border-color .2s, background .2s;
}
.form-field textarea { resize:vertical; min-height:80px; }
.form-field select option { color:#0D1B4B; }
.form-field input::placeholder, .form-field textarea::placeholder { color:#64748B; }
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { outline:none; border-color:#4A6BDB; background:rgba(255,255,255,.1); }
.form-field input.invalid { border-color:#EF4444; background:rgba(239,68,68,.08); }
.form-submit { width:100%; margin-top:.5rem; padding:1rem; background:#fff; color:#0030B8; font-weight:700; font-size:1rem; border-radius:50px; transition:all .3s; box-shadow:0 4px 24px rgba(255,255,255,.15); }
.form-submit:hover { transform:translateY(-2px); box-shadow:0 10px 32px rgba(255,255,255,.25); }
.form-note { font-size:.75rem; color:#64748B; margin-top:.85rem; text-align:center; }
.form-status { font-size:.85rem; color:#4ADE80; margin-top:.85rem; text-align:center; font-weight:600; }

/* ============================================================
   FASE 2 — BOTÃO FLUTUANTE WHATSAPP
   ============================================================ */
.wpp-float {
  position:fixed; bottom:24px; right:24px; z-index:900;
  width:60px; height:60px; border-radius:50%;
  background:linear-gradient(135deg,#25D366,#128C7E); color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 28px rgba(37,211,102,.45);
  opacity:0; visibility:hidden; transform:translateY(20px) scale(.8);
  transition:opacity .3s, transform .3s, visibility .3s;
}
.wpp-float.visible { opacity:1; visibility:visible; transform:translateY(0) scale(1); }
.wpp-float:hover { transform:translateY(-4px) scale(1.06); box-shadow:0 14px 40px rgba(37,211,102,.6); }
.wpp-float::before { content:''; position:absolute; inset:0; border-radius:50%; background:inherit; z-index:-1; animation:wppPulse 2.2s ease-out infinite; }
@keyframes wppPulse { 0% { transform:scale(1); opacity:.6; } 100% { transform:scale(1.8); opacity:0; } }

/* ============================================================
   FASE 2 — BANNER DE COOKIES (LGPD)
   ============================================================ */
.cookie-banner {
  position:fixed; bottom:20px; left:20px; right:20px; max-width:680px; margin:0 auto; z-index:950;
  background:rgba(7,14,43,.96); backdrop-filter:blur(16px);
  border:1px solid rgba(176,184,201,.14); border-radius:16px;
  padding:1.25rem 1.5rem; box-shadow:0 16px 48px rgba(4,8,28,.5);
  display:flex; align-items:center; gap:1.5rem; flex-wrap:wrap;
  transform:translateY(160%); transition:transform .4s cubic-bezier(.34,1.2,.64,1);
}
.cookie-banner.visible { transform:translateY(0); }
.cookie-text { font-size:.82rem; color:#94A3B8; line-height:1.6; flex:1; min-width:220px; margin:0; }
.cookie-text a { color:#B0B8C9; text-decoration:underline; }
.cookie-actions { display:flex; gap:.6rem; flex-shrink:0; }
.cookie-btn { padding:.6rem 1.3rem; border-radius:50px; font-size:.85rem; font-weight:600; transition:all .2s; }
.cookie-accept { background:#0030B8; color:#fff; }
.cookie-accept:hover { background:#1A47D6; transform:translateY(-2px); }
.cookie-reject { background:transparent; color:#94A3B8; border:1px solid rgba(176,184,201,.2); }
.cookie-reject:hover { color:#fff; border-color:rgba(176,184,201,.4); }

/* ── PROJETOS SOB MEDIDA (callout) ── */
.custom-solutions {
  position:relative; overflow:hidden; margin-top:5rem; text-align:center;
  background:linear-gradient(150deg,#04081C 0%,#0D1B4B 60%,#0030B8 135%);
  border:1px solid rgba(255,255,255,.08); border-radius:28px; padding:4rem 2.5rem;
}
.custom-solutions-glow { position:absolute; width:420px; height:420px; border-radius:50%; filter:blur(90px); background:rgba(0,48,184,.45); top:-180px; left:50%; transform:translateX(-50%); pointer-events:none; }
.cs-badge { position:relative; display:inline-flex; align-items:center; gap:.5rem; padding:.45rem 1.1rem; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15); border-radius:50px; font-size:.78rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:#B0B8C9; margin-bottom:1.5rem; }
.cs-title { position:relative; font-family:'Outfit',sans-serif; font-size:clamp(1.8rem,3.5vw,2.6rem); font-weight:800; line-height:1.15; color:#fff; letter-spacing:-.02em; margin-bottom:1.25rem; }
.cs-title span { background:linear-gradient(135deg,#94A3B8,#E2E8F0); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.cs-desc { position:relative; font-size:1.1rem; color:#94A3B8; line-height:1.7; max-width:640px; margin:0 auto 2rem; }
.cs-desc strong { color:#fff; font-weight:700; }
.cs-tags { position:relative; display:flex; flex-wrap:wrap; justify-content:center; gap:.65rem; max-width:720px; margin:0 auto 2.5rem; }
.cs-tags li { padding:.5rem 1.1rem; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:50px; font-size:.875rem; font-weight:500; color:#E2E8F0; transition:all .2s; }
.cs-tags li:hover { background:rgba(255,255,255,.12); transform:translateY(-2px); }
.cs-cta { position:relative; display:inline-flex; align-items:center; gap:.6rem; padding:1rem 2.25rem; background:linear-gradient(135deg,#25D366,#128C7E); color:#fff; font-weight:700; font-size:1rem; border-radius:50px; transition:all .3s; box-shadow:0 8px 28px rgba(37,211,102,.35); }
.cs-cta:hover { transform:translateY(-3px); box-shadow:0 14px 40px rgba(37,211,102,.5); }

/* ── RESPONSIVE ── */

/* Telas medias (notebooks/tablets em paisagem): reduz folga do menu */
@media (max-width:1100px) and (min-width:901px) {
  .nav-menu { gap:1.4rem; }
  .nav-link { font-size:.82rem; }
}

@media (max-width:900px) {
  .nav-toggle { display:flex; }
  .nav-menu {
    position:fixed; top:72px; left:0; right:0; max-height:calc(100vh - 72px); overflow-y:auto;
    flex-direction:column; background:#fff; padding:1.5rem 2rem 2rem; gap:.25rem; align-items:stretch;
    transform:translateY(-130%); transition:transform .3s; border-bottom:1px solid rgba(13,27,75,.08);
    box-shadow:0 8px 24px rgba(13,27,75,.08);
  }
  .nav-menu.open { transform:translateY(0); }
  .nav-menu > li { width:100%; }
  .nav-menu .nav-link { display:block; padding:.85rem 0; font-size:1rem; }
  .nav-menu .btn-cta { justify-content:center; margin-top:.75rem; }
  .nav-dropdown::after { display:none; }
  /* Dropdown vira acordeao: fechado por padrao, abre ao tocar em "Produtos" */
  .dropdown-menu {
    position:static; transform:none; box-shadow:none; border:none; background:transparent;
    min-width:0; padding:0 0 0 1rem; opacity:0; visibility:hidden; pointer-events:none;
    max-height:0; overflow:hidden; transition:max-height .3s ease, opacity .2s ease;
  }
  .nav-dropdown.open .dropdown-menu {
    transform:none; opacity:1; visibility:visible; pointer-events:auto; max-height:320px; padding:.25rem 0 .5rem 1rem;
  }
  .dropdown-item { padding:.7rem .5rem; font-size:.95rem; }
}
/* Tablets (retrato): reduz folgas grandes do hero/seções */
@media (max-width:1024px) {
  .hero-inner { gap:3rem; }
}

@media (max-width:768px) {
  .container { padding:0 1.5rem; }
  .hero-inner, .product-row, .why-inner, .footer-grid { grid-template-columns:1fr; gap:3rem; }
  .product-row.reverse { direction:ltr; }
  .hero-visual, .why-numbers { display:none; }
  .hero-sub { max-width:none; }
  .hero-actions { gap:.75rem; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .pillars { grid-template-columns:1fr; }
  .cta-inner { padding:3rem 1.5rem; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2.5rem; }
  .browser-mockup { transform:none !important; }
  .testimonials-grid { grid-template-columns:1fr; }
  .process-grid { grid-template-columns:1fr 1fr; }
  .contact-grid { grid-template-columns:1fr; gap:2.5rem; }
  .wpp-float { width:54px; height:54px; bottom:18px; right:18px; }
  .cookie-banner { flex-direction:column; align-items:stretch; text-align:center; left:12px; right:12px; bottom:12px; }
  .cookie-actions { justify-content:center; }
  .custom-solutions { padding:3rem 1.5rem; margin-top:3.5rem; border-radius:22px; }
  .cs-cta { width:100%; justify-content:center; }
}
@media (max-width:480px) {
  .container { padding:0 1.2rem; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .cta-contact-row { gap:1.5rem; }
  .process-grid { grid-template-columns:1fr; }
  .hero-actions { flex-direction:column; align-items:stretch; }
  .btn-hero-primary, .btn-hero-secondary { justify-content:center; }
  .hero-trust-badges { flex-wrap:wrap; }
}
