:root{
  --nsoft-purple:#7030A0;
  --nsoft-purple-2:#8a44c5;
  --nsoft-ink:#101114;
  --nsoft-bg:#ffffff;
  --nsoft-muted:#f6f6f9;
  --nsoft-border:#ececf2;

  --radius:20px;
  --shadow-sm: 0 10px 26px rgba(0,0,0,.08);
  --shadow-md: 0 18px 44px rgba(0,0,0,.12);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:var(--nsoft-bg);
  color:var(--nsoft-ink);
}
a{ color:inherit; }
.container{ width:min(1160px, 92%); margin:0 auto; }

h1,h2,h3{ letter-spacing:-0.02em; }
h2{ margin:0 0 10px 0; font-size:26px; }
.lead{
  margin:0;
  color:rgba(16,17,20,.70);
  line-height:1.75;
  max-width:82ch;
}

/* Header (navbar melhor + logo maior + WhatsApp branco) */
header{
  position: sticky;
  top:0;
  z-index:50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--nsoft-border);
}
.topbar{
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 0; gap:18px;
}
.brand{
  display:flex; align-items:center; gap:14px;
  text-decoration:none;
}
.brand img{
  height:48px; /* LOGO MAIOR */
  width:auto;
  display:block;
}
.brand strong{
  letter-spacing:.3px;
  font-size:18px;
}
.nav{ display:flex; gap:22px; flex-wrap:wrap; align-items:center; }
.nav a{
  text-decoration:none;
  color:rgba(16,17,20,.62);
  font-weight:750;
}
.nav a:hover{ color:var(--nsoft-purple); }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius: 999px;
  border:1px solid var(--nsoft-border);
  background:#fff;
  text-decoration:none;
  font-weight:750;
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
}
.btn-primary{
  border-color: rgba(112,48,160,.25);
  background: linear-gradient(135deg, rgba(112,48,160,1), rgba(138,68,197,1));
  color:#fff !important; /* garante branco */
  box-shadow: 0 18px 36px rgba(112,48,160,.22);
}
.btn-primary:hover{ filter: brightness(1.03); }
.btn-ghost:hover{ border-color: rgba(112,48,160,.35); color:var(--nsoft-purple); }

main{ padding-bottom: 40px; }
.section{ padding: 62px 0; }
.muted{
  background: var(--nsoft-muted);
  border-top:1px solid var(--nsoft-border);
  border-bottom:1px solid var(--nsoft-border);
}

/* Hero */
.hero{
  padding: 64px 0 36px 0;
  background:
    radial-gradient(900px 380px at 18% 6%, rgba(112,48,160,.16), transparent 55%),
    radial-gradient(750px 320px at 88% 18%, rgba(120,120,120,.10), transparent 55%);
}
.hero-grid{
  display:grid; grid-template-columns: 1.15fr .85fr;
  gap: 30px; align-items:center;
}
.kicker{
  color: var(--nsoft-purple);
  font-weight:850;
  letter-spacing:.14em;
  text-transform: uppercase;
  font-size: 12px;
}
h1{
  margin: 12px 0 12px 0;
  font-size: clamp(32px, 4.2vw, 48px);
  line-height: 1.05;
}
.sub{
  margin: 0 0 18px 0;
  color: rgba(16,17,20,.70);
  font-size: 16px;
  line-height: 1.75;
  max-width: 62ch;
}
.hero-actions{ display:flex; gap:12px; flex-wrap:wrap; align-items:center; }

.hero-card{
  border:1px solid var(--nsoft-border);
  border-radius: var(--radius);
  background:#fff;
  box-shadow: var(--shadow-sm);
  padding: 18px;
}
.hero-card .row{
  display:flex; gap:12px; align-items:flex-start;
  padding: 12px 0;
  border-bottom:1px solid var(--nsoft-border);
}
.hero-card .row:last-child{ border-bottom:none; }
.pill{
  width:36px; height:36px; border-radius: 14px;
  background: rgba(112,48,160,.12);
  border: 1px solid rgba(112,48,160,.22);
  display:flex; align-items:center; justify-content:center;
  font-weight:900;
  color: var(--nsoft-purple);
  flex: 0 0 auto;
}
.row b{ display:block; }
.row span{ color:rgba(16,17,20,.62); font-size: 13px; line-height: 1.5; display:block; margin-top:2px; }

/* Material Symbols */
.material-symbols-rounded{
  font-variation-settings: 'FILL' 1, 'wght' 600, 'GRAD' 0, 'opsz' 24;
}

/* Suite */
.suite-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.suite-item{
  border:1px solid var(--nsoft-border);
  border-radius: var(--radius);
  background:#fff;
  padding: 16px;
  text-decoration:none;
  box-shadow: 0 12px 34px rgba(0,0,0,.07);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
  position:relative;
  overflow:hidden;
}
.suite-item::before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(520px 140px at 12% 0%, rgba(112,48,160,.18), transparent 60%),
    radial-gradient(460px 140px at 92% 0%, rgba(120,120,120,.10), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.suite-item:hover{
  transform: translateY(-3px);
  border-color: rgba(112,48,160,.28);
  box-shadow: var(--shadow-md);
}
.suite-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  position:relative;
}
.suite-icon{
  width:54px; height:54px;
  border-radius: 18px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, rgba(112,48,160,1), rgba(138,68,197,1));
  box-shadow: 0 18px 30px rgba(112,48,160,.22);
  flex: 0 0 auto;
  color:#fff;
}
.suite-icon .material-symbols-rounded{ font-size: 26px; }

.suite-title{
  margin: 14px 0 6px 0;
  font-size: 16px;
  position:relative;
}
.suite-desc{
  margin:0;
  font-size: 13px;
  color: rgba(16,17,20,.62);
  line-height: 1.55;
  position:relative;
}

/* Cards */
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.card{
  border:1px solid var(--nsoft-border);
  border-radius: var(--radius);
  background:#fff;
  padding:18px;
  box-shadow: 0 10px 26px rgba(0,0,0,.07);
}
.card h3{ margin: 10px 0 8px 0; font-size: 16px; }
.card p{ margin: 0; color: rgba(16,17,20,.65); font-size: 13px; line-height: 1.65; }
.icon{
  width:48px; height:48px; border-radius: 18px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900;
  color:#fff;
  background: linear-gradient(135deg, rgba(112,48,160,1), rgba(138,68,197,1));
  box-shadow: 0 16px 28px rgba(112,48,160,.18);
}

/* Footer */
footer{ margin-top:56px; border-top:1px solid var(--nsoft-border); padding: 28px 0; color: rgba(16,17,20,.62); }
.foot-grid{ display:grid; grid-template-columns: 1.2fr 1fr; gap:18px; }
.legal{ font-size:14px; line-height:1.65; }
.small{ font-size:12px; color: rgba(16,17,20,.58); }

@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .suite-grid{ grid-template-columns: repeat(2, 1fr); }
  .grid-3{ grid-template-columns: 1fr; }
  .foot-grid{ grid-template-columns:1fr; }
}
@media (max-width: 520px){
  .suite-grid{ grid-template-columns: 1fr; }
}