:root{
  --ns-primary:#0b2a4a;
  --ns-accent:#4f8cff;
  --ns-soft:#f5f7ff;
  --ns-dark:#061727;
}

html{scroll-behavior:smooth;}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
  color: #0f172a;
}

.navbar{
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.navbar-brand .logo-dot{
  display:inline-block; width:10px; height:10px; border-radius:999px;
  background: var(--ns-accent); margin-left:6px;
}

.hero{
  position:relative;
  overflow:hidden;
  background: radial-gradient(1200px 600px at 10% 10%, rgba(79,140,255,.35), transparent 60%),
              radial-gradient(900px 500px at 90% 15%, rgba(255,255,255,.18), transparent 60%),
              linear-gradient(135deg, var(--ns-primary), var(--ns-dark));
  color:#fff;
}

.hero .badge{
  border:1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.10);
}

.hero-illustration{
  max-width: 520px;
  width: 100%;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  box-shadow: 0 24px 70px rgba(0,0,0,.32);
}

.section-title{
  letter-spacing: .4px;
}

.kpi{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 12px 34px rgba(2,8,23,.06);
}

.service-card{
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 20px;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  background:#fff;
  height:100%;
}

.service-card:hover{
  transform: translateY(-4px);
  border-color: rgba(79,140,255,.35);
  box-shadow: 0 18px 50px rgba(2,8,23,.10);
}

.service-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(79,140,255,.12);
  border: 1px solid rgba(79,140,255,.18);
}

.service-icon img{
  width: 26px;
  height: 26px;
}

.soft-section{
  background: linear-gradient(180deg, var(--ns-soft), #ffffff);
}

.process-step{
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 18px;
  background: #fff;
  height:100%;
}

footer{
  background: #07192b;
  color: rgba(255,255,255,.78);
}

footer a{color: rgba(255,255,255,.9); text-decoration:none;}
footer a:hover{color:#fff; text-decoration:underline;}

.floating-actions{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 999;
  display:flex;
  gap:10px;
  flex-direction: column;
}

.floating-actions a{
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: 0 18px 40px rgba(2,8,23,.20);
  border: 1px solid rgba(255,255,255,.12);
}

.action-call{ background: #0ea5e9; }
.action-wa{ background: #22c55e; }

.action-call svg, .action-wa svg{ width: 22px; height: 22px; fill:#fff; }

.form-control, .form-select{
  border-radius: 14px;
  padding: .75rem .9rem;
}

.btn{
  border-radius: 14px;
  padding: .75rem 1rem;
}
