.elementor-623 .elementor-element.elementor-element-ea9666e{--display:flex;}/* Start custom CSS for container, class: .elementor-element-ea9666e */html, body{
      width:100%;
      max-width:100%;
      overflow-x:hidden;
}
    :root{
      --bg: #f7f8f4;
      --surface: #ffffff;
      --surface-soft: #ffffff;
      --primary: #49ab2f;
      --primary-dark: #005b3c;
      --primary-deep: #004b34;
      --primary-light: #dff3d1;
      --text: #173025;
      --muted: #66756d;
      --border: #dbe7dc;
      --shadow: 0 18px 40px rgba(0, 91, 60, 0.10);
      --shadow-soft: 0 10px 24px rgba(0, 91, 60, 0.08);
      --radius: 22px;
      --radius-lg: 30px;
      --max: 1180px;
    }

    *{margin:0;padding:0;box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      font-family:'Inter',sans-serif;
      background:var(--bg);
      color:var(--text);
      line-height:1.6;
    }

    a{text-decoration:none;color:inherit}
    img{max-width:100%;display:block}
    button{font-family:inherit}

    ..elementor-623 .elementor-element.elementor-element-ea9666e .container{
      width:min(92%, var(--max));
      margin:0 auto;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:16px 24px;
      border:none;
      border-radius:999px;
      font-weight:700;
      cursor:pointer;
      transition:.25s ease;
    }

    .btn-primary{
      background:linear-gradient(135deg, var(--primary), var(--primary-dark));
      color:#fff;
      box-shadow:0 12px 24px rgba(0,91,60,.18);
    }

    .btn-primary:hover{
      transform:translateY(-2px);
      filter:brightness(.96);
    }

    .btn-secondary{
      background:#fff;
      color:var(--primary-dark);
      border:1px solid rgba(0,91,60,.12);
      box-shadow:var(--shadow-soft);
    }

    .btn-secondary:hover{
      transform:translateY(-2px);
      border-color:var(--primary);
    }

    .tag{
      display:inline-block;
      padding:8px 14px;
      border-radius:999px;
      background:rgba(73,171,47,.10);
      color:var(--primary-dark);
      font-size:14px;
      font-weight:700;
      margin-bottom:18px;
    }

    header{
      position:sticky;
      top:0;
      z-index:1000;
      background:#ffffff;
      border-bottom:1px solid rgba(219,231,220,.92);
      width:100%;
}

    header::before{
      content:"";
      position:absolute;
      top:0;
      left:50%;
      transform:translateX(-50%);
      
      width:100vw;
      height:100%;
      
      background:#ffffff;
      border-bottom:1px solid rgba(219,231,220,.92);
    
      z-index:-1;
    }
    
    .nav{
      min-height:96px;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:20px;
      position:relative;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:16px;
      min-width:0;
      position:relative;
      z-index:1002;
    }

    .brand img{
      height:78px;
      width:auto;
      object-fit:contain;
    }

    .brand-text{
      font-size:15px;
      color:var(--muted);
      font-weight:600;
      white-space:nowrap;
    }

    .desktop-nav{
      display:flex;
      align-items:center;
      gap:24px;
    }

    .menu{
      display:flex;
      align-items:center;
      gap:24px;
      color:var(--muted);
      font-weight:600;
      font-size:15px;
    }

    .menu a:hover{
      color:var(--primary-dark);
    }

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

    .menu-toggle{
      display:none;
      width:48px;
      height:48px;
      border-radius:14px;
      border:1px solid var(--border);
      background:#fff;
      align-items:center;
      justify-content:center;
      cursor:pointer;
      box-shadow:var(--shadow-soft);
      position:relative;
      z-index:1002;
    }

    .menu-toggle span{
      position:absolute;
      width:20px;
      height:2px;
      background:var(--primary-dark);
      border-radius:2px;
      transition:.25s ease;
    }

    .menu-toggle span:nth-child(1){transform:translateY(-6px)}
    .menu-toggle span:nth-child(2){transform:translateY(0)}
    .menu-toggle span:nth-child(3){transform:translateY(6px)}

    .menu-toggle.active span:nth-child(1){transform:rotate(45deg)}
    .menu-toggle.active span:nth-child(2){opacity:0}
    .menu-toggle.active span:nth-child(3){transform:rotate(-45deg)}

    .mobile-panel{
      display:none;
    }

    

    .hero-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:42px;
      align-items:center;
    }

    .hero h1{
      font-size:clamp(36px, 5vw, 60px);
      line-height:1.02;
      letter-spacing:-1.9px;
      margin-bottom:18px;
      color:var(--text);
      max-width:720px;
    }

    .hero p{
      font-size:18px;
      color:var(--muted);
      max-width:650px;
      margin-bottom:28px;
    }

    .hero-actions{
      display:flex;
      flex-wrap:wrap;
      gap:14px;
      margin-bottom:24px;
    }

    .hero-highlights{
      display:flex;
      flex-wrap:wrap;
      gap:12px;
    }

    .chip{
      background:#fff;
      border:1px solid var(--border);
      border-radius:999px;
      padding:10px 14px;
      font-size:14px;
      color:var(--muted);
      font-weight:600;
      box-shadow:var(--shadow-soft);
    }
    
    
    .hero{
      position: relative;
      padding: 76px 0 60px;
      z-index: 1;
      overflow: visible; /* importante */
    }
    
    /* FUNDO FULL WIDTH REAL */
    .hero::before{
      content:"";
      position:absolute;
      top:0;
      left:50%;
      transform:translateX(-50%);
    
      width:100vw;
      height:100%;
    
      z-index:-1;
    
      background:
        radial-gradient(circle at 90% 0%, rgba(73,171,47,.25), transparent 40%),
        radial-gradient(circle at 0% 100%, rgba(0,91,60,.18), transparent 40%),
        #edf7e8;
    }

    .hero-visual{
      display:flex;
      flex-direction:column;
      gap:16px;
    }

    .hero-main-card{
      grid-column:1 / -1;
      min-height:450px;
      border-radius:var(--radius-lg);
      overflow:hidden;
      position:relative;
      box-shadow:var(--shadow);
      border:1px solid rgba(255,255,255,.6);
      background:#eef5ea;
    }

    .hero-main-card img{
      width:100%;
      height:100%;
      object-fit:cover;
    }

    .hero-main-overlay{
      position:absolute;
      inset:0;
      background:linear-gradient(to top, rgba(0,91,60,.60), rgba(0,91,60,.05));
    }

    .hero-main-caption{
      position:absolute;
      left:24px;
      right:24px;
      bottom:22px;
      z-index:2;
      color:#fff;
    }

    .hero-main-caption-box{
      display:inline-block;
      max-width:470px;
      padding:18px 20px;
      border-radius:20px;
      background:rgba(255,255,255,.12);
      border:1px solid rgba(255,255,255,.22);
      backdrop-filter:blur(10px);
    }

    .hero-main-caption h3{
      font-size:24px;
      line-height:1.08;
      margin-bottom:8px;
    }

    .hero-main-caption p{
      margin:0;
      color:rgba(255,255,255,.92);
      font-size:15px;
    }

    .mini-visual{
      width:100%;
      border-radius:24px;
      overflow:hidden;
      position:relative;
      box-shadow:var(--shadow);
      border:1px solid rgba(255,255,255,.6);
      background:#fff;
    }

    .mini-visual img{
      width:100%;
      height:auto;
      display:block;
    }

    .mini-badge{
      position:absolute;
      left:16px;
      bottom:16px;
      background:rgba(255,255,255,.94);
      color:var(--primary-dark);
      border-radius:999px;
      padding:8px 12px;
      font-size:13px;
      font-weight:700;
      box-shadow:0 10px 20px rgba(0,0,0,.08);
    }

    .logo-box{
      background:#ffffff !important;
      display:flex;
      align-items:center;
      justify-content:center;
      padding:20px;
    }

    .logo-showcase{
      max-width:92%;
      max-height:190px;
      object-fit:contain;
    }

    section{
      padding:74px 0;
    }

    .section-head{
      max-width:760px;
      margin-bottom:34px;
    }

    .section-head h2{
      font-size:clamp(28px,4vw,42px);
      line-height:1.1;
      letter-spacing:-1px;
      margin-bottom:12px;
      color:var(--text);
    }

    .section-head p{
      color:var(--muted);
      font-size:17px;
    }

    .solutions-grid{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:18px;
    }

    .card{
      background:var(--surface);
      border:1px solid var(--border);
      border-radius:var(--radius);
      padding:24px;
      box-shadow:var(--shadow);
      transition:.25s ease;
    }

    .card:hover{
      transform:translateY(-4px);
    }

    .icon{
      width:54px;
      height:54px;
      border-radius:16px;
      display:grid;
      place-items:center;
      background:linear-gradient(135deg, rgba(73,171,47,.10), rgba(0,91,60,.10));
      color:var(--primary-dark);
      font-size:18px;
      font-weight:800;
      margin-bottom:18px;
    }

    .card h3{
      font-size:18px;
      margin-bottom:8px;
      color:var(--text);
    }

    .card p{
      color:var(--muted);
      font-size:15px;
    }

    .process{
      position:relative;
      background:linear-gradient(180deg, #fbfdf9, #eff7ea);
      z-index:1;
    }
    
    .process::before{
      content:"";
      position:absolute;
      top:0;
      left:50%;
      transform:translateX(-50%);
      width:100vw;
      height:100%;
      background:linear-gradient(180deg, #fbfdf9, #eff7ea);
      z-index:-1;
}

    .process{
      box-shadow: 0 20px 40px rgba(0,0,0,0.06);
}

    .timeline{
      display:grid;
      grid-template-columns:repeat(5,1fr);
      gap:18px;
    }

    .step{
      background:#fff;
      border:1px solid var(--border);
      border-radius:22px;
      padding:24px;
      box-shadow:var(--shadow-soft);
    }

    .step-number{
      width:42px;
      height:42px;
      border-radius:50%;
      display:grid;
      place-items:center;
      background:linear-gradient(135deg, var(--primary), var(--primary-dark));
      color:#fff;
      font-weight:800;
      margin-bottom:16px;
    }

    .step h3{
      font-size:18px;
      margin-bottom:8px;
    }

    .step p{
      color:var(--muted);
      font-size:15px;
    }

    .benefits-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:18px;
    }

    .benefit{
      display:flex;
      gap:16px;
      align-items:flex-start;
      background:#fff;
      border:1px solid var(--border);
      border-radius:18px;
      padding:22px;
      box-shadow:var(--shadow);
    }

    .benefit-bullet{
      width:42px;
      height:42px;
      min-width:42px;
      border-radius:12px;
      display:grid;
      place-items:center;
      background:linear-gradient(135deg, rgba(73,171,47,.10), rgba(0,91,60,.10));
      color:var(--primary-dark);
      font-weight:800;
    }

    .benefit h4{
      margin-bottom:6px;
      font-size:18px;
    }

    .benefit p{
      color:var(--muted);
      font-size:15px;
    }

    .promo{
      padding:42px;
      border-radius:30px;
      background:linear-gradient(135deg, var(--primary), var(--primary-dark));
      box-shadow:var(--shadow);
      color:#fff;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:24px;
      flex-wrap:wrap;
    }

    .promo h3{
      font-size:clamp(26px,3vw,38px);
      line-height:1.08;
      max-width:760px;
      margin-bottom:8px;
    }

    .promo p{
      max-width:720px;
      color:rgba(255,255,255,.92);
    }

    .brand-strip{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:22px;
    }

    .strip-card{
      background:#fff;
      border:1px solid var(--border);
      border-radius:28px;
      padding:28px;
      box-shadow:var(--shadow);
    }

    .strip-card img{
      border-radius:22px;
      overflow:hidden;
      width:100%;
      margin-top:16px;
    }

    .faq-wrap{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:18px;
    }

    .faq-item{
      background:#fff;
      border:1px solid var(--border);
      border-radius:18px;
      overflow:hidden;
      box-shadow:var(--shadow);
    }

    .faq-question{
      width:100%;
      background:#fff;
      border:none;
      text-align:left;
      padding:20px 22px;
      font-size:17px;
      font-weight:700;
      color:var(--text);
      cursor:pointer;
    }

    .faq-answer{
      max-height:0;
      overflow:hidden;
      transition:max-height .3s ease;
      padding:0 22px;
      color:var(--muted);
    }

    .faq-item.active .faq-answer{
      max-height:240px;
      padding:0 22px 22px;
    }

    .contact-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:28px;
      align-items:start;
    }

    .contact-info,
    .form-box{
      background:#fff;
      border:1px solid var(--border);
      border-radius:28px;
      padding:30px;
      font-size:14px;
      box-shadow:var(--shadow);
    }

    .contact-info ul{
      list-style:none;
      display:grid;
      gap:14px;
      margin-top:18px;
      color:var(--muted);
    }

    form{
      display:grid;
      gap:14px;
    }

    .form-row{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:14px;
    }

    input, select, textarea{
      width:100%;
      padding:16px;
      border-radius:14px;
      border:1px solid var(--border);
      background:#fbfcfa;
      font-family:inherit;
      font-size:14px;
      color:var(--text);
      outline:none;
    }

    input:focus, select:focus, textarea:focus{
      border-color:rgba(73,171,47,.45);
      box-shadow:0 0 0 4px rgba(73,171,47,.08);
    }

    textarea{
      min-height:130px;
      resize:vertical;
    }

    .radio-group{
      display:flex;
      gap:35px;
      align-items:center;
      color:var(--muted);
      font-weight:600;
      padding-top:4px;
      flex-wrap:wrap;
    }

    .radio-option{
      display:flex;
      align-items:center;
      gap:1px;
    }

    footer{
      padding:26px 0 46px;
      color:var(--muted);
      font-size:14px;
    }

    .footer-grid{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:24px;
      border-top:1px solid var(--border);
      padding-top:28px;
    }

    .footer-card{
      background:#fff;
      border:1px solid var(--border);
      border-radius:24px;
      padding:24px;
      box-shadow:var(--shadow);
    }

    .footer-logo{
      height:94px;
      width:auto;
      margin-bottom:14px;
      object-fit:contain;
      background:#ffffff;
    }

    .footer-card h4{
      font-size:18px;
      margin-bottom:10px;
      color:var(--text);
    }

    .footer-card p,
    .footer-card li{
      color:var(--muted);
    }

    .footer-card ul{
      list-style:none;
      display:grid;
      gap:10px;
    }

    .copyright{
      margin-top:20px;
      text-align:center;
    }

    .whatsapp-float{
      position:fixed;
      right:20px;
      bottom:20px;
      width:62px;
      height:62px;
      border-radius:50%;
      background:linear-gradient(135deg, #25d366, #128c7e);
      color:#fff;
      display:flex;
      align-items:center;
      justify-content:center;
      box-shadow:0 16px 32px rgba(18,140,126,.25);
      z-index:1200;
      transition:.25s ease;
    }

    .whatsapp-float:hover{
      transform:translateY(-2px) scale(1.03);
    }

    .whatsapp-float svg{
      width:30px;
      height:30px;
      fill:#fff;
    }

    @media (max-width: 1080px){
      .hero-grid,
      .benefits-grid,
      .faq-wrap,
      .contact-grid,
      .footer-grid,
      .brand-strip{
        grid-template-columns:1fr;
      }

      .timeline{
        grid-template-columns:repeat(2,1fr);
      }

      .solutions-grid{
        grid-template-columns:repeat(2,1fr);
      }
    }

    @media (max-width: 860px){
      .desktop-nav{
        display:none;
      }

      .menu-toggle{
        display:flex;
      }

      .mobile-panel{
        display:block;
        position:fixed;
        top:0;
        right:-100%;
        width:min(86%, 340px);
        height:100vh;
        background:#ffffff;
        box-shadow:-10px 0 30px rgba(0,0,0,.10);
        z-index:1001;
        transition:right .28s ease;
        padding:110px 24px 24px;
      }

      .mobile-panel.active{
        right:0;
      }

      .mobile-nav{
        display:grid;
        gap:14px;
      }

      .mobile-nav a{
        padding:14px 16px;
        border-radius:14px;
        background:#f8fbf5;
        color:var(--primary-dark);
        font-weight:700;
        border:1px solid var(--border);
      }

      .mobile-cta{
        margin-top:20px;
      }
    }

    @media (max-width: 780px){
      .hero{padding-top:42px}
      .solutions-grid,
      .timeline,
      .form-row,
      .hero-visual{
        grid-template-columns:1fr;
      }
      .hero-main-card{
        min-height:320px;
      }
      .mini-visual{
        min-height:240px;
      }
      .brand-text{
        display:none;
      }
      .brand img{
        height:100px;
      }
      .footer-logo{
        height:70px;
      }
    }

    @media (max-width: 520px){
      .btn{width:100%}
      .hero p{font-size:16px}
      .promo{padding:28px}
      .brand img{height:100px}
      .footer-logo{height:50px}
      .nav{
        min-height:86px;
      }
    }/* End custom CSS */