/* ===========================
   VARIABLES / PALETA
   =========================== */
:root{
  --primary: #0078D7;    /* azul vivo principal */
  --secondary: #55A5E4;  /* azul claro */
  --dark: #002847;       /* azul oscuro */
  --accent: #FF8A00;     /* naranja acento */
  --bg: #ffffff;
  --muted: #6b7280;
  --radius: 14px;
  --container: 1180px;
  --shadow-1: 0 6px 18px rgba(2,8,23,0.08);
  --shadow-2: 0 12px 30px rgba(2,8,23,0.10);
}

/* ===========================
   RESET / BASE
   =========================== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: "Inter", "Segoe UI", system-ui, -apple-system, Roboto, "Helvetica Neue", Arial;
  color:#0b1220;
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}

/* container */
.wrap{
  width:90%;
  max-width:var(--container);
  margin:0 auto;
}

/* ===========================
   HEADER / NAV
   =========================== */
.site-header{
  position:sticky;
  top:0;
  z-index:60;
  background: linear-gradient(90deg, rgba(0,40,71,0.95), rgba(0,40,71,0.98));
  padding:14px 0;
  box-shadow: 0 3px 8px rgba(0,0,0,0.12);
}

.site-header .wrap{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
}

.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:#fff; }
.brand-icon{ width:36px; height:36px; display:block; filter:drop-shadow(0 2px 4px rgba(0,0,0,0.15)); }
.brand-text{ font-weight:700; font-size:1.1rem; letter-spacing:0.4px; }

.nav ul{ list-style:none; display:flex; gap:22px; margin:0; padding:0; align-items:center; }
.nav a{
  color: #e6f2ff;
  text-decoration:none;
  padding:10px 8px;
  border-radius:8px;
  font-weight:600;
  transition: all .18s ease;
}
.nav a:hover{ color:var(--dark); background: linear-gradient(90deg,var(--secondary),#88c5f6) ; transform: translateY(-2px); }

/* hamburger */
.menu-btn{
  display:none;
  background:transparent;
  border:0; color:#fff; font-size:1.25rem; cursor:pointer;
}

/* ===========================
   HERO
   =========================== */
.hero{
  padding:60px 0;
  background:
    radial-gradient(400px 200px at 10% 20%, rgba(85,165,228,0.06), transparent 12%),
    linear-gradient(180deg, rgba(0,120,215,0.06), rgba(85,165,228,0.02));
}
.hero-grid{
  display:grid;
  grid-template-columns: 1fr 420px;
  gap:28px;
  align-items:center;
}
.hero-content h1{
  font-size:clamp(1.6rem, 2.4vw, 2.6rem);
  margin:0 0 12px;
  color:var(--dark);
}
.lead{ color:var(--muted); margin-bottom:18px; font-size:1.05rem; }

.hero-ctas{ display:flex; gap:12px; flex-wrap:wrap; }

/* hero card */
.hero-card{
  background:linear-gradient(180deg, #fff, #f7fbff);
  border-radius:var(--radius);
  box-shadow:var(--shadow-2);
  padding:12px;
  position:relative;
  overflow:hidden;
  transform:translateY(6px);
}
.hero-card img{ width:100%; height:260px; object-fit:cover; border-radius:10px; display:block; }
.chip{
  position:absolute;
  left:14px; bottom:14px;
  background: rgba(0,40,71,0.9);
  color:#fff;
  padding:8px 12px;
  border-radius:999px;
  font-weight:600;
  font-size:0.9rem;
  display:inline-flex;
  gap:8px;
  align-items:center;
}

/* CTA buttons */
.btn{
  text-decoration:none;
  display:inline-flex;
  gap:10px;
  align-items:center;
  padding:10px 16px;
  border-radius:10px;
  font-weight:700;
  transition: transform .16s ease, box-shadow .16s ease;
}
.btn-primary{
  background: linear-gradient(90deg,var(--primary),var(--secondary));
  color:#fff;
  box-shadow: 0 8px 22px rgba(0,120,215,0.14);
}
.btn-primary:hover{ transform: translateY(-4px); box-shadow: 0 18px 40px rgba(0,120,215,0.18); }
.btn-outline{
  background:transparent;
  color:var(--primary);
  border:2px solid rgba(0,120,215,0.14);
}

/* ===========================
   SECTIONS
   =========================== */
.section{ padding:64px 0; }
.section.alt{ background: linear-gradient(180deg, #fbfdff, #fff); }

.section-title{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  color:var(--dark);
  font-size:1.45rem;
  margin-bottom:28px;
}
.section-title i{ color:var(--primary); }

/* cards grid */
.cards-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:20px;
}
.cards-grid.lg-3{ grid-template-columns: repeat(3, 1fr); }

/* card */
.card{
  background: #fff;
  border-radius:14px;
  padding:20px;
  box-shadow:var(--shadow-1);
  transition: transform .28s cubic-bezier(.2,.9,.3,1), box-shadow .28s;
  min-height:150px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.card:hover{ transform: translateY(-12px); box-shadow: var(--shadow-2); }
.card-icon{
  width:56px; height:56px;
  display:inline-grid; place-items:center;
  background: linear-gradient(180deg,var(--secondary),var(--primary));
  color:#fff; border-radius:10px; font-size:1.15rem;
  box-shadow: 0 6px 18px rgba(0,120,215,0.12);
}
.card h3{ margin:0; color:var(--dark); }
.card p{ margin:0; color:var(--muted); font-size:0.96rem; }
.card .link{ margin-top:auto; color:var(--primary); font-weight:700; text-decoration:none; }

/* MEDIA FOR CONTENT IMAGES */
.media img{ width:100%; height:160px; object-fit:cover; border-radius:10px; }

/* pills */
.pill{
  display:inline-block;
  margin-top:10px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(85,165,228,0.12);
  color:var(--dark);
  font-weight:600;
  font-size:0.85rem;
}

/* ===========================
   TEAM
   =========================== */
.team-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:18px;
}
.team-card{
  text-align:center;
  padding:18px;
  border-radius:12px;
  background:linear-gradient(180deg,#fff,#fbfdff);
  box-shadow:var(--shadow-1);
}
.team-card img{ width:120px; height:120px; object-fit:cover; border-radius:50%; margin-bottom:12px; border:6px solid rgba(85,165,228,0.12); }

/* ===========================
   CTA / CONTACT
   =========================== */
.cta-section{ padding:64px 0; background:linear-gradient(180deg,#f6fbff,#fff); }
.cta-grid{ display:grid; grid-template-columns: 1fr 420px; gap:28px; align-items:center; }
.cta-card{ padding:28px; border-radius:16px; background:linear-gradient(180deg,#fff,#f7fbff); box-shadow:var(--shadow-2); }
.cta-card h2{ margin:0 0 8px; color:var(--dark); }
.benefits{ list-style:none; padding:0; margin:12px 0 18px; color:var(--muted); }
.benefits li{ margin:8px 0; display:flex; gap:10px; align-items:center; }
.benefits li i{ color:var(--accent); background:#fff; border-radius:6px; padding:6px; box-shadow:0 4px 12px rgba(255,138,0,0.08); }

/* CTA visual */
.cta-visual img{ width:100%; border-radius:12px; box-shadow:var(--shadow-1); }

/* ===========================
   FOOTER
   =========================== */
.footer {
  padding: 20px 0;
  background: var(--dark);
  color: #dbeafe;
  text-align: center;
}

.footer-grid {
  display: flex;
  justify-content: center; /* centra horizontalmente */
  align-items: center;
  gap: 20px;
}

/* ===========================
   ANIMATIONS / REVEAL
   =========================== */
.card-animate{ opacity:0; transform: translateY(18px) scale(.995); transition: all .7s cubic-bezier(.2,.9,.3,1); }
.card-animate.in-view{ opacity:1; transform: translateY(0) scale(1); }

/* small elements */
.kicker{ color:var(--secondary); font-weight:700; font-size:0.9rem; }

/* ===========================
   RESPONSIVE
   =========================== */
@media (max-width:1100px){
  .hero-grid{ grid-template-columns: 1fr 360px; }
  .cards-grid{ grid-template-columns: repeat(2, 1fr); }
  .team-grid{ grid-template-columns: repeat(2, 1fr); }
  .cta-grid{ grid-template-columns: 1fr; }
  .wrap{ width:94%; }
}
@media (max-width:760px){
  .site-header .wrap{ gap:8px; }
  .nav{ display:none; }
  .menu-btn{ display:block; color:#fff; }

  /* open nav */
  .nav.open{ display:block; position:absolute; right:14px; top:64px; background:linear-gradient(180deg,#003a6b,#001f3a); padding:12px; border-radius:8px; box-shadow:var(--shadow-2); }
  .nav.open ul{ display:flex; flex-direction:column; gap:8px; }
  .nav.open a{ color:#fff; padding:8px 12px; }

  .hero-grid{ grid-template-columns:1fr; gap:18px; }
  .cards-grid{ grid-template-columns: 1fr; }
  .team-grid{ grid-template-columns: 1fr; }
  .brand-text{ display:none; }
  .hero-card img{ height:220px; }
}
