:root{
  --azul:#118e9c;
  --azul-2:#2d90ff;
  --amarelo:#f6e28b;
  --rosa:#e9678c;
  --lilas:#a88bff;
  --menta:#7ee6d4;

  --fundo:#fbfcff;
  --card:#ffffff;
  --cinza:#f3f6fb;
  --borda:#e9edf5;

  --texto:#1f2d3d;
  --texto-2:#4a5b6d;

  --shadow:0 18px 40px rgba(23,32,42,.10);
  --shadow-soft:0 10px 25px rgba(23,32,42,.08);

  --radius:22px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--fundo);
  color:var(--texto);
}

.container{
  width:min(1120px,92%);
  margin:0 auto;
}

a{color:inherit}
small{color:var(--texto-2)}

/* =========================
   NAVBAR
========================= */
.navbar{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(251,252,255,.85);
  border-bottom:1px solid var(--borda);
  backdrop-filter:blur(10px);
}

.navbar .inner{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:900;
  text-decoration:none;
  color:inherit;
}

.brand .name{
  display:flex;
  flex-direction:column;
  line-height:1.05;
}
.brand .name strong{font-size:16px}
.brand .name small{font-size:12px}

.logo{
  height:64px;
  background:#fff;
  padding:6px;
  border-radius:12px;
  box-shadow:0 8px 20px rgba(0,0,0,.08);
}

/* menu desktop */
.menu{
  display:flex;
  align-items:center;
  gap:8px;
}

.menu a{
  padding:10px 12px;
  border-radius:999px;
  text-decoration:none;
  border:1px solid transparent;
}

.menu a:hover{
  background:rgba(17,142,156,.12);
  border-color:rgba(17,142,156,.22);
}

/* botão menu (puzzle) */
.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid var(--borda);
  background:rgba(255,255,255,.92);
  box-shadow:var(--shadow-soft);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  z-index:1001;
}

.puzzle-icon{
  width:26px;
  height:26px;
  display:block;
  object-fit:contain;
  transition:transform .25s ease,filter .25s ease;
}


.nav-toggle:hover .puzzle-icon{
  transform:scale(1.08);
  filter:brightness(1.05);
}

.navbar.open .puzzle-icon{
  transform:rotate(90deg) scale(1.05);
}

/* =========================
   HERO
========================= */
.hero{
  position:relative;
  overflow:hidden;
  padding:62px 0 34px;
  background:
    radial-gradient(900px 380px at 15% 10%, rgba(233,103,140,.22), transparent 60%),
    radial-gradient(900px 380px at 85% 10%, rgba(17,142,156,.18), transparent 60%),
    linear-gradient(180deg,#fff,var(--fundo));
  border-bottom:1px solid var(--borda);
}

.hero .grid-hero{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:26px;
  align-items:center;
}

.hero h1{
  font-size:clamp(28px,3.2vw,44px);
  margin-bottom:10px;
}

.hero p{
  color:var(--texto-2);
  line-height:1.55;
  margin-bottom:18px;
}

.actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.btn{
  padding:12px 16px;
  border-radius:999px;
  font-weight:800;
  text-decoration:none;
  box-shadow:var(--shadow-soft);
}

.btn.primary{
  background:linear-gradient(135deg,var(--azul),var(--menta));
  color:#fff;
}

.btn.secondary{
  background:#fff;
  border:1px solid var(--borda);
}

/* =========================
   SEÇÕES
========================= */
.section{padding:46px 0}
.section h2{font-size:28px;margin-bottom:10px}
.section p{color:var(--texto-2)}

.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}

.card{
  background:#fff;
  border:1px solid var(--borda);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:var(--shadow-soft);
}

.icon{
  width:42px;
  height:42px;
  border-radius:16px;
  display:grid;
  place-items:center;
  margin-bottom:10px;
  color:#fff;
  font-weight:900;
}

.icon.c1{background:linear-gradient(135deg,var(--azul),var(--menta))}
.icon.c2{background:linear-gradient(135deg,var(--rosa),var(--amarelo))}
.icon.c3{background:linear-gradient(135deg,var(--lilas),var(--azul-2))}

/* =========================
   FOOTER + FIXOS
========================= */
.footer{
  margin-top:30px;
  padding:22px 0;
  background:rgba(243,246,251,.9);
  border-top:1px solid var(--borda);
}

.footer .container{
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
}

.whats,
.instagram{
  position:fixed;
  right:16px;
  padding:12px 14px;
  border-radius:999px;
  color:#fff;
  font-weight:900;
  text-decoration:none;
  box-shadow:var(--shadow);
  z-index:900;
}

.whats{bottom:16px;background:#25D366}
.instagram{bottom:70px;background:linear-gradient(45deg,#f58529,#dd2a7b,#7f21b6,#1e2575)}

/* =========================
   RESPONSIVO
========================= */
@media (max-width:980px){
  .hero .grid-hero{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .logo{height:56px}
}

@media (max-width:860px){
  .nav-toggle{display:inline-flex}

  .brand .name small{display:none}

  .menu{
    position:absolute;
    left:4%;
    right:4%;
    top:calc(100% + 10px);
    display:none;
    flex-direction:column;
    gap:8px;
    padding:12px;
    background:rgba(255,255,255,.97);
    border:1px solid var(--borda);
    border-radius:18px;
    box-shadow:var(--shadow);
    z-index:1000;
  }

  .menu a{
    padding:12px;
    border-radius:14px;
    background:rgba(243,246,251,.9);
  }

  .navbar.open .menu{display:flex}
}
