/* =========
   Base / Tokens
   ========= */
:root{
  --bg: #ffffff;
  --text: #141414;
  --muted: #5c5f66;
  --card: #f7f8fa;
  --border: #e4e7ec;
  --primary-start:#d71920;
  --primary-end:#1736f5;
  --radius: 16px;
  --shadow: 0 10px 30px rgba(0,0,0,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Raleway", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.container{
  width:min(1120px, 92vw);
  margin-inline:auto;
}
.narrow{width:min(900px, 92vw)}

/* Acessibilidade: skip to content */
.skip-link{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
.skip-link:focus{
  left:16px; top:16px; width:auto; height:auto; padding:10px 14px; background:#000; color:#fff; border-radius:8px; z-index:9999;
}

/* =========
   Header
   ========= */
.site-header{
  position:sticky; top:0; z-index:1000;
  background:rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border-bottom:1px solid var(--border);
}
.header-inner{
  display:flex; align-items:center; gap:20px;
  padding:12px 0;
}
.brand{display:flex; align-items:center; gap:12px}
.logo{width:44px; height:44px; object-fit:cover; border-radius:10px; box-shadow:var(--shadow)}
.brand-text{display:flex; flex-direction:column; line-height:1.2}
.brand-text .tagline{font-size:.78rem; color:var(--muted); letter-spacing:.4px}

.nav{margin-left:auto}
.nav-list{display:flex; gap:20px; list-style:none; padding:0; margin:0}
.nav-list a{padding:8px 10px; border-radius:10px}
.nav-list a:hover{background:var(--card)}

.cta-desktop{margin-left:8px}

.hamburger{
  display:none; margin-left:8px;
  width:46px; height:42px; border-radius:12px; border:1px solid var(--border);
  background:#fff; cursor:pointer; position:relative;
}
.hamburger span{
  position:absolute; left:10px; right:10px; height:2px; background:#1f2937; transition:.25s;
}
.hamburger span:nth-child(1){top:12px}
.hamburger span:nth-child(2){top:20px}
.hamburger span:nth-child(3){top:28px}
.hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.mobile-nav{
  display:none; border-top:1px solid var(--border); background:#fff;
}
.mobile-nav.open{display:block}
.mobile-nav ul{list-style:none; margin:0; padding:16px}
.mobile-nav li{border-bottom:1px dashed var(--border)}
.mobile-nav li:last-child{border:none}
.mobile-nav a{display:block; padding:12px 4px}

/* =========
   Sections
   ========= */
.section{padding:80px 0}
.section h2{font-size:2rem; margin:0 0 20px}
.prose p{margin:0 0 14px; color:#1f2430}

/* Hero */
.hero{padding:120px 0 90px}
.hero-grid{
  display:grid; grid-template-columns: 1.2fr 1fr; gap:40px; align-items:center;
}
.hero-copy h1{font-size: clamp(2rem, 1.2rem + 2.5vw, 3rem); line-height:1.15; margin:0 0 14px}
.hero-copy p{font-size:1.05rem; color:#2a2f3a; margin:0 0 22px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap}

/* Animated blob */
.hero-visual{position:relative; min-height:300px}
.blob{
  position:absolute; inset:0 auto auto 0;
  width:320px; height:320px;
  background: radial-gradient(120% 120% at 30% 20%, rgba(215,25,32,.9), transparent 60%),
              radial-gradient(120% 120% at 80% 80%, rgba(23,54,245,.9), transparent 60%),
              linear-gradient(135deg, rgba(215,25,32,.85), rgba(23,54,245,.85));
  filter: saturate(110%);
  border-radius: 40% 60% 60% 40% / 40% 50% 50% 60%;
  animation: blob 14s ease-in-out infinite;
  box-shadow: 0 30px 70px rgba(23,54,245,.25), 0 12px 30px rgba(215,25,32,.18);
}
.blob.blur{
  width:360px; height:360px; left:40px; top:30px;
  opacity:.35; filter: blur(30px);
  animation: blob 18s ease-in-out infinite reverse;
}
@keyframes blob{
  0%, 100%{
    transform: translate(0,0) rotate(0deg) scale(1);
    border-radius: 40% 60% 60% 40% / 40% 50% 50% 60%;
  }
  33%{
    transform: translate(10px,-12px) rotate(8deg) scale(1.04);
    border-radius: 55% 45% 50% 50% / 50% 40% 60% 50%;
  }
  66%{
    transform: translate(-12px,10px) rotate(-6deg) scale(0.98);
    border-radius: 45% 55% 40% 60% / 55% 60% 40% 45%;
  }
}

/* Metrics */
.metrics-grid{
  margin-top:26px;
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px;
}
.metric{
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  padding:18px; text-align:center; box-shadow:var(--shadow);
}
.metric-number{display:block; font-size:1.8rem; font-weight:800}
.metric-label{display:block; color:var(--muted)}

/* Cards */
.cards-grid{
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:18px;
}
.card{
  background:#fff; border:1px solid var(--border); border-radius:calc(var(--radius) + 2px);
  padding:22px; box-shadow:var(--shadow);
  display:flex; flex-direction:column; gap:10px;
}
.card h3{margin:0}
.card p{margin:0; color:#2a2f3a}
.card-icon{
  width:48px; height:48px; border-radius:14px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(215,25,32,.1), rgba(23,54,245,.1));
  color:#1f2bf3;
}

/* Features */
.features-grid{
  display:grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap:16px;
}
.feature{
  background:#fff; border:1px solid var(--border); border-radius:calc(var(--radius) + 2px);
  padding:20px; box-shadow:var(--shadow);
}
.feature h3{margin:8px 0 6px}
.feature p{margin:0; color:#2a2f3a}
.feature-icon{
  width:46px; height:46px; border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(215,25,32,.1), rgba(23,54,245,.1));
  color:#1f2bf3;
}

.partners-note{
  margin-top:20px; background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  padding:18px; box-shadow:var(--shadow);
}
.triple-box{
  margin-top:12px;
  display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:12px;
}
.mini-card{
  background:#fff; border:1px solid var(--border); border-radius:12px; padding:14px; text-align:center; font-weight:600;
}

/* Contato */
.contact-intro{max-width:65ch; color:#2a2f3a}
.contact-cta{display:flex; gap:12px; margin:16px 0 22px}

.form{margin-top:10px}
.form-grid{
  display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:16px; margin-bottom:12px;
}
.field{display:flex; flex-direction:column; gap:8px}
.field span{font-weight:600; font-size:.95rem}
.field input, .field textarea{
  border:1px solid var(--border); border-radius:12px; padding:12px 14px; font:inherit; width:100%; background:#fff;
}
.field input:focus, .field textarea:focus{outline:2px solid rgba(23,54,245,.25)}
.field-full{grid-column:1 / -1}
.form-status{min-height:24px; margin-top:8px; color:#0a7f20; font-weight:600}

/* Botões */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:12px 16px; border-radius:14px; font-weight:700; border:1px solid transparent; cursor:pointer; transition:.2s ease;
  user-select:none;
}
.btn.gradient{
  color:#fff; background:linear-gradient(135deg, var(--primary-start), var(--primary-end)); box-shadow:var(--shadow);
}
.btn.gradient:hover{transform: translateY(-1px)}
.btn.ghost{
  border-color:var(--border); background:#fff; color:#1c1f27;
}
.btn.ghost:hover{background:#f9fafb}

/* Footer */
.site-footer{border-top:1px solid var(--border); background:#fff; padding:28px 0; margin-top:20px}
.footer-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap}
.footer-links{display:flex; gap:14px; list-style:none; margin:0; padding:0}
.footer-links a{padding:6px 8px; border-radius:8px}
.footer-links a:hover{background:var(--card)}

/* =========
   Responsividade
   ========= */
@media (max-width: 1024px){
  .hero-grid{grid-template-columns: 1fr; gap:24px}
  .hero-visual{min-height:260px}
  .metrics-grid{grid-template-columns:1fr 1fr}
  .features-grid{grid-template-columns:1fr 1fr}
}

@media (max-width: 768px){
  .nav{display:none}
  .cta-desktop{display:none}
  .hamburger{display:block}
  .section{padding:64px 0}
  .cards-grid{grid-template-columns:1fr}
  .metrics-grid{grid-template-columns:1fr}
  .features-grid{grid-template-columns:1fr}
  .triple-box{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .hero{padding-top:108px}
}

/* =========
   Ajustes de ancoragem para header fixo
   ========= */
:target{scroll-margin-top: 96px;}


/* Parceiros */
.partners-grid{
  margin-top:24px;
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap:20px;
  align-items:center;
  justify-items:center;
}
.partner-logo img{
  max-height:80px;
  width:auto;
  object-fit:contain;
  filter: grayscale(0%);
  transition: transform 0.2s ease, filter 0.2s ease;
}
.partner-logo:hover img{
  transform: scale(1.05);
  filter: grayscale(0%);
}


/* Parceiros */
.partners-intro{max-width:65ch; color:#2a2f3a; margin-bottom:12px}
.partners-grid{
  display:grid; grid-template-columns: repeat(5, minmax(0,1fr));
  gap:18px; align-items:center; justify-items:center;
}
.partner{
  display:flex; align-items:center; justify-content:center;
  background:#fff; border:1px solid var(--border); border-radius:12px;
  padding:14px; width:100%; height:100%; min-height:90px;
  transition: transform .15s ease, box-shadow .15s ease;
  box-shadow: var(--shadow);
}
.partner:hover{transform: translateY(-2px)}
.partner img{max-height:46px; width:auto; height:auto; filter: saturate(100%);}

/* Responsivo para Parceiros */
@media (max-width: 1024px){
  .partners-grid{grid-template-columns: repeat(3, minmax(0,1fr));}
}
@media (max-width: 768px){
  .partners-grid{grid-template-columns: repeat(2, minmax(0,1fr));}
  .partner img{max-height:40px}
}
