*{
  margin:0;
  padding:0;
  box-sizing:border-box;
  font-family:'Inter', sans-serif;
}

body{
  background:#0f172a;
  overflow-x:hidden;
}

.hero-gradient{
  background:
  radial-gradient(circle at top left, rgba(108,99,255,.35), transparent 35%),
  radial-gradient(circle at bottom right, rgba(108,99,255,.20), transparent 30%),
  #0f172a;
}

.glass{
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(15px);
  border:1px solid rgba(255,255,255,0.08);
}

.glow{
  box-shadow: 0 0 40px rgba(108,99,255,.35);
}

.float{
  animation: float 4s ease-in-out infinite;
}

@keyframes float{

  0%{
    transform: translateY(0px);
  }

  50%{
    transform: translateY(-12px);
  }

  100%{
    transform: translateY(0px);
  }

}

.btn-primary{
  background:#6c63ff;
  transition:.3s;
}

.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 0 30px rgba(108,99,255,.45);
}

.btn-secondary{
  border:1px solid rgba(255,255,255,.15);
  transition:.3s;
}

.btn-secondary:hover{
  background:rgba(255,255,255,.05);
} 

/* BENEFITS */

.benefit-card{
  transition:.4s;
  position:relative;
  overflow:hidden;
}

.benefit-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    135deg,
    rgba(108,99,255,.12),
    transparent
  );
  opacity:0;
  transition:.4s;
}

.benefit-card:hover{
  transform:translateY(-10px);
  border:1px solid rgba(108,99,255,.35);
  box-shadow:0 0 40px rgba(108,99,255,.18);
}

.benefit-card:hover::before{
  opacity:1;
}

.icon-box{
  width:70px;
  height:70px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(108,99,255,.15);
  border:1px solid rgba(108,99,255,.25);
  font-size:32px;
} 

/* MODULES */

.module-card{
  position:relative;
  overflow:hidden;
  transition:.4s;
}

.module-card:hover{
  transform:translateY(-10px);
  border:1px solid rgba(108,99,255,.35);
  box-shadow:0 0 50px rgba(108,99,255,.18);
}

.module-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(
    135deg,
    rgba(108,99,255,.12),
    transparent
  );
  opacity:0;
  transition:.4s;
}

.module-card:hover::before{
  opacity:1;
}

.module-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.module-icon{
  width:70px;
  height:70px;
  border-radius:20px;
  background:rgba(108,99,255,.15);
  border:1px solid rgba(108,99,255,.25);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:32px;
}

.module-tag{
  background:rgba(108,99,255,.12);
  color:#6c63ff;
  padding:10px 18px;
  border-radius:999px;
  font-size:14px;
  border:1px solid rgba(108,99,255,.2);
}

/* FINANCEIRO */

.module-preview{
  background:#111827;
  border-radius:24px;
  padding:30px;
}

.mini-chart{
  display:flex;
  align-items:flex-end;
  gap:12px;
  height:180px;
}

.chart-bar{
  flex:1;
  border-radius:14px 14px 0 0;
  background:#6c63ff;
}

/* CHAT */

.chat-preview{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.chat-message{
  padding:18px 22px;
  border-radius:20px;
  width:max-content;
  max-width:80%;
  font-weight:500;
}

.chat-message.left{
  background:#111827;
  color:white;
}

.chat-message.right{
  background:#6c63ff;
  color:white;
  margin-left:auto;
}

/* MORADOR */

.resident-preview{
  display:flex;
  flex-direction:column;
  gap:18px;
}

.resident-item{
  height:80px;
  border-radius:20px;
  background:#111827;
}

/* DASHBOARD */

.dashboard-preview{
  display:flex;
  align-items:center;
  gap:30px;
  margin-top:20px;
}

.dashboard-circle{
  width:120px;
  height:120px;
  border-radius:50%;
  background:conic-gradient(
    #6c63ff 0%,
    #6c63ff 70%,
    #1f2937 70%
  );
}

.dashboard-lines{
  flex:1;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.dashboard-lines div{
  height:18px;
  border-radius:999px;
  background:#111827;
}

/* PLATFORM */

.platform-item{
  display:flex;
  gap:20px;
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}

.platform-item span{
  width:46px;
  height:46px;
  border-radius:14px;
  background:rgba(108,99,255,.16);
  color:#6c63ff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
}

.platform-item h3{
  color:#fff;
  font-size:20px;
  font-weight:800;
}

.platform-item p{
  color:#9ca3af;
  margin-top:6px;
}

.product-window{
  border-radius:32px;
  overflow:hidden;
  background:rgba(255,255,255,.05);
}

.window-top{
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.window-top p{
  color:#9ca3af;
  font-size:14px;
}

.window-dots{
  display:flex;
  gap:8px;
}

.window-dots span{
  width:12px;
  height:12px;
  border-radius:50%;
  background:#6c63ff;
  opacity:.8;
}

.product-body{
  display:grid;
  grid-template-columns:90px 1fr;
  min-height:430px;
}

.fake-sidebar{
  background:#0f172a;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:18px;
}

.fake-sidebar div{
  width:42px;
  height:42px;
  border-radius:14px;
  background:#6c63ff;
}

.fake-sidebar span{
  height:14px;
  border-radius:999px;
  background:#1f2937;
}

.fake-content{
  padding:28px;
}

.fake-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
}

.fake-header h3{
  color:#fff;
  font-weight:800;
  font-size:24px;
}

.fake-header p{
  color:#9ca3af;
  margin-top:4px;
}

.fake-header button{
  background:#6c63ff;
  color:#fff;
  padding:10px 16px;
  border-radius:14px;
  font-weight:700;
}

.fake-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  margin-top:30px;
}

.fake-stats div{
  background:#111827;
  border-radius:20px;
  padding:22px;
}

.fake-stats strong{
  color:#fff;
  font-size:30px;
  display:block;
}

.fake-stats small{
  color:#9ca3af;
}

.fake-table{
  margin-top:26px;
  background:#111827;
  border-radius:22px;
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.fake-table span{
  height:18px;
  border-radius:999px;
  background:#1f2937;
}

.phone-mockup{
  position:absolute;
  right:-35px;
  bottom:-70px;
  width:210px;
  border-radius:34px;
  padding:22px;
  background:rgba(15,23,42,.92);
  border:1px solid rgba(108,99,255,.28);
}

.phone-notch{
  width:70px;
  height:8px;
  border-radius:999px;
  background:#1f2937;
  margin:0 auto 22px;
}

.phone-mockup h4{
  color:#fff;
  font-weight:800;
  margin-bottom:18px;
}

.phone-card{
  height:90px;
  border-radius:20px;
  background:linear-gradient(135deg,#6c63ff,#8b5cf6);
  margin-bottom:14px;
}

.phone-card.small{
  height:58px;
  background:#111827;
}

.phone-mockup button{
  width:100%;
  background:#6c63ff;
  color:#fff;
  border-radius:16px;
  padding:12px;
  font-size:13px;
  font-weight:800;
  margin-top:6px;
}

html{
  scroll-behavior:smooth;
} 

/* PLANS */

.plan-card{
  transition:.4s;
  position:relative;
}

.plan-card:hover{
  transform:translateY(-10px);
  border-color:rgba(108,99,255,.35);
  box-shadow:0 0 50px rgba(108,99,255,.18);
}

.plan-card h3{
  color:#fff;
  font-size:28px;
  font-weight:900;
}

.plan-card p{
  color:#9ca3af;
  margin-top:16px;
  min-height:72px;
}

.plan-card strong{
  display:block;
  color:#fff;
  font-size:28px;
  margin-top:28px;
}

.plan-card ul{
  color:#cbd5e1;
  margin-top:28px;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.plan-card li::before{
  content:'✓ ';
  color:#6c63ff;
  font-weight:900;
}

.plan-card a{
  display:block;
  text-align:center;
  margin-top:32px;
  padding:16px;
  border-radius:18px;
  background:#6c63ff;
  color:#fff;
  font-weight:800;
}

.plan-featured{
  border:1px solid rgba(108,99,255,.45);
  box-shadow:0 0 50px rgba(108,99,255,.16);
}

.featured-label{
  display:inline-block;
  color:#fff;
  background:#6c63ff;
  padding:8px 14px;
  border-radius:999px;
  font-size:13px;
  font-weight:800;
  margin-bottom:20px;
}

/* CONTACT */

.whatsapp-btn{
  display:inline-flex;
  margin-top:34px;
  padding:18px 26px;
  border-radius:18px;
  background:#22c55e;
  color:#fff;
  font-weight:900;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  background:#111827;
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  border-radius:18px;
  padding:18px;
  outline:none;
}

.contact-form input:focus,
.contact-form textarea:focus{
  border-color:#6c63ff;
  box-shadow:0 0 0 4px rgba(108,99,255,.12);
}

.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:16px;
}

.contact-form textarea{
  min-height:150px;
  resize:none;
}

.contact-form button{
  width:100%;
  margin-top:18px;
  padding:18px;
  border-radius:18px;
  background:#6c63ff;
  color:#fff;
  font-weight:900;
  transition:.3s;
}

.contact-form button:hover{
  transform:translateY(-3px);
  box-shadow:0 0 30px rgba(108,99,255,.35);
}

@media(max-width:768px){
  .form-grid{
    grid-template-columns:1fr;
  }
}

/* FINAL CTA + FOOTER */

.final-cta{
  position:relative;
  overflow:hidden;
}

.final-cta::before{
  content:'';
  position:absolute;
  inset:-80px;
  background:radial-gradient(circle, rgba(108,99,255,.25), transparent 60%);
  z-index:-1;
}

.footer-premium{
  padding:80px 0 30px;
  background:#070b16;
  border-top:1px solid rgba(108,99,255,.18);
}

.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
}

.footer-grid h3{
  color:#fff;
  font-size:22px;
  font-weight:900;
}

.footer-grid p{
  color:#8b5cf6;
  font-size:13px;
  margin-top:4px;
}

.footer-text{
  color:#9ca3af !important;
  line-height:1.8;
  margin-top:24px !important;
  max-width:360px;
}

.footer-grid h4{
  color:#fff;
  font-weight:900;
  margin-bottom:18px;
}

.footer-grid a,
.footer-grid span{
  display:block;
  color:#9ca3af;
  margin-bottom:12px;
  transition:.3s;
}

.footer-grid a:hover{
  color:#6c63ff;
  transform:translateX(4px);
}

.footer-bottom{
  margin-top:60px;
  padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}

.footer-bottom p,
.footer-bottom a{
  color:#9ca3af;
  font-size:14px;
}

.footer-bottom a:hover{
  color:#6c63ff;
}

@media(max-width:900px){
  .footer-grid{
    grid-template-columns:1fr 1fr;
  }
}

@media(max-width:600px){
  .footer-grid{
    grid-template-columns:1fr;
  }
}

.nav-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.mobile-menu-btn{
  display:none;
  color:#fff;
  font-size:30px;
  line-height:1;
}

.mobile-menu{
  display:none;
}

@media(max-width:768px){

  body{
    overflow-x:hidden;
  }

  header .max-w-7xl{
    padding-left:14px;
    padding-right:14px;
  }

  header .glass{
    margin-top:16px;
    padding:14px;
  }

  header nav{
    display:none !important;
  }

  .mobile-menu-btn{
    display:block;
    margin-left:auto;
    z-index:10;
  }

  .nav-actions .btn-primary{
    display:none;
  }

  .mobile-menu{
    display:none;
  }

  .mobile-menu.active{
    display:grid;
    grid-template-columns:1fr;
    gap:8px;
    margin-top:10px;
    padding:14px;
    border-radius:20px;
    background:rgba(15,23,42,.96);
    border:1px solid rgba(255,255,255,.10);
    box-shadow:0 20px 50px rgba(0,0,0,.35);
  }

  .mobile-menu a{
    color:#fff;
    font-weight:700;
    padding:14px 16px;
    border-radius:14px;
    background:rgba(255,255,255,.04);
  }

  .mobile-menu a:hover{
    background:rgba(108,99,255,.18);
  }
} 

@media(max-width:768px){

  #plataforma{
    overflow:hidden;
  }

  #plataforma h2{
    font-size:38px;
    line-height:1.08;
  }

  #plataforma .grid{
    grid-template-columns:1fr;
  }

  .product-window{
    max-width:100%;
    overflow:hidden;
  }

  .window-top p{
    max-width:170px;
    overflow:hidden;
    white-space:nowrap;
    text-overflow:ellipsis;
  }

  .product-body{
    grid-template-columns:64px minmax(0,1fr);
  }

  .fake-content{
    min-width:0;
    padding:20px;
  }

  .fake-header{
    flex-direction:column;
    align-items:flex-start;
  }

  .fake-stats{
    grid-template-columns:1fr;
  }

  .phone-mockup{
    position:relative;
    right:auto;
    bottom:auto;
    width:100%;
    margin-top:24px;
  }
}

body{
    background:#070b16 !important;
    color:white;
    overflow-x:hidden;
}

.hero-bg{
    background:
        radial-gradient(circle at top left, rgba(108,99,255,.25), transparent 35%),
        radial-gradient(circle at bottom right, rgba(108,99,255,.18), transparent 35%),
        #070b16;
}