/* ===================== TOKENS ===================== */
  :root{
    --black:        #0a0a0d;
    --black-soft:   #161219;
    --black-card:   #1d1822;
    --white:        #ffffff;
    --off-white:    #f7f4f7;
    --ink:          #1a1620;
    --gray:         #6e6675;
    --gray-light:   #b9b1bd;

    --magenta:        #ff1088;
    --magenta-deep:   #8c094b;
    --magenta-bright: #ff58ac;
    --magenta-line:   rgba(255,16,136,0.35);

    --display: 'Bricolage Grotesque', 'Inter', sans-serif;
    --body:    'Inter', sans-serif;
    --mono:    'JetBrains Mono', monospace;

    --container: 1180px;
    --radius: 14px;
    --ease: cubic-bezier(.16,.8,.3,1);
  }

  *,*::before,*::after{ box-sizing:border-box; }
  html{ 
    scroll-behavior:smooth;
    overflow-x:hidden;
    scrollbar-width:none;
    -ms-overflow-style:none; 
  }
  
  html::-webkit-scrollbar{ display:none; }

  body{
    margin:0;
    background:var(--off-white);
    color:var(--ink);
    font-family:var(--body);
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
  }
  img,svg{ display:block; max-width:100%; }
  a{ color:inherit; text-decoration:none; }
  ul{ list-style:none; margin:0; padding:0; }
  button{ font-family:inherit; cursor:pointer; border:none; background:none; }
  input{ font-family:inherit; }

  .wrap{ max-width:var(--container); margin:0 auto; padding:0 24px; }

  ::selection{ background:var(--magenta); color:#fff; }

  :focus-visible{
    outline: 2px solid var(--magenta-bright);
    outline-offset: 3px;
    border-radius: 4px;
  }

  .skip-link{
    position:absolute; left:-999px; top:0; background:var(--magenta);
    color:#fff; padding:12px 18px; z-index:999; border-radius:0 0 8px 0;
  }
  .skip-link:focus{ left:0; }

  .eyebrow{
    font-family:var(--mono);
    font-size:12.5px;
    letter-spacing:.14em;
    text-transform:uppercase;
    font-weight:500;
  }

  /* ===================== NAV ===================== */
  header{
    position:fixed; top:0; left:0; right:0; z-index:200;
    padding:18px 0;
    transition: background .35s var(--ease), padding .35s var(--ease), border-color .35s var(--ease);
    border-bottom:1px solid transparent;
  }
  header.scrolled{
    background:rgba(10,10,13,0.78);
    backdrop-filter: blur(14px) saturate(140%);
    -webkit-backdrop-filter: blur(14px) saturate(140%);
    padding:12px 0;
    border-color: rgba(255,255,255,0.08);
  }
  .nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }

  .logo{ display:flex; align-items:center; }
  .logo-img{ height:30px; width:auto; display:block; }
  .footer-brand .logo-img, .footer-brand .logo{ height:auto; }
  .footer-brand .logo .logo-img{ height:36px; }

  nav.primary-nav{ display:flex; }
  nav.primary-nav ul{ display:flex; gap:34px; }
  nav.primary-nav a{
    color:var(--gray-light); font-size:14.5px; font-weight:500;
    transition: color .2s;
    position:relative;
  }
  nav.primary-nav a::after{
    content:""; position:absolute; left:0; right:0; bottom:-6px; height:1px;
    background:var(--magenta-bright); transform:scaleX(0); transform-origin:left;
    transition: transform .25s var(--ease);
  }
  nav.primary-nav a:hover{ color:var(--white); }
  nav.primary-nav a:hover::after{ transform:scaleX(1); }

  .nav-actions{ display:flex; align-items:center; gap:10px; }

  .nav-cta{
    background:var(--magenta-deep);
    color:#fff;
    font-size:14px; font-weight:600;
    padding:11px 22px;
    border-radius:100px;
    transition: background .2s, transform .2s;
    white-space:nowrap;
  }
  .nav-cta:hover{ background:var(--magenta); transform:translateY(-1px); }

  /* ===================== HERO ===================== */
  .hero{
    position:relative;
    background: radial-gradient(120% 90% at 78% -10%, #2c0e22 0%, var(--black) 55%) , var(--black);
    color:#fff;
    padding:168px 0 110px;
    overflow:hidden;
  }
  .hero::before{ /* grain */
    content:""; position:absolute; inset:0; opacity:.5; mix-blend-mode:overlay; pointer-events:none; z-index:1;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  }
  /* bloom de luz vindo de baixo no hero */
  .hero::after{
    content:""; position:absolute; pointer-events:none; z-index:1;
    width:700px; height:400px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,16,136,.18) 0%, transparent 70%);
    bottom:-180px; left:50%; transform:translateX(-50%);
    filter: blur(40px);
  }
  .pulse-svg{ position:absolute; inset:0; width:100%; height:100%; opacity:.55; }
  .hero-grid{
    position:relative; z-index:2;
    display:grid; grid-template-columns: 1.05fr 0.85fr; gap:50px; align-items:center;
  }
  .hero h1{
    font-family:var(--display); font-weight:700;
    font-size:clamp(2.6rem, 4.6vw, 4.3rem);
    line-height:1.04; letter-spacing:-0.01em;
    margin:18px 0 22px;
  }
  .hero h1 em{
    font-style:normal; color:var(--magenta-bright);
    background:linear-gradient(180deg, transparent 62%, rgba(255,61,166,.28) 62%);
  }
  .hero .eyebrow{ color:var(--magenta-bright); }
  .hero p.lead{
    font-size:17.5px; line-height:1.65; color:var(--gray-light); max-width:480px; margin-bottom:34px;
  }

  .cep-form{
    display:flex; gap:10px; max-width:430px; margin-bottom:18px;
  }
  .cep-form input{
    flex:1; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16);
    color:#fff; padding:15px 18px; border-radius:100px; font-size:15px;
    transition:border-color .2s, background .2s;
  }
  .cep-form input::placeholder{ color:#8d8590; }
  .cep-form input:focus{ border-color:var(--magenta-bright); background:rgba(255,255,255,.1); outline:none; }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    background:var(--magenta-deep); color:#fff; font-weight:600; font-size:15px;
    padding:15px 26px; border-radius:100px; white-space:nowrap;
    transition: background .2s, transform .2s, box-shadow .2s;
  }
  .btn:hover{ background:var(--magenta); transform:translateY(-2px); box-shadow:0 10px 26px -8px rgba(255,16,136,.5); }
  .btn-ghost{
    background:transparent; border:1px solid rgba(255,255,255,.25); color:#fff;
  }
  .btn-ghost:hover{ background:rgba(255,255,255,.08); box-shadow:none; }
  .btn-dark{ background:var(--black); }
  .btn-dark:hover{ background:#000; box-shadow:0 10px 26px -8px rgba(0,0,0,.55); }

  .trust-line{ font-size:13.5px; color:#8d8590; display:flex; align-items:center; gap:8px; }
  .trust-line .dot{ width:6px; height:6px; border-radius:50%; background:var(--magenta-bright); }

  /* speed readout card */
  .readout{
    position:relative; z-index:2;
    background:linear-gradient(165deg, var(--black-card), #120e16);
    border:1px solid rgba(255,255,255,.08);
    border-radius:22px;
    padding:30px 30px 26px;
    box-shadow: 0 30px 60px -25px rgba(0,0,0,.7), 0 0 0 1px rgba(255,16,136,.08), 0 0 60px -10px rgba(255,16,136,.2);
  }
  /* reflexo de luz no topo do card */
  .readout::before{
    content:""; position:absolute; pointer-events:none;
    top:0; left:10%; right:10%; height:1px;
    background: linear-gradient(90deg, transparent, rgba(255,88,172,.6), transparent);
    border-radius:50%;
  }
  .readout-top{ display:flex; justify-content:space-between; align-items:center; margin-bottom:22px; }
  .readout-top span{ font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; color:#8d8590; text-transform:uppercase; }
  .live-pill{
    display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:11px; color:#7be08a;
  }
  .live-pill .led{ width:7px; height:7px; border-radius:50%; background:#7be08a; box-shadow:0 0 8px #7be08a; animation: ledsine 2.4s ease-in-out infinite; }
  @keyframes ledsine{
    0%,100%{ opacity:1; box-shadow:0 0 8px #7be08a; }
    50%{ opacity:.18; box-shadow:0 0 2px #7be08a; }
  }

  .speed-number{
    font-family:var(--mono); font-weight:600; color:#fff;
    font-size:clamp(3.4rem, 6vw, 4.6rem); line-height:1; letter-spacing:-0.02em;
    display:flex; align-items:flex-end; gap:10px;
  }
  .speed-number span{ font-size:18px; color:var(--magenta-bright); font-weight:500; padding-bottom:8px; }

  .bars{ display:flex; align-items:flex-end; gap:5px; height:30px; margin:18px 0 22px; }
  .bars i{
    display:block; width:7px; border-radius:3px; background:var(--magenta-deep);
    animation: barpulse 1.8s ease-in-out infinite;
  }
  .bars i:nth-child(1){ height:30%; animation-delay:0s; }
  .bars i:nth-child(2){ height:55%; animation-delay:.15s; }
  .bars i:nth-child(3){ height:80%; animation-delay:.3s; }
  .bars i:nth-child(4){ height:100%; animation-delay:.45s; }
  .bars i:nth-child(5){ height:65%; animation-delay:.6s; }
  @keyframes barpulse{
    0%,100%{ background:var(--magenta-deep); }
    50%{ background:var(--magenta-bright); }
  }

  .readout-stats{ display:grid; grid-template-columns:1fr 1fr; gap:14px; border-top:1px solid rgba(255,255,255,.08); padding-top:18px; }
  .readout-stats div b{ display:block; font-family:var(--mono); font-size:19px; color:#fff; }
  .readout-stats div small{ font-size:11.5px; color:#8d8590; }

  /* ===================== STATS BAR ===================== */
  .statbar{
    background:var(--black-soft); color:#fff; padding:46px 0;
    border-top:1px solid rgba(255,255,255,.06);
  }
  .statbar .wrap{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
  .statbar b{
    display:block; font-family:var(--mono); font-weight:600; color:var(--magenta-bright);
    font-size:clamp(1.7rem,3vw,2.4rem);
  }
  .statbar small{ font-size:13px; color:#9b939f; }
  .statbar .div-line{ width:1px; background:rgba(255,255,255,.08); }

  /* ===================== SECTION GENERIC ===================== */
  section{ padding:110px 0; }
  .x-kicker{ display:flex; justify-content:center; margin-bottom:16px; color:var(--magenta); opacity:.55; }
  .center .x-kicker{ justify-content:center; }
  .section-head:not(.center) .x-kicker{ justify-content:flex-start; }
  .features .x-kicker{ color:var(--magenta-bright); opacity:.65; }

  .section-head{ max-width:640px; margin-bottom:58px; }
  .section-head .eyebrow{ color:var(--magenta); margin-bottom:14px; display:block; }
  .section-head h2{
    font-family:var(--display); font-weight:700; font-size:clamp(2rem,3.4vw,2.8rem);
    line-height:1.12; letter-spacing:-0.01em; margin:0 0 14px;
  }
  .section-head p{ color:var(--gray); font-size:16.5px; line-height:1.6; }
  .center{ text-align:center; margin-left:auto; margin-right:auto; }

  /* ===================== PLANS ===================== */
  .plans{ background:var(--off-white); position:relative; overflow:hidden; }
  /* luz difusa vinda do card em destaque para iluminar a seção */
  .plans::before{
    content:""; position:absolute; pointer-events:none;
    width:600px; height:600px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,16,136,.07) 0%, transparent 65%);
    top:50%; left:50%; transform:translate(-50%,-50%);
    filter: blur(30px);
  }
  .plans-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
  .plan{
    background:#fff; border:1px solid #e9e3e8; border-radius:20px; padding:34px 30px;
    display:flex; flex-direction:column; transition: transform .3s var(--ease), box-shadow .3s var(--ease);
  }
  .plan:hover{ transform:translateY(-6px); box-shadow:0 24px 48px -28px rgba(26,22,32,.25); }
  .plan-feat{
    background:linear-gradient(165deg, var(--magenta-deep), var(--magenta) 60%, var(--magenta-bright));
    color:#fff; border:none; transform:scale(1.04);
    box-shadow:0 28px 60px -22px rgba(226,18,122,.55), 0 0 0 1px rgba(255,255,255,.15) inset;
    position:relative; overflow:hidden;
  }
  /* reflexo espelho no card destaque */
  @keyframes shimmer {
    0%   { transform: translateX(-100%) skewX(-12deg); opacity: 0; }
    5%   { opacity: 1; }
    40%  { transform: translateX(580%)  skewX(-12deg); opacity: 1; }
    41%  { opacity: 0; }
    100% { transform: translateX(580%)  skewX(-12deg); opacity: 0; }
  }

  .plan-feat::after{
    content:""; position:absolute; pointer-events:none;
    top:-20%; left:0; width:21%; height:140%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.22), transparent);
    animation: shimmer 7s ease-in-out infinite;
  }
  .plan-feat-mark{
    position:absolute; top:18px; right:18px; width:34px; height:34px;
    pointer-events:none; opacity:.95;
    animation: markSpin 7s ease-in-out infinite;
  }
  @keyframes markSpin {
    0%                { transform: rotate(0deg);   }
    17.1%  { transform: rotate(360deg); }
    100%              { transform: rotate(360deg); }
  }
  .plan-feat:hover{ transform:scale(1.04) translateY(-6px); }
  .badge{
    align-self:flex-start; font-family:var(--mono); font-size:11px; letter-spacing:.08em;
    background:rgba(255,255,255,.18); padding:5px 12px; border-radius:100px; margin-bottom:18px;
  }
  .plan-feat .badge{ background:rgba(255,255,255,.22); }
  .plan:not(.plan-feat) .badge{ background:#f1ebef; color:var(--magenta-deep); }
  .plan-speed{ font-family:var(--mono); font-size:14px; color:var(--magenta); margin-bottom:6px; }
  .plan-feat .plan-speed{ color:rgba(255,255,255,.85); }
  .plan h3{ font-family:var(--display); font-size:25px; font-weight:700; margin:0 0 12px; }
  .plan-price{ display:flex; align-items:baseline; gap:6px; margin-bottom:16px; }
  .plan-price b{ font-family:var(--mono); font-size:34px; font-weight:600; }
  .plan-price span{ font-size:13.5px; color:var(--gray); }
  .plan-feat .plan-price span{ color:rgba(255,255,255,.75); }
  .plan-desc{ font-size:14.5px; line-height:1.55; color:var(--gray); margin-bottom:24px; }
  .plan-feat .plan-desc{ color:rgba(255,255,255,.85); }
  .plan-list{ display:flex; flex-direction:column; gap:11px; margin-bottom:28px; flex:1; }
  .plan-list li{ display:flex; gap:10px; font-size:14px; align-items:flex-start; }
  .plan-list svg{ flex:none; margin-top:2px; }
  .plan .btn{ width:100%; }
  .plan:not(.plan-feat) .btn{ background:var(--ink); }
  .plan:not(.plan-feat) .btn:hover{ background:var(--magenta); }
  .plan-feat .btn{ background:#fff; color:var(--magenta-deep); }
  .plan-feat .btn:hover{ background:var(--black); color:#fff; box-shadow:none; }

  /* ===================== FEATURES (dark) ===================== */
  .features{ background:var(--black); color:#fff; position:relative; overflow:hidden; }
  .features::before{
    content:""; position:absolute; inset:0; opacity:.45; mix-blend-mode:overlay; pointer-events:none; z-index:1;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.3'/%3E%3C/svg%3E");
  }
  /* raios de luz tipo fibra óptica cruzando o fundo */
  .features::after{
    content:""; position:absolute; pointer-events:none; z-index:1;
    inset:0;
    background:
      linear-gradient(118deg, transparent 30%, rgba(255,16,136,.05) 45%, transparent 55%),
      linear-gradient(62deg,  transparent 40%, rgba(255,88,172,.04) 52%, transparent 62%);
  }
  /* bloom magenta no canto superior direito */
  .features-glow-tr{
    position:absolute; pointer-events:none; z-index:1;
    width:500px; height:500px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,16,136,.12) 0%, transparent 65%);
    top:-150px; right:-150px;
    filter: blur(50px);
  }
  /* bloom suave no canto inferior esquerdo */
  .features-glow-bl{
    position:absolute; pointer-events:none; z-index:1;
    width:380px; height:380px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(140,9,75,.15) 0%, transparent 65%);
    bottom:-100px; left:-80px;
    filter: blur(40px);
  }
  .features .wrap{ position:relative; z-index:2; }
  .features .section-head p{ color:#9b939f; }
  .feat-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.08); border-radius:20px; overflow:hidden; }
  .feat-card{ background:var(--black); padding:36px 30px; transition: background .3s, box-shadow .3s; }
  .feat-card:hover{ background:var(--black-soft); box-shadow: inset 0 1px 0 rgba(255,88,172,.15); }
  .feat-icon{
    width:46px; height:46px; border-radius:12px; background:rgba(226,18,122,.14);
    display:flex; align-items:center; justify-content:center; margin-bottom:20px; color:var(--magenta-bright);
    box-shadow: 0 0 18px -4px rgba(255,16,136,.3);
    transition: box-shadow .3s;
  }
  .feat-card:hover .feat-icon{ box-shadow: 0 0 28px -2px rgba(255,16,136,.5); }
  .feat-card h3{ font-family:var(--display); font-size:18.5px; font-weight:700; margin:0 0 9px; }
  .feat-card p{ font-size:14px; line-height:1.6; color:#9b939f; }

  /* ===================== MARQUEE STRIP ===================== */
  .coverage{ overflow:hidden; padding:0; background:var(--off-white); }

  .marquee-strip{
    padding: 36px 0;
    overflow: hidden;
    position: relative;
    border-top: 1px solid rgba(26,22,32,.07);
    border-bottom: 1px solid rgba(26,22,32,.07);
  }
  .marquee-strip::before,
  .marquee-strip::after{
    content:""; position:absolute; top:0; width:180px; height:100%; z-index:2; pointer-events:none;
  }
  .marquee-strip::before{ left:0;  background:linear-gradient(to right, var(--off-white), transparent); }
  .marquee-strip::after { right:0; background:linear-gradient(to left,  var(--off-white), transparent); }

  .marquee-row{
    display:flex; align-items:center;
    width:max-content;
    animation: marqueeScroll 40s linear infinite;
  }
  .marquee-row{ pointer-events: none; }
  .marquee-row.paused{ animation-play-state: paused; }
  @keyframes marqueeScroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }

  .marquee-item{
    display:flex; align-items:baseline; gap:10px;
    padding: 0 52px;
    white-space:nowrap;
  }
  .mi-value{
    font-family: var(--display);
    font-size: 32px;
    font-weight: 800;
    color: var(--ink);
    letter-spacing: -.04em;
    line-height: 1;
  }
  .mi-label{
    font-family: var(--mono);
    font-size: 11px;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--gray);
  }
  .marquee-sep{
    color: var(--magenta);
    flex-shrink:0;
    display:flex; align-items:center;
    opacity: .6;
  }

  .ring{
    position:absolute; border-radius:50%; border:1.5px solid var(--magenta-line);
    animation: ringgrow 3.2s ease-out infinite;
  }
  .ring:nth-child(1){ width:40%; height:40%; animation-delay:0s; }
  .ring:nth-child(2){ width:40%; height:40%; animation-delay:.8s; }
  .ring:nth-child(3){ width:40%; height:40%; animation-delay:1.6s; }
  @keyframes ringgrow{
    0%{ width:30%; height:30%; opacity:.9; }
    100%{ width:100%; height:100%; opacity:0; }
  }
  .signal-core{
    width:60px; height:60px; border-radius:50%; background:var(--magenta);
    display:flex; align-items:center; justify-content:center; color:#fff; z-index:2;
    box-shadow:0 0 0 8px rgba(226,18,122,.12);
  }

  /* ===================== TESTIMONIALS ===================== */
  .quotes{ background:#fff; position:relative; overflow:hidden; }
  /* halo difuso centralizado no fundo */
  .quotes::before{
    content:""; position:absolute; pointer-events:none;
    width:800px; height:300px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,16,136,.05) 0%, transparent 65%);
    bottom:-80px; left:50%; transform:translateX(-50%);
    filter: blur(30px);
  }
  .quotes-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; position:relative; z-index:1; }
  .quote-card{ background:var(--off-white); border-radius:18px; padding:30px; }
  .quote-card p{ font-size:15px; line-height:1.65; color:var(--ink); margin-bottom:20px; }
  .quote-who{ display:flex; align-items:center; gap:12px; }
  .avatar{
    width:38px; height:38px; border-radius:50%; flex:none;
    display:flex; align-items:center; justify-content:center; color:#fff; font-family:var(--mono);
    font-size:13px; font-weight:600;
  }
  .quote-who b{ display:block; font-size:13.5px; }
  .quote-who small{ font-size:12px; color:var(--gray); }

  /* ===================== FAQ ===================== */
  .faq{ background:var(--off-white); position:relative; overflow:hidden; }
  /* bloom sutil no canto superior */
  .faq::before{
    content:""; position:absolute; pointer-events:none;
    width:500px; height:500px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,16,136,.05) 0%, transparent 65%);
    top:-160px; right:-100px;
    filter: blur(40px);
  }
  .faq-list{ max-width:760px; margin:0 auto; position:relative; z-index:1; }
  details{
    border-bottom:1px solid #e2dadf; padding:22px 0;
    position:relative;
    transition: border-color .3s;
  }
  details[open]{
    border-color: rgba(255,16,136,.25);
  }
  /* linha de luz magenta na esquerda quando aberto */
  details[open]::before{
    content:""; position:absolute; left:-24px; top:0; bottom:0; width:2px;
    background: linear-gradient(180deg, transparent, rgba(255,16,136,.5) 30%, rgba(255,16,136,.5) 70%, transparent);
    border-radius:2px;
  }
  summary{
    display:flex; justify-content:space-between; align-items:center; gap:20px;
    font-family:var(--display); font-weight:600; font-size:17px; cursor:pointer; list-style:none;
  }
  summary::-webkit-details-marker{ display:none; }
  .plus{ position:relative; width:18px; height:18px; flex:none; }
  .plus::before,.plus::after{
    content:""; position:absolute; background:var(--magenta); border-radius:2px; transition:transform .35s var(--ease);
  }
  .plus::before{ width:18px; height:2px; top:8px; left:0; }
  .plus::after{ width:2px; height:18px; top:0; left:8px; }
  details[open] .plus::before{ transform:rotate(45deg); }
  details[open] .plus::after{ transform:rotate(45deg); }
  details p{ font-size:14.5px; line-height:1.65; color:var(--gray); margin:14px 0 0; max-width:620px; }

  /* ===================== FINAL CTA ===================== */
  .final-cta{
    background: linear-gradient(120deg, var(--magenta-deep) 0%, var(--magenta) 48%, var(--magenta-bright) 100%);
    color:#fff; text-align:center; position:relative; overflow:hidden;
  }
  .final-cta::before{
    content:""; position:absolute; inset:0; opacity:.5; mix-blend-mode:overlay; pointer-events:none; z-index:1;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.3'/%3E%3C/svg%3E");
  }
  /* bloom de luz branca centralizado atrás do texto */
  .final-cta::after{
    content:""; position:absolute; pointer-events:none; z-index:1;
    width:700px; height:400px; border-radius:50%;
    background: radial-gradient(ellipse, rgba(255,255,255,.18) 0%, transparent 65%);
    top:50%; left:50%; transform:translate(-50%,-50%);
    filter: blur(50px);
  }
  /* raio de luz diagonal */
  .final-cta-ray{
    position:absolute; pointer-events:none; z-index:1;
    inset:0;
    background:
      linear-gradient(125deg, transparent 35%, rgba(255,255,255,.07) 48%, transparent 58%),
      linear-gradient(55deg,  transparent 40%, rgba(255,255,255,.05) 52%, transparent 62%);
  }
  .final-cta .wrap{ position:relative; z-index:2; }
  .final-cta h2{ font-family:var(--display); font-weight:700; font-size:clamp(2rem,4vw,3rem); margin:0 0 16px; }
  .final-cta p{ font-size:16px; opacity:.92; margin-bottom:34px; }
  .final-cta .final-slogan{
    font-family:var(--display); font-weight:700; font-size:clamp(1.15rem,2vw,1.5rem);
    opacity:1; margin:8px 0 0; letter-spacing:-0.01em;
  }
  .final-cta .btn-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

  /* ===================== FOOTER ===================== */
  footer{ background:var(--black); color:#9b939f; padding:74px 0 30px; }
  .footer-grid{ display:grid; grid-template-columns:1.4fr repeat(3,1fr); gap:40px; margin-bottom:60px; }
  .footer-brand p{ font-size:14px; line-height:1.6; margin:16px 0 22px; max-width:260px; }
  .social-row{ display:flex; gap:10px; }
  .social-row a{
    width:36px; height:36px; border-radius:50%; overflow:hidden;
    display:flex; align-items:center; justify-content:center;
    transition: transform .2s, box-shadow .2s;
  }
  .social-row a:hover{ transform:translateY(-2px); box-shadow:0 6px 16px -4px rgba(0,0,0,.45); }
  .social-row a svg{ display:block; width:100%; height:100%; }
  .footer-col h4{ font-family:var(--display); font-size:14px; color:#fff; margin:0 0 18px; }
  .footer-col ul{ display:flex; flex-direction:column; gap:11px; }
  .footer-col a{ font-size:14px; transition:color .2s; }
  .footer-col a:hover{ color:#fff; }

  .js-dev{ position:relative; }
  .js-dev::after{
    content:'Em breve';
    position:absolute; bottom:calc(100% + 6px); left:50%; transform:translateX(-50%) translateY(4px);
    background:#1d1822; color:var(--magenta-bright); border:1px solid var(--magenta-line);
    font-family:var(--mono); font-size:11px; letter-spacing:.08em; white-space:nowrap;
    padding:4px 10px; border-radius:6px; pointer-events:none;
    opacity:0; transition: opacity .18s, transform .18s;
  }
  .js-dev:hover::after{
    opacity:1; transform:translateX(-50%) translateY(0);
  }
  .footer-bottom{
    border-top:1px solid rgba(255,255,255,.08); padding-top:26px;
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
    font-size:12.5px;
  }
  .footer-bottom .legal{ display:flex; gap:20px; }

  /* ===================== PLAN MODAL (WhatsApp) ===================== */
  .plan-modal-overlay{
    position:fixed; inset:0; z-index:400;
    background:rgba(10,10,13,.72);
    backdrop-filter: blur(6px);
    display:flex; align-items:center; justify-content:center;
    padding:20px;
    opacity:0; pointer-events:none;
    transition: opacity .25s var(--ease);
  }
  .plan-modal-overlay.open{ opacity:1; pointer-events:auto; }
  .plan-modal{
    background:var(--off-white);
    color:var(--ink);
    width:100%; max-width:460px;
    max-height:88vh; overflow-y:auto;
    border-radius:20px;
    padding:32px;
    position:relative;
    transform:translateY(18px) scale(.98);
    transition: transform .3s var(--ease);
    box-shadow:0 30px 70px -20px rgba(0,0,0,.5);
  }
  .plan-modal-overlay.open .plan-modal{ transform:translateY(0) scale(1); }
  .plan-modal-close{
    position:absolute; top:18px; right:18px; width:34px; height:34px;
    border-radius:50%; background:rgba(0,0,0,.06);
    display:flex; align-items:center; justify-content:center;
    transition: background .2s;
  }
  .plan-modal-close:hover{ background:rgba(0,0,0,.12); }
  .plan-modal-chip{
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,16,136,.1); color:var(--magenta-deep);
    font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.04em;
    padding:6px 14px; border-radius:100px; margin-bottom:16px;
  }
  .plan-modal h3{
    font-family:var(--display); font-size:24px; font-weight:700;
    margin:0 0 8px; letter-spacing:-.01em;
    color:var(--magenta-deep);
  }
  .plan-modal-sub{ font-size:14.5px; color:var(--gray); line-height:1.5; margin:0 0 24px; }
  .plan-modal-field{ margin-bottom:16px; }
  .plan-modal-field label{
    display:block; font-size:13px; font-weight:600; color:var(--ink); margin-bottom:7px;
  }
  .plan-modal-field input{
    width:100%; padding:13px 16px; border-radius:10px;
    border:1.5px solid rgba(0,0,0,.12); background:#fff;
    font-size:15px; color:var(--ink); transition: border-color .2s;
  }
  .plan-modal-field input:focus{ outline:none; border-color:var(--magenta); }
  .plan-modal-field small{ display:block; margin-top:6px; font-size:12px; color:var(--gray); }
  .plan-modal-consent{
    display:flex; gap:10px; align-items:flex-start;
    background:rgba(0,0,0,.03); border-radius:12px; padding:14px 16px;
    margin:20px 0 22px;
  }
  .plan-modal-consent input{ margin-top:3px; flex-shrink:0; width:16px; height:16px; accent-color:var(--magenta); }
  .plan-modal-consent label{ font-size:12.5px; line-height:1.55; color:var(--gray); }
  .plan-modal-consent a{ color:var(--magenta-deep); font-weight:600; text-decoration:underline; }
  .plan-modal-note{
    font-size:12px; color:var(--gray); line-height:1.5; margin:0 0 22px;
    display:flex; gap:8px; align-items:flex-start;
  }
  .plan-modal-note svg{ flex-shrink:0; margin-top:1px; color:var(--gray); }
  .plan-modal-submit{
    width:100%; background:#1DA851; color:#fff; font-weight:700; font-size:15.5px;
    padding:15px 24px; border-radius:100px;
    display:flex; align-items:center; justify-content:center; gap:9px;
    box-shadow: 0 8px 20px -8px rgba(29,168,81,.55);
    transition: background .2s, transform .2s, box-shadow .2s;
  }
  .plan-modal-submit:hover{ background:#178f44; transform:translateY(-1px); box-shadow: 0 10px 22px -8px rgba(29,168,81,.65); }
  .plan-modal-submit svg{ flex-shrink:0; }
  .plan-modal-error{ font-size:12.5px; color:#c0265a; margin:-8px 0 14px; display:none; }
  .plan-modal-error.show{ display:block; }

  /* ===================== UTIL / REVEAL ===================== */
  section[id]{ scroll-margin-top: 92px; }
  [data-reveal]{ opacity:0; transform:translateY(24px); transition: opacity .7s var(--ease), transform .7s var(--ease); }

  [data-reveal].in{ opacity:1; transform:none; }

  /* ===================== RESPONSIVE ===================== */
  @media (max-width: 980px){
    nav.primary-nav{ display:none; }
    .hero-grid{ grid-template-columns:1fr; }
    .readout{ max-width:440px; }
    .statbar .wrap{ grid-template-columns:repeat(2,1fr); gap:30px 16px; }
    .plans-grid{ grid-template-columns:1fr; max-width:440px; margin:0 auto; }
    .plan-feat{ transform:none; }
    .plan-feat:hover{ transform:translateY(-6px); }
    .feat-grid{ grid-template-columns:1fr; }
        .quotes-grid{ grid-template-columns:1fr; }
    .footer-grid{ grid-template-columns:1fr 1fr; }
  }
  @media (max-width: 560px){
    section{ padding:76px 0; }
    .hero{ padding:140px 0 80px; }
    .cep-form{ flex-direction:column; }
      .plan-modal{ padding:26px 22px; }
    .footer-grid{ grid-template-columns:1fr; gap:34px; }
    .footer-bottom{ flex-direction:column; align-items:flex-start; }
    .final-cta .btn-row{ flex-direction:column; width:100%; }
  }

  /* ===================== LEGAL MODAL (Termos/Privacidade) ===================== */
  .legal-modal{ z-index:500; }
  .legal-modal .plan-modal{ max-width:620px; }
  .legal-modal-body{ font-size:14px; line-height:1.7; color:var(--gray); }
  .legal-modal-body h4{
    font-family:var(--display); font-size:15.5px; color:var(--ink);
    margin:22px 0 8px;
  }
  .legal-modal-body h4:first-child{ margin-top:0; }
  .legal-modal-body p{ margin:0 0 10px; }
  .legal-modal-body ul{ margin:0 0 10px; padding-left:18px; list-style:disc; }
  .legal-modal-body li{ margin-bottom:6px; }
  .legal-modal-updated{
    font-family:var(--mono); font-size:11.5px; color:var(--gray);
    margin-top:18px; padding-top:14px; border-top:1px solid rgba(0,0,0,.08);
  }

  /* ===================== DEV MODAL (site em desenvolvimento) ===================== */
  .dev-modal-overlay{
    position:fixed; inset:0; z-index:600;
    background:rgba(5,4,7,.78);
    backdrop-filter: blur(8px);
    display:flex; align-items:center; justify-content:center;
    padding:20px;
    opacity:0; pointer-events:none;
    transition: opacity .3s var(--ease);
  }
  .dev-modal-overlay.show{ opacity:1; pointer-events:auto; }

  .dev-modal{
    position:relative;
    width:100%; max-width:380px;
    background:var(--black-soft);
    border:1.5px solid #f5c400;
    border-radius:20px;
    padding:38px 26px 26px;
    text-align:center;
    transform:translateY(40px) scale(.92);
    opacity:0;
    box-shadow:0 0 0 1px rgba(245,196,0,.12), 0 30px 70px -20px rgba(0,0,0,.7);
    transition: transform .45s cubic-bezier(.34,1.56,.64,1), opacity .35s var(--ease);
    overflow:hidden;
  }
  .dev-modal::before{
    content:''; position:absolute; left:0; right:0; top:0; height:8px;
    background: repeating-linear-gradient(135deg,
      #f5c400 0 14px,
      #1a1620 14px 28px);
    background-size: 200% 100%;
    animation: devStripeMove 1.8s linear infinite;
  }
  @keyframes devStripeMove{
    0%{ background-position: 0 0; }
    100%{ background-position: -39.6px 0; }
  }
  .dev-modal-overlay.show .dev-modal{
    transform:translateY(0) scale(1);
    opacity:1;
    animation: devModalGlow 2.4s ease-in-out .45s infinite;
  }
  @keyframes devModalGlow{
    0%, 100%{ box-shadow:0 0 0 1px rgba(245,196,0,.15), 0 30px 70px -20px rgba(0,0,0,.7), 0 0 26px -6px rgba(245,196,0,.35); }
    50%{ box-shadow:0 0 0 1px rgba(245,196,0,.35), 0 30px 70px -20px rgba(0,0,0,.7), 0 0 46px 4px rgba(245,196,0,.55); }
  }

  .dev-modal-close{
    position:absolute; top:14px; right:14px; width:30px; height:30px;
    border-radius:50%; background:rgba(255,255,255,.06);
    display:flex; align-items:center; justify-content:center;
    color:#fff; transition: background .2s;
  }
  .dev-modal-close:hover{ background:rgba(255,255,255,.14); }

  .dev-modal-icon{
    width:62px; height:62px; margin:4px auto 18px;
    border-radius:50%;
    background: radial-gradient(circle at 35% 30%, #ffe033, #f5c400 60%, #c49a00);
    display:flex; align-items:center; justify-content:center;
    animation: devIconBob 1.8s ease-in-out infinite;
  }
  @keyframes devIconBob{
    0%, 100%{ transform:translateY(0) rotate(0deg); }
    25%{ transform:translateY(-3px) rotate(-8deg); }
    75%{ transform:translateY(2px) rotate(6deg); }
  }
  .dev-modal-icon svg{ transform-origin:50% 90%; }

  .dev-modal-eyebrow{
    font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase;
    color:#f5c400; font-weight:600; margin-bottom:8px;
  }
  .dev-modal h4{
    font-family:var(--display); font-size:21px; font-weight:700; color:#fff;
    margin:0 0 10px; letter-spacing:-.01em;
  }
  .dev-modal p{
    font-size:14px; line-height:1.55; color:#b9b1bd; margin:0 0 22px;
  }

  .dev-modal-bar{
    height:4px; border-radius:100px; background:rgba(255,255,255,.08);
    overflow:hidden; margin-bottom:20px;
  }
  .dev-modal-bar-fill{
    height:100%; width:40%; border-radius:100px;
    background:linear-gradient(90deg, #c49a00, #ffe033);
    animation: devBarSlide 1.6s ease-in-out infinite;
  }
  @keyframes devBarSlide{
    0%{ transform:translateX(-100%); }
    100%{ transform:translateX(350%); }
  }

  .dev-modal-ok{
    width:100%; padding:13px 24px; border-radius:100px;
    background:var(--magenta); color:#fff; font-weight:700; font-size:14.5px;
    transition: background .2s, transform .2s;
  }
  .dev-modal-ok:hover{ background:var(--magenta-bright); transform:translateY(-1px); }


  @media (prefers-reduced-motion: reduce){
    *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  }