*{box-sizing:border-box}
:root{
  --bg:#04130f;
  --surface:rgba(9,29,22,.86);
  --border:rgba(255,255,255,.06);
  --text:#eef9f3;
  --muted:#a7bcb3;
  --primary:#53f090;
  --primary-2:#1ddc6b;
  --shadow:0 20px 60px rgba(0,0,0,.38);
  --radius:26px;
}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
}
.bg-grid{
  position:fixed; inset:0; z-index:-3;
  background:
    linear-gradient(rgba(83,240,144,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(83,240,144,.05) 1px, transparent 1px);
  background-size:42px 42px,42px 42px;
}
.bg-glow{
  position:fixed; width:420px; height:420px; border-radius:50%;
  filter:blur(90px); z-index:-2; pointer-events:none;
}
.glow-left{left:-140px; top:-120px; background:rgba(38,155,95,.22)}
.glow-right{right:-120px; top:260px; background:rgba(20,102,61,.24)}
a{text-decoration:none;color:inherit}
button{font:inherit}
.container{width:min(1180px, calc(100% - 32px)); margin:0 auto}

.site-header{
  position:sticky; top:0; z-index:30;
  background:rgba(4,19,15,.75);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.04);
}
.nav{
  min-height:84px;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.brand{display:flex; align-items:center; gap:14px; font-size:1.3rem; font-weight:800}
.brand-logo{
  width:54px; height:54px; object-fit:contain; border-radius:14px;
  background:#fff; padding:4px; box-shadow:var(--shadow);
}
.nav-links{display:flex; align-items:center; gap:20px}
.nav-links a{color:#d6e8df; font-weight:500}
.nav-pill{
  border:1px solid var(--border); background:rgba(255,255,255,.03); color:var(--text);
  border-radius:999px; padding:12px 18px; cursor:pointer;
}
.menu-toggle{display:none; background:none; border:0; padding:0; cursor:pointer}
.menu-toggle span{display:block; width:28px; height:3px; margin:5px 0; background:#fff; border-radius:3px}

.hero{padding:76px 0 44px}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:34px; align-items:center}
.eyebrow{
  display:inline-flex; padding:10px 16px; border-radius:999px; font-size:.84rem; font-weight:700;
  color:#81ffb3; background:rgba(83,240,144,.08); border:1px solid rgba(83,240,144,.14);
}
.hero-copy h1{
  margin:18px 0 16px; font-size:clamp(2.4rem, 5vw, 5rem); line-height:.96; max-width:11ch;
}
.hero-copy p{
  color:var(--muted); line-height:1.8; font-size:1.05rem; max-width:62ch;
}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap; margin:28px 0 34px}
.btn{
  border:0; border-radius:999px; padding:16px 24px; display:inline-flex; justify-content:center; align-items:center;
  font-weight:800; transition:.28s ease; cursor:pointer;
}
.btn:hover{transform:translateY(-3px); box-shadow:0 14px 30px rgba(83,240,144,.18)}
.btn-primary{
  background:linear-gradient(135deg, var(--primary), var(--primary-2));
  color:#032313; box-shadow:0 12px 30px rgba(83,240,144,.24);
}
.btn-secondary{
  background:rgba(255,255,255,.04); color:#fff; border:1px solid var(--border);
}
.btn-full{width:100%}
.btn-large{min-width:250px}
.hero-highlights{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.hero-highlights > div{
  padding:18px; border-radius:22px; background:rgba(255,255,255,.03); border:1px solid var(--border);
}

.tech-card{
  background:linear-gradient(180deg, rgba(12,34,26,.98), rgba(6,21,16,.98));
  border:1px solid var(--border);
  border-radius:34px; padding:22px; box-shadow:var(--shadow); overflow:hidden; position:relative;
}
.tech-card::after{
  content:""; position:absolute; right:-70px; bottom:-90px; width:260px; height:260px;
  background:radial-gradient(circle, rgba(83,240,144,.22), transparent 65%);
}
.tech-top,.tech-bottom{display:flex; justify-content:space-between; align-items:center; gap:16px}
.tech-top{font-weight:700; color:#cfe8dc}
.tech-top i{
  display:inline-block; width:10px; height:10px; border-radius:50%; background:#72ffab; margin-right:8px;
  box-shadow:0 0 0 8px rgba(114,255,171,.08);
}

.router-scene{
  position:relative; min-height:430px; margin:22px 0; border-radius:28px; overflow:hidden; border:1px solid var(--border);
  background:radial-gradient(circle at center, rgba(83,240,144,.18), transparent 36%), #05130f;
}
.scene-grid{
  position:absolute; inset:0;
  background:
    linear-gradient(rgba(83,240,144,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(83,240,144,.05) 1px, transparent 1px);
  background-size:34px 34px,34px 34px;
}
.wifi-wave{
  position:absolute; left:50%; top:56%;
  transform:translate(-50%, -50%);
  border-radius:50%;
  border:1px solid rgba(83,240,144,.16);
  animation:pulse 3.8s ease-out infinite;
}
.wave-1{width:170px;height:170px}
.wave-2{width:270px;height:270px; animation-delay:1s}
.wave-3{width:370px;height:370px; animation-delay:2s}

.router{
  position:absolute; left:50%; top:58%;
  transform:translate(-50%, -50%);
  width:144px; height:86px;
}
.router-body{
  position:absolute; bottom:0; left:0; right:0;
  height:46px; border-radius:16px;
  background:linear-gradient(180deg, #1d4132, #0f261d);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 0 28px rgba(83,240,144,.18);
  display:flex; align-items:center; justify-content:center; gap:10px;
}
.router-top{
  position:absolute; left:14px; right:14px; top:18px; height:12px;
  border-radius:12px 12px 6px 6px;
  background:linear-gradient(180deg, #2b5c47, #15362a);
  border:1px solid rgba(255,255,255,.08);
}
.router-light{
  width:8px; height:8px; border-radius:50%;
  background:#79ffab; box-shadow:0 0 12px rgba(121,255,171,.8);
  animation:blink 1.8s infinite alternate;
}
.router-light:nth-child(2){animation-delay:.5s}
.router-light:nth-child(3){animation-delay:1s}
.antenna{
  position:absolute; bottom:40px; width:8px; height:66px; border-radius:8px;
  background:linear-gradient(180deg, #295441, #0f261d);
}
.antenna-left{left:24px; transform:rotate(-14deg)}
.antenna-right{right:24px; transform:rotate(14deg)}

.activity{
  position:absolute;
  display:flex; align-items:center; gap:12px;
  padding:14px 16px; border-radius:18px;
  background:rgba(15,43,32,.92); border:1px solid rgba(83,240,144,.16);
  box-shadow:0 12px 24px rgba(0,0,0,.22);
  animation:floatCard 5s ease-in-out infinite;
}
.activity strong{display:block; font-size:1rem}
.activity span{display:block; color:var(--muted); font-size:.9rem}
.activity-icon{
  width:44px; height:44px; display:grid; place-items:center; border-radius:14px;
  background:rgba(83,240,144,.12); font-size:1.3rem;
}
.activity-tv{left:28px; top:34px}
.activity-gamer{right:24px; bottom:34px; animation-delay:1.1s}

.floating-tag{
  position:absolute; padding:12px 16px; border-radius:18px; font-weight:800;
  background:rgba(15,43,32,.92); border:1px solid rgba(83,240,144,.16);
}
.tag-1{left:28px; bottom:30px}
.tag-2{right:28px; top:34px}
.tag-3{left:50%; bottom:136px; transform:translateX(-50%)}

.tech-bottom small{display:block; color:var(--muted); margin-bottom:6px}

.benefits,.plans,.coverage,.cta-band{padding:74px 0}
.section-head{text-align:center; max-width:780px; margin:0 auto 34px}
.section-head h2{font-size:clamp(2rem, 3.4vw, 3.2rem); margin:16px 0 10px}
.section-head p{color:var(--muted); line-height:1.8}
.benefits-grid,.plans-grid{display:grid; gap:20px}
.benefits-grid{grid-template-columns:repeat(4,1fr)}
.plans-grid{grid-template-columns:repeat(4,1fr); align-items:stretch}
.info-card,.plan-card,.coverage-copy,.map-card,.cta-wrap{
  background:rgba(9,29,22,.86); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
}
.info-card{
  padding:24px;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.info-card:hover{
  transform:translateY(-6px);
  border-color:rgba(83,240,144,.18);
}
.icon-box{
  width:56px; height:56px; display:grid; place-items:center; border-radius:16px;
  background:rgba(83,240,144,.10); margin-bottom:14px; font-size:1.4rem;
}
.info-card p{color:var(--muted); line-height:1.75}

.plan-card{
  padding:24px; position:relative; display:flex; flex-direction:column;
  transition:transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}
.plan-card:hover{
  transform:translateY(-8px);
  border-color:rgba(83,240,144,.18);
}
.tag{
  display:inline-block; margin-bottom:14px; padding:9px 14px; border-radius:999px;
  background:rgba(255,255,255,.05); font-weight:700;
}
.plan-card h3{font-size:2rem; margin:0 0 8px}
.price{
  display:flex; align-items:flex-end; white-space:nowrap;
  font-size:clamp(2.1rem, 3.55vw, 3.8rem);
  font-weight:800; line-height:1; margin:10px 0 18px; letter-spacing:-0.04em;
}
.price span{
  font-size:1.12rem; font-weight:700; line-height:1.2; margin-left:.04em; padding-bottom:.14em;
}
.plan-card ul{list-style:none; padding:0; margin:0 0 24px}
.plan-card li{position:relative; padding-left:28px; margin:0 0 14px; line-height:1.5; color:#d7e6df}
.plan-card li::before{content:"✓"; position:absolute; left:0; top:0; color:#72ffab; font-weight:800}
.plan-card .btn{margin-top:auto}
.featured{
  border-color:rgba(83,240,144,.22);
  background:linear-gradient(180deg, rgba(17,50,36,.96), rgba(8,26,19,.96));
}
.popular{
  position:absolute; right:18px; top:18px; padding:9px 14px; border-radius:999px;
  background:linear-gradient(135deg, #79ffab, #54e788); color:#032514; font-weight:800;
}

.coverage-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:24px; align-items:center}
.coverage-copy{padding:28px}
.coverage-copy h2{font-size:clamp(2rem, 3.2vw, 3.1rem); margin:16px 0 12px}
.coverage-copy p{color:var(--muted); line-height:1.8}
.coverage-tags{display:flex; flex-wrap:wrap; gap:12px; margin:22px 0 28px}
.coverage-tags span{
  padding:12px 16px; border-radius:999px; background:rgba(255,255,255,.04);
  border:1px solid var(--border); font-weight:700;
}
.map-card{padding:16px}
#map{
  display:block; width:100%; min-height:430px; border-radius:20px;
}
.leaflet-container{
  background:#0a1713;
  border-radius:20px;
  color:#111;
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
  background:#0f241c;
  color:#eef9f3;
  border:1px solid rgba(83,240,144,.18);
}
.leaflet-control-attribution{
  background:rgba(4,19,15,.78)!important;
  color:#cfe8dc!important;
}
.leaflet-control-attribution a{
  color:#81ffb3!important;
}
.cta-wrap{
  padding:30px; display:flex; justify-content:space-between; align-items:center; gap:20px;
}
.cta-wrap h2{font-size:clamp(1.8rem, 3vw, 3rem); margin:14px 0 10px}
.cta-wrap p{margin:0; color:var(--muted)}

.floating-whatsapp{
  position:fixed; right:18px; bottom:18px; z-index:40;
  padding:14px 18px; border-radius:999px;
  background:linear-gradient(135deg, var(--primary), var(--primary-2));
  color:#042414; font-weight:800; box-shadow:0 14px 34px rgba(83,240,144,.28);
}

.modal{
  position:fixed; inset:0; display:none; place-items:center; padding:20px; z-index:60;
  background:rgba(0,0,0,.56);
}
.modal.show{display:grid}
.modal-box{
  width:min(420px,100%); background:#0b1d17; border:1px solid var(--border); border-radius:24px;
  padding:28px; position:relative; box-shadow:var(--shadow);
}
.modal-box p{color:var(--muted)}
.modal-close{
  position:absolute; right:14px; top:14px; width:38px; height:38px; border-radius:50%;
  border:0; background:rgba(255,255,255,.05); color:#fff; font-size:1.6rem; cursor:pointer;
}

@keyframes pulse{
  0%{opacity:.2; transform:translate(-50%, -50%) scale(.8)}
  70%{opacity:1}
  100%{opacity:0; transform:translate(-50%, -50%) scale(1.25)}
}
@keyframes floatCard{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-8px)}
}
@keyframes blink{
  0%{opacity:.35}
  100%{opacity:1}
}

@media (max-width:1080px){
  .hero-grid,.coverage-grid,.benefits-grid,.plans-grid{grid-template-columns:1fr 1fr}
  .cta-wrap{flex-direction:column; align-items:flex-start}
}
@media (max-width:820px){
  .menu-toggle{display:block}
  .nav-links{
    position:absolute; left:16px; right:16px; top:84px; display:none; flex-direction:column; align-items:flex-start;
    padding:18px; background:rgba(7,22,17,.98); border:1px solid var(--border); border-radius:22px;
  }
  .nav-links.show{display:flex}
  .hero-grid,.coverage-grid,.benefits-grid,.plans-grid{grid-template-columns:1fr}
  .hero-highlights{grid-template-columns:1fr}
}
@media (max-width:560px){
  .container{width:min(100% - 20px, 1180px)}
  .nav{min-height:76px}
  .brand-logo{width:48px; height:48px}
  .brand span{font-size:1.1rem}
  .hero{padding:56px 0 26px}
  .hero-copy h1{max-width:none}
  .btn,.nav-pill{width:100%}
  .hero-actions{flex-direction:column}
  .info-card,.plan-card,.coverage-copy,.map-card,.cta-wrap{border-radius:22px}
  #map{
  display:block; width:100%; min-height:430px; border-radius:20px;
}
.leaflet-container{
  background:#0a1713;
  border-radius:20px;
  color:#111;
}
.leaflet-popup-content-wrapper,
.leaflet-popup-tip{
  background:#0f241c;
  color:#eef9f3;
  border:1px solid rgba(83,240,144,.18);
}
.leaflet-control-attribution{
  background:rgba(4,19,15,.78)!important;
  color:#cfe8dc!important;
}
.leaflet-control-attribution a{
  color:#81ffb3!important;
}
  .floating-whatsapp{right:12px; bottom:12px}
  .price{font-size:clamp(2.25rem, 10vw, 3.3rem)}
  .router-scene{min-height:380px}
  .activity{padding:12px 14px}
  .activity strong{font-size:.92rem}
  .activity span{font-size:.82rem}
  .tag-2{top:auto; bottom:28px; right:20px}
  .tag-1{left:20px}
}


/* Ajuste mobile sem mudar layout */
@media (max-width: 768px){
  .bg-glow,
  .tech-card::after{
    display:none !important;
  }

  .wifi-wave,
  .activity,
  .router-light{
    animation:none !important;
  }

  .router-scene{
    min-height:320px !important;
  }

  #map{
    min-height:300px !important;
  }

  .leaflet-control-attribution{
    font-size:10px;
  }
}
